properly handle panorama photos without storage access
This commit is contained in:
parent
ffd15a417a
commit
83ab2ad56e
1 changed files with 8 additions and 10 deletions
|
@ -4,6 +4,7 @@ import android.content.res.Configuration
|
||||||
import android.graphics.Bitmap
|
import android.graphics.Bitmap
|
||||||
import android.graphics.BitmapFactory
|
import android.graphics.BitmapFactory
|
||||||
import android.graphics.Color
|
import android.graphics.Color
|
||||||
|
import android.net.Uri
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.Window
|
import android.view.Window
|
||||||
|
@ -14,7 +15,6 @@ import com.simplemobiletools.commons.extensions.beVisible
|
||||||
import com.simplemobiletools.commons.extensions.onGlobalLayout
|
import com.simplemobiletools.commons.extensions.onGlobalLayout
|
||||||
import com.simplemobiletools.commons.extensions.showErrorToast
|
import com.simplemobiletools.commons.extensions.showErrorToast
|
||||||
import com.simplemobiletools.commons.extensions.toast
|
import com.simplemobiletools.commons.extensions.toast
|
||||||
import com.simplemobiletools.commons.helpers.PERMISSION_WRITE_STORAGE
|
|
||||||
import com.simplemobiletools.commons.helpers.ensureBackgroundThread
|
import com.simplemobiletools.commons.helpers.ensureBackgroundThread
|
||||||
import com.simplemobiletools.gallery.pro.R
|
import com.simplemobiletools.gallery.pro.R
|
||||||
import com.simplemobiletools.gallery.pro.extensions.*
|
import com.simplemobiletools.gallery.pro.extensions.*
|
||||||
|
@ -48,14 +48,7 @@ open class PanoramaPhotoActivity : SimpleActivity() {
|
||||||
explore.setImageResource(if (isExploreEnabled) R.drawable.ic_explore_vector else R.drawable.ic_explore_off_vector)
|
explore.setImageResource(if (isExploreEnabled) R.drawable.ic_explore_vector else R.drawable.ic_explore_off_vector)
|
||||||
}
|
}
|
||||||
|
|
||||||
handlePermission(PERMISSION_WRITE_STORAGE) {
|
|
||||||
if (it) {
|
|
||||||
checkIntent()
|
checkIntent()
|
||||||
} else {
|
|
||||||
toast(R.string.no_storage_permissions)
|
|
||||||
finish()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onResume() {
|
override fun onResume() {
|
||||||
|
@ -144,7 +137,12 @@ open class PanoramaPhotoActivity : SimpleActivity() {
|
||||||
|
|
||||||
for (i in 0..10) {
|
for (i in 0..10) {
|
||||||
try {
|
try {
|
||||||
bitmap = BitmapFactory.decodeFile(path, options)
|
bitmap = if (path.startsWith("content://")) {
|
||||||
|
val inputStream = contentResolver.openInputStream(Uri.parse(path))
|
||||||
|
BitmapFactory.decodeStream(inputStream)
|
||||||
|
} else {
|
||||||
|
BitmapFactory.decodeFile(path, options)
|
||||||
|
}
|
||||||
break
|
break
|
||||||
} catch (e: OutOfMemoryError) {
|
} catch (e: OutOfMemoryError) {
|
||||||
options.inSampleSize *= 2
|
options.inSampleSize *= 2
|
||||||
|
|
Loading…
Reference in a new issue