diff --git a/app/build.gradle b/app/build.gradle index 61d228d0378f82397b1a179e73b8580eb62eeeaa..fa96ab9e369ce7b18e9acfd92e632f975b26a6cd 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -73,7 +73,7 @@ android { defaultConfig { applicationId "foundation.e.camera" - minSdkVersion 26 + minSdkVersion 29 targetSdkVersion 34 //compileSdkVersion 31 // needed to support appcompat:1.4.0 (which we need for emoji policy support, and not yet ready to target SDK 30) diff --git a/app/src/main/java/net/sourceforge/opencamera/MainActivity.java b/app/src/main/java/net/sourceforge/opencamera/MainActivity.java index 222b911eb3efc3af75d8dd1eefd4c2ccd3e70a15..f58967d2fe898d02c7f397fc403c2623b8f68020 100644 --- a/app/src/main/java/net/sourceforge/opencamera/MainActivity.java +++ b/app/src/main/java/net/sourceforge/opencamera/MainActivity.java @@ -1504,7 +1504,10 @@ public class MainActivity extends AppCompatActivity implements PreferenceFragmen for(Map.Entry entry : preloaded_bitmap_resources.entrySet()) { if( MyDebug.LOG ) Log.d(TAG, "recycle: " + entry.getKey()); - entry.getValue().recycle(); + Bitmap recycleValue = entry.getValue(); + if (recycleValue != null) { + recycleValue.recycle(); + } } preloaded_bitmap_resources.clear(); if( textToSpeech != null ) { @@ -5043,7 +5046,7 @@ public class MainActivity extends AppCompatActivity implements PreferenceFragmen final String REVIEW_ACTION = "com.android.camera.action.REVIEW"; final String KEY_FROM_SNAPCAM = "from-snapcam"; boolean done = false; - if( !is_raw ) { + if( !is_raw || (Build.VERSION.SDK_INT >= Build.VERSION_CODES.UPSIDE_DOWN_CAKE) ) { // REVIEW_ACTION means we can view video files without autoplaying. // However, Google Photos at least has problems with going to a RAW photo (in RAW only mode), // unless we first pause and resume Open Camera. @@ -5052,8 +5055,15 @@ public class MainActivity extends AppCompatActivity implements PreferenceFragmen if( MyDebug.LOG ) Log.d(TAG, "try REVIEW_ACTION"); try { - Intent intent = new Intent(REVIEW_ACTION, uri); - intent.putExtra(KEY_FROM_SNAPCAM, allowEdit); + Intent intent = new Intent(); + intent.setData(uri); + if (Build.VERSION.SDK_INT < Build.VERSION_CODES.UPSIDE_DOWN_CAKE) { + intent.setAction(REVIEW_ACTION); + intent.putExtra(KEY_FROM_SNAPCAM, allowEdit); + } else { + intent.setAction(MediaStore.ACTION_REVIEW); + intent.setFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION); + } this.startActivity(intent); done = true; } @@ -5066,7 +5076,9 @@ public class MainActivity extends AppCompatActivity implements PreferenceFragmen Log.d(TAG, "try ACTION_VIEW"); try { Intent intent = new Intent(Intent.ACTION_VIEW, uri); - intent.putExtra(KEY_FROM_SNAPCAM, allowEdit); + if (Build.VERSION.SDK_INT < Build.VERSION_CODES.UPSIDE_DOWN_CAKE) { + intent.putExtra(KEY_FROM_SNAPCAM, allowEdit); + } this.startActivity(intent); } catch(ActivityNotFoundException e) {