From fd363b27e87ad4b9dc23bcd415d3d9fb5619cdfb Mon Sep 17 00:00:00 2001 From: Angus Kong Date: Mon, 1 Apr 2013 15:59:09 -0700 Subject: Handle InterruptedException in waitDone Dirty bit for mParameters should be set properly if getParameters is not finished. bug:8517092 Change-Id: I2259dc978465d23bff9c6852bec4a791f94137d0 --- src/com/android/camera/CameraManager.java | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) (limited to 'src/com/android/camera') diff --git a/src/com/android/camera/CameraManager.java b/src/com/android/camera/CameraManager.java index b1161cdc4..be82ea613 100644 --- a/src/com/android/camera/CameraManager.java +++ b/src/com/android/camera/CameraManager.java @@ -420,12 +420,20 @@ public class CameraManager { } public void setParameters(Parameters params) { - // TODO: check if this synchronous version is necessary + if (params == null) { + Log.v(TAG, "null parameters in setParameters()"); + return; + } mParametersIsDirty = true; mCameraHandler.obtainMessage(SET_PARAMETERS, params).sendToTarget(); } public void setParametersAsync(Parameters params) { + // TODO: remove this. + if (params == null) { + Log.v(TAG, "null parameters in setParameters()"); + return; + } mParametersIsDirty = true; mCameraHandler.removeMessages(SET_PARAMETERS_ASYNC); mCameraHandler.obtainMessage(SET_PARAMETERS_ASYNC, params).sendToTarget(); @@ -434,8 +442,7 @@ public class CameraManager { public Parameters getParameters() { if (mParametersIsDirty || mParameters == null) { mCameraHandler.sendEmptyMessage(GET_PARAMETERS); - waitDone(); - mParametersIsDirty = false; + if (waitDone()) mParametersIsDirty = false; } return mParameters; } @@ -445,7 +452,8 @@ public class CameraManager { ENABLE_SHUTTER_SOUND, (enable ? 1 : 0), 0).sendToTarget(); } - public void waitDone() { + // return false if cancelled. + public boolean waitDone() { final Object waitDoneLock = new Object(); final Runnable unlockRunnable = new Runnable() { @Override @@ -462,8 +470,10 @@ public class CameraManager { waitDoneLock.wait(); } catch (InterruptedException ex) { Log.v(TAG, "waitDone interrupted"); + return false; } } + return true; } } } -- cgit v1.2.3