summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xsrc/com/android/camera/SettingsManager.java27
1 files changed, 21 insertions, 6 deletions
diff --git a/src/com/android/camera/SettingsManager.java b/src/com/android/camera/SettingsManager.java
index 3d2c4658e..b3cf50eb2 100755
--- a/src/com/android/camera/SettingsManager.java
+++ b/src/com/android/camera/SettingsManager.java
@@ -1882,14 +1882,14 @@ public class SettingsManager implements ListMenu.SettingsListener {
}
private List<String> getSupportedIso(int cameraId) {
+ CameraCharacteristics cameraCharacteristics = mCharacteristics.get(cameraId);
List<String> supportedIso = new ArrayList<>();
- try {
- int[] range = mCharacteristics.get(cameraId).get(
- CaptureModule.ISO_AVAILABLE_MODES);
- supportedIso.add("auto");
+ supportedIso.add("auto");
- if (range != null) {
- for (int iso : range) {
+ try {
+ int[] modes = cameraCharacteristics.get(CaptureModule.ISO_AVAILABLE_MODES);
+ if (modes != null) {
+ for (int iso : modes) {
for (String key : KEY_ISO_INDEX.keySet()) {
if (KEY_ISO_INDEX.get(key).equals(iso)) {
supportedIso.add(key);
@@ -1903,6 +1903,21 @@ public class SettingsManager implements ListMenu.SettingsListener {
Log.w(TAG, "Supported ISO_AVAILABLE_MODES is null.");
} catch (IllegalArgumentException e) {
Log.w(TAG, "IllegalArgumentException Supported ISO_AVAILABLE_MODES is wrong.");
+
+ Range<Integer> range = mCharacteristics.get(cameraId).get(
+ CameraCharacteristics.SENSOR_INFO_SENSITIVITY_RANGE);
+ if (range != null) {
+ int max = range.getUpper();
+ int value = 50;
+ while (value <= max) {
+ if (range.contains(value)) {
+ supportedIso.add(String.valueOf(value));
+ }
+ value += 50;
+ }
+ } else {
+ Log.w(TAG, "Supported ISO range is null.");
+ }
}
return supportedIso;