diff options
32 files changed, 516 insertions, 389 deletions
diff --git a/res/drawable-hdpi/button_zoom_in_disabled_holo.png b/res/drawable-hdpi/button_zoom_in_disabled_holo.png Binary files differdeleted file mode 100644 index 7688afe..0000000 --- a/res/drawable-hdpi/button_zoom_in_disabled_holo.png +++ /dev/null diff --git a/res/drawable-hdpi/button_zoom_in_holo.png b/res/drawable-hdpi/button_zoom_in_holo.png Binary files differdeleted file mode 100644 index dde4f48..0000000 --- a/res/drawable-hdpi/button_zoom_in_holo.png +++ /dev/null diff --git a/res/drawable-hdpi/button_zoom_in_pressed_holo.png b/res/drawable-hdpi/button_zoom_in_pressed_holo.png Binary files differdeleted file mode 100644 index d9f9f12..0000000 --- a/res/drawable-hdpi/button_zoom_in_pressed_holo.png +++ /dev/null diff --git a/res/drawable-hdpi/button_zoom_out_disabled_holo.png b/res/drawable-hdpi/button_zoom_out_disabled_holo.png Binary files differdeleted file mode 100644 index 832319e..0000000 --- a/res/drawable-hdpi/button_zoom_out_disabled_holo.png +++ /dev/null diff --git a/res/drawable-hdpi/button_zoom_out_holo.png b/res/drawable-hdpi/button_zoom_out_holo.png Binary files differdeleted file mode 100644 index 484542e..0000000 --- a/res/drawable-hdpi/button_zoom_out_holo.png +++ /dev/null diff --git a/res/drawable-hdpi/button_zoom_out_pressed_holo.png b/res/drawable-hdpi/button_zoom_out_pressed_holo.png Binary files differdeleted file mode 100644 index d2a3e59..0000000 --- a/res/drawable-hdpi/button_zoom_out_pressed_holo.png +++ /dev/null diff --git a/res/drawable-mdpi/button_zoom_in_disabled_holo.png b/res/drawable-mdpi/button_zoom_in_disabled_holo.png Binary files differdeleted file mode 100644 index 7688afe..0000000 --- a/res/drawable-mdpi/button_zoom_in_disabled_holo.png +++ /dev/null diff --git a/res/drawable-mdpi/button_zoom_in_holo.png b/res/drawable-mdpi/button_zoom_in_holo.png Binary files differdeleted file mode 100644 index dde4f48..0000000 --- a/res/drawable-mdpi/button_zoom_in_holo.png +++ /dev/null diff --git a/res/drawable-mdpi/button_zoom_in_pressed_holo.png b/res/drawable-mdpi/button_zoom_in_pressed_holo.png Binary files differdeleted file mode 100644 index d9f9f12..0000000 --- a/res/drawable-mdpi/button_zoom_in_pressed_holo.png +++ /dev/null diff --git a/res/drawable-mdpi/button_zoom_out_disabled_holo.png b/res/drawable-mdpi/button_zoom_out_disabled_holo.png Binary files differdeleted file mode 100644 index 832319e..0000000 --- a/res/drawable-mdpi/button_zoom_out_disabled_holo.png +++ /dev/null diff --git a/res/drawable-mdpi/button_zoom_out_holo.png b/res/drawable-mdpi/button_zoom_out_holo.png Binary files differdeleted file mode 100644 index 484542e..0000000 --- a/res/drawable-mdpi/button_zoom_out_holo.png +++ /dev/null diff --git a/res/drawable-mdpi/button_zoom_out_pressed_holo.png b/res/drawable-mdpi/button_zoom_out_pressed_holo.png Binary files differdeleted file mode 100644 index d2a3e59..0000000 --- a/res/drawable-mdpi/button_zoom_out_pressed_holo.png +++ /dev/null diff --git a/res/drawable-w1024dp-hdpi/ic_zoom_holo_light.png b/res/drawable-w1024dp-hdpi/ic_zoom_holo_light.png Binary files differnew file mode 100644 index 0000000..b90d1ac --- /dev/null +++ b/res/drawable-w1024dp-hdpi/ic_zoom_holo_light.png diff --git a/res/drawable-w1024dp-mdpi/btn_zoom_in.xml b/res/drawable-w1024dp-mdpi/btn_zoom_in.xml deleted file mode 100644 index d798b5a..0000000 --- a/res/drawable-w1024dp-mdpi/btn_zoom_in.xml +++ /dev/null @@ -1,21 +0,0 @@ -<?xml version="1.0" encoding="utf-8"?> -<!-- Copyright (C) 2010 The Android Open Source Project - - Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. ---> - -<selector xmlns:android="http://schemas.android.com/apk/res/android"> - <item android:state_pressed="true" android:drawable="@drawable/button_zoom_in_pressed_holo" /> - <item android:state_enabled="false" android:drawable="@drawable/button_zoom_in_disabled_holo" /> - <item android:drawable="@drawable/button_zoom_in_holo" /> -</selector> diff --git a/res/drawable-w1024dp-mdpi/btn_zoom_out.xml b/res/drawable-w1024dp-mdpi/btn_zoom_out.xml deleted file mode 100644 index 925327d..0000000 --- a/res/drawable-w1024dp-mdpi/btn_zoom_out.xml +++ /dev/null @@ -1,21 +0,0 @@ -<?xml version="1.0" encoding="utf-8"?> -<!-- Copyright (C) 2010 The Android Open Source Project - - Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. ---> - -<selector xmlns:android="http://schemas.android.com/apk/res/android"> - <item android:state_pressed="true" android:drawable="@drawable/button_zoom_out_pressed_holo" /> - <item android:state_enabled="false" android:drawable="@drawable/button_zoom_out_disabled_holo" /> - <item android:drawable="@drawable/button_zoom_out_holo" /> -</selector> diff --git a/res/drawable-w1024dp-mdpi/ic_zoom_holo_light.png b/res/drawable-w1024dp-mdpi/ic_zoom_holo_light.png Binary files differnew file mode 100644 index 0000000..0917b07 --- /dev/null +++ b/res/drawable-w1024dp-mdpi/ic_zoom_holo_light.png diff --git a/res/drawable-w1024dp-xhdpi/ic_zoom_holo_light.png b/res/drawable-w1024dp-xhdpi/ic_zoom_holo_light.png Binary files differnew file mode 100644 index 0000000..572294e --- /dev/null +++ b/res/drawable-w1024dp-xhdpi/ic_zoom_holo_light.png diff --git a/res/layout-w1024dp/camera_control.xml b/res/layout-w1024dp/camera_control.xml index 23bad2b..0ba7d6c 100644 --- a/res/layout-w1024dp/camera_control.xml +++ b/res/layout-w1024dp/camera_control.xml @@ -43,26 +43,13 @@ <com.android.camera.ui.IndicatorControlWheel android:id="@+id/indicator_control_wheel" android:layout_width="match_parent" android:layout_height="match_parent"> - <com.android.camera.ui.RotateImageView android:id="@+id/zoom_increment" - android:clickable="true" - android:layout_width="wrap_content" - android:layout_height="wrap_content" - android:src="@drawable/btn_zoom_in" - android:visibility="gone" /> - <com.android.camera.ui.RotateImageView android:id="@+id/zoom_decrement" - android:clickable="true" - android:layout_width="wrap_content" - android:layout_height="wrap_content" - android:src="@drawable/btn_zoom_out" - android:visibility="gone" /> </com.android.camera.ui.IndicatorControlWheel> + <com.android.camera.ui.ZoomControlWheel + android:id="@+id/zoom_control" + android:layout_width="match_parent" + android:layout_height="match_parent" + android:visibility="gone" /> </com.android.camera.ui.IndicatorControlWheelContainer> - <com.android.camera.ui.ZoomPicker - android:id="@+id/zoom_control" - android:layout_width="wrap_content" - android:layout_height="wrap_content" - android:visibility="gone"/> - <include layout="@layout/mode_picker"/> </com.android.camera.ui.ControlPanelLayout> diff --git a/src/com/android/camera/Camera.java b/src/com/android/camera/Camera.java index 5cd6ce6..c3c28c1 100644 --- a/src/com/android/camera/Camera.java +++ b/src/com/android/camera/Camera.java @@ -19,7 +19,7 @@ package com.android.camera; import com.android.camera.ui.CameraPicker; import com.android.camera.ui.FaceView; import com.android.camera.ui.FocusRectangle; -import com.android.camera.ui.IndicatorControl; +import com.android.camera.ui.IndicatorControlContainer; import com.android.camera.ui.RotateImageView; import com.android.camera.ui.RotateLayout; import com.android.camera.ui.SharePopup; @@ -249,7 +249,7 @@ public class Camera extends ActivityBase implements FocusManager.Listener, private Toast mNoShareToast; private final Handler mHandler = new MainHandler(); - private IndicatorControl mIndicatorControl; + private IndicatorControlContainer mIndicatorControlContainer; private PreferenceGroup mPreferenceGroup; // multiple cameras support @@ -335,8 +335,8 @@ public class Camera extends ActivityBase implements FocusManager.Listener, Editor editor = mPreferences.edit(); editor.putString(CameraSettings.KEY_EXPOSURE, "0"); editor.apply(); - if (mIndicatorControl != null) { - mIndicatorControl.reloadPreferences(); + if (mIndicatorControlContainer != null) { + mIndicatorControlContainer.reloadPreferences(); } } } @@ -460,48 +460,45 @@ public class Camera extends ActivityBase implements FocusManager.Listener, private void initializeZoomControl() { mZoomControl = (ZoomControl) findViewById(R.id.zoom_control); - if (!mParameters.isZoomSupported()) { - mZoomControl.setZoomSupported(false); - } + if (!mParameters.isZoomSupported()) return; mZoomControl.initialize(this); } - private void initializeZoom() { - if (!mParameters.isZoomSupported()) return; - mZoomMax = mParameters.getMaxZoom(); - mSmoothZoomSupported = mParameters.isSmoothZoomSupported(); - if (mZoomControl != null) { - mZoomControl.setZoomMax(mZoomMax); - mZoomControl.setZoomIndex(mParameters.getZoom()); - mZoomControl.setSmoothZoomSupported(mSmoothZoomSupported); - mZoomControl.setOnZoomChangeListener( - new ZoomControl.OnZoomChangedListener() { - // only for immediate zoom - @Override - public void onZoomValueChanged(int index) { - Camera.this.onZoomValueChanged(index); - } + private class ZoomChangeListener implements ZoomControl.OnZoomChangedListener { + // only for immediate zoom + @Override + public void onZoomValueChanged(int index) { + Camera.this.onZoomValueChanged(index); + } - // only for smooth zoom - @Override - public void onZoomStateChanged(int state) { - if (mPausing) return; + // only for smooth zoom + @Override + public void onZoomStateChanged(int state) { + if (mPausing) return; - Log.v(TAG, "zoom picker state=" + state); - if (state == ZoomControl.ZOOM_IN) { - Camera.this.onZoomValueChanged(mZoomMax); - } else if (state == ZoomControl.ZOOM_OUT){ - Camera.this.onZoomValueChanged(0); - } else { - mTargetZoomValue = -1; - if (mZoomState == ZOOM_START) { - mZoomState = ZOOM_STOPPING; - mCameraDevice.stopSmoothZoom(); - } - } + Log.v(TAG, "zoom picker state=" + state); + if (state == ZoomControl.ZOOM_IN) { + Camera.this.onZoomValueChanged(mZoomMax); + } else if (state == ZoomControl.ZOOM_OUT) { + Camera.this.onZoomValueChanged(0); + } else { + mTargetZoomValue = -1; + if (mZoomState == ZOOM_START) { + mZoomState = ZOOM_STOPPING; + mCameraDevice.stopSmoothZoom(); } - }); + } } + } + + private void initializeZoom() { + if (!mParameters.isZoomSupported()) return; + mZoomMax = mParameters.getMaxZoom(); + mSmoothZoomSupported = mParameters.isSmoothZoomSupported(); + mZoomControl.setZoomMax(mZoomMax); + mZoomControl.setZoomIndex(mParameters.getZoom()); + mZoomControl.setSmoothZoomSupported(mSmoothZoomSupported); + mZoomControl.setOnZoomChangeListener(new ZoomChangeListener()); mCameraDevice.setZoomChangeListener(mZoomListener); } @@ -556,7 +553,7 @@ public class Camera extends ActivityBase implements FocusManager.Listener, @Override public boolean onDown(MotionEvent e) { // Check if the popup window is visible. - View popup = mIndicatorControl.getActiveSettingPopup(); + View popup = mIndicatorControlContainer.getActiveSettingPopup(); if (popup == null) return false; @@ -564,9 +561,9 @@ public class Camera extends ActivityBase implements FocusManager.Listener, // event by themselves. Dismiss the popup window if users touch on // other areas. if (!Util.pointInView(e.getX(), e.getY(), popup) - && !Util.pointInView(e.getX(), e.getY(), mIndicatorControl) + && !Util.pointInView(e.getX(), e.getY(), mIndicatorControlContainer) && !Util.pointInView(e.getX(), e.getY(), mPreviewFrame)) { - mIndicatorControl.dismissSettingPopup(); + mIndicatorControlContainer.dismissSettingPopup(); // Let event fall through. } return false; @@ -824,7 +821,7 @@ public class Camera extends ActivityBase implements FocusManager.Listener, mZoomValue = value; // Update the UI when we get zoom value. - if (mZoomControl != null) mZoomControl.setZoomIndex(value); + mZoomControl.setZoomIndex(value); // Keep mParameters up to date. We do not getParameter again in // takePicture. If we do not do this, wrong zoom value will be set. @@ -1065,8 +1062,8 @@ public class Camera extends ActivityBase implements FocusManager.Listener, private void overrideCameraSettings(final String flashMode, final String whiteBalance, final String focusMode) { - if (mIndicatorControl != null) { - mIndicatorControl.overrideSettings( + if (mIndicatorControlContainer != null) { + mIndicatorControlContainer.overrideSettings( CameraSettings.KEY_FLASH_MODE, flashMode, CameraSettings.KEY_WHITE_BALANCE, whiteBalance, CameraSettings.KEY_FOCUS_MODE, focusMode); @@ -1092,8 +1089,9 @@ public class Camera extends ActivityBase implements FocusManager.Listener, private void initializeIndicatorControl() { // setting the indicator buttons. - mIndicatorControl = (IndicatorControl) findViewById(R.id.indicator_control); - if (mIndicatorControl == null) return; + mIndicatorControlContainer = + (IndicatorControlContainer) findViewById(R.id.indicator_control); + if (mIndicatorControlContainer == null) return; loadCameraPreferences(); final String[] SETTING_KEYS = { CameraSettings.KEY_WHITE_BALANCE, @@ -1105,20 +1103,24 @@ public class Camera extends ActivityBase implements FocusManager.Listener, CameraSettings.KEY_PICTURE_SIZE}; CameraPicker.setImageResourceId(R.drawable.ic_switch_photo_facing_holo_light); - mIndicatorControl.initialize(this, mPreferenceGroup, - CameraSettings.KEY_FLASH_MODE, SETTING_KEYS, OTHER_SETTING_KEYS); - mIndicatorControl.setListener(this); + mIndicatorControlContainer.initialize(this, mPreferenceGroup, + CameraSettings.KEY_FLASH_MODE, mParameters.isZoomSupported(), + SETTING_KEYS, OTHER_SETTING_KEYS); + mIndicatorControlContainer.setListener(this); } private boolean collapseCameraControls() { - if (mIndicatorControl != null && mIndicatorControl.dismissSettingPopup()) { + if ((mIndicatorControlContainer != null) + && mIndicatorControlContainer.dismissSettingPopup()) { return true; } return false; } private void enableCameraControls(boolean enable) { - if (mIndicatorControl != null) mIndicatorControl.setEnabled(enable); + if (mIndicatorControlContainer != null) { + mIndicatorControlContainer.setEnabled(enable); + } if (mModePicker != null) mModePicker.setEnabled(enable); if (mZoomControl != null) mZoomControl.setEnabled(enable); } @@ -1161,7 +1163,7 @@ public class Camera extends ActivityBase implements FocusManager.Listener, if (mThumbnailView != null) mThumbnailView.setDegree(degree); if (mModePicker != null) mModePicker.setDegree(degree); if (mSharePopup != null) mSharePopup.setOrientation(degree); - if (mIndicatorControl != null) mIndicatorControl.setDegree(degree); + if (mIndicatorControlContainer != null) mIndicatorControlContainer.setDegree(degree); if (mZoomControl != null) mZoomControl.setDegree(degree); } @@ -2153,13 +2155,13 @@ public class Camera extends ActivityBase implements FocusManager.Listener, if (mParameters.isZoomSupported()) { mZoomValue = 0; setCameraParametersWhenIdle(UPDATE_PARAM_ZOOM); - if (mZoomControl != null) mZoomControl.setZoomIndex(0); + mZoomControl.setZoomIndex(0); } - if (mIndicatorControl != null) { - mIndicatorControl.dismissSettingPopup(); + if (mIndicatorControlContainer != null) { + mIndicatorControlContainer.dismissSettingPopup(); CameraSettings.restorePreferences(Camera.this, mPreferences, mParameters); - mIndicatorControl.reloadPreferences(); + mIndicatorControlContainer.reloadPreferences(); onSharedPreferenceChanged(); } } diff --git a/src/com/android/camera/VideoCamera.java b/src/com/android/camera/VideoCamera.java index 759e760..dadc29a 100644 --- a/src/com/android/camera/VideoCamera.java +++ b/src/com/android/camera/VideoCamera.java @@ -17,12 +17,11 @@ package com.android.camera; import com.android.camera.ui.CameraPicker; -import com.android.camera.ui.IndicatorControl; +import com.android.camera.ui.IndicatorControlContainer; import com.android.camera.ui.IndicatorControlWheelContainer; import com.android.camera.ui.RotateImageView; import com.android.camera.ui.SharePopup; import com.android.camera.ui.ZoomControl; -import com.android.camera.ui.ZoomPicker; import android.content.ActivityNotFoundException; import android.content.BroadcastReceiver; @@ -139,7 +138,7 @@ public class VideoCamera extends ActivityBase private PreviewFrameLayout mPreviewFrameLayout; private SurfaceHolder mSurfaceHolder = null; - private IndicatorControl mIndicatorControl; + private IndicatorControlContainer mIndicatorControlContainer; private View mReviewControl; private Toast mNoShareToast; @@ -453,20 +452,24 @@ public class VideoCamera extends ActivityBase } private boolean collapseCameraControls() { - if (mIndicatorControl != null && mIndicatorControl.dismissSettingPopup()) { + if ((mIndicatorControlContainer != null) + && mIndicatorControlContainer.dismissSettingPopup()) { return true; } return false; } private void enableCameraControls(boolean enable) { - if (mIndicatorControl != null) mIndicatorControl.setEnabled(enable); + if (mIndicatorControlContainer != null) { + mIndicatorControlContainer.setEnabled(enable); + } if (mModePicker != null) mModePicker.setEnabled(enable); } private void initializeIndicatorControl() { - mIndicatorControl = (IndicatorControl) findViewById(R.id.indicator_control); - if (mIndicatorControl == null) return; + mIndicatorControlContainer = + (IndicatorControlContainer) findViewById(R.id.indicator_control); + if (mIndicatorControlContainer == null) return; loadCameraPreferences(); final String[] SETTING_KEYS = { @@ -477,10 +480,10 @@ public class VideoCamera extends ActivityBase CameraSettings.KEY_VIDEO_TIME_LAPSE_FRAME_INTERVAL}; CameraPicker.setImageResourceId(R.drawable.ic_switch_video_facing_holo_light); - mIndicatorControl.initialize(this, mPreferenceGroup, + mIndicatorControlContainer.initialize(this, mPreferenceGroup, CameraSettings.KEY_VIDEOCAMERA_FLASH_MODE, - SETTING_KEYS, OTHER_SETTING_KEYS); - mIndicatorControl.setListener(this); + mParameters.isZoomSupported(), SETTING_KEYS, OTHER_SETTING_KEYS); + mIndicatorControlContainer.setListener(this); mPopupGestureDetector = new GestureDetector(this, new PopupGestureListener()); } @@ -518,7 +521,7 @@ public class VideoCamera extends ActivityBase if (mThumbnailView != null) mThumbnailView.setDegree(degree); if (mModePicker != null) mModePicker.setDegree(degree); if (mSharePopup != null) mSharePopup.setOrientation(degree); - if (mIndicatorControl != null) mIndicatorControl.setDegree(degree); + if (mIndicatorControlContainer != null) mIndicatorControlContainer.setDegree(degree); } private void startPlayVideoActivity() { @@ -877,7 +880,9 @@ public class VideoCamera extends ActivityBase super.onPause(); mPausing = true; - if (mIndicatorControl != null) mIndicatorControl.dismissSettingPopup(); + if (mIndicatorControlContainer != null) { + mIndicatorControlContainer.dismissSettingPopup(); + } finishRecorderAndCloseCamera(); @@ -1376,9 +1381,10 @@ public class VideoCamera extends ActivityBase if (mReviewControl != null) mReviewControl.setVisibility(View.GONE); if (mCaptureTimeLapse) { if (Util.isTabletUI()) { - ((IndicatorControlWheelContainer) mIndicatorControl).startTimeLapseAnimation( - mTimeBetweenTimeLapseFrameCaptureMs, - mRecordingStartTime); + ((IndicatorControlWheelContainer) mIndicatorControlContainer) + .startTimeLapseAnimation( + mTimeBetweenTimeLapseFrameCaptureMs, + mRecordingStartTime); } } } else { @@ -1387,7 +1393,8 @@ public class VideoCamera extends ActivityBase if (mReviewControl != null) mReviewControl.setVisibility(View.VISIBLE); if (mCaptureTimeLapse) { if (Util.isTabletUI()) { - ((IndicatorControlWheelContainer) mIndicatorControl).stopTimeLapseAnimation(); + ((IndicatorControlWheelContainer) mIndicatorControlContainer) + .stopTimeLapseAnimation(); } } } @@ -1736,14 +1743,14 @@ public class VideoCamera extends ActivityBase if (mParameters.isZoomSupported()) { mZoomValue = 0; setCameraParameters(); - if (mZoomControl != null) mZoomControl.setZoomIndex(0); + mZoomControl.setZoomIndex(0); } - if (mIndicatorControl != null) { - mIndicatorControl.dismissSettingPopup(); + if (mIndicatorControlContainer != null) { + mIndicatorControlContainer.dismissSettingPopup(); CameraSettings.restorePreferences(VideoCamera.this, mPreferences, mParameters); - mIndicatorControl.reloadPreferences(); + mIndicatorControlContainer.reloadPreferences(); onSharedPreferenceChanged(); } } @@ -1824,65 +1831,59 @@ public class VideoCamera extends ActivityBase @Override public boolean onDown(MotionEvent e) { // Check if the popup window is visible. - View popup = mIndicatorControl.getActiveSettingPopup(); + View popup = mIndicatorControlContainer.getActiveSettingPopup(); if (popup == null) return false; // Let popup window or indicator wheel handle the event by // themselves. Dismiss the popup window if users touch on other // areas. if (!Util.pointInView(e.getX(), e.getY(), popup) - && !Util.pointInView(e.getX(), e.getY(), mIndicatorControl)) { - mIndicatorControl.dismissSettingPopup(); + && !Util.pointInView(e.getX(), e.getY(), mIndicatorControlContainer)) { + mIndicatorControlContainer.dismissSettingPopup(); // Let event fall through. } return false; } } + private class ZoomChangeListener implements ZoomControl.OnZoomChangedListener { + // only for immediate zoom + @Override + public void onZoomValueChanged(int index) { + VideoCamera.this.onZoomValueChanged(index); + } + + // only for smooth zoom + @Override + public void onZoomStateChanged(int state) { + if (mPausing) return; + + Log.v(TAG, "zoom picker state=" + state); + if (state == ZoomControl.ZOOM_IN) { + VideoCamera.this.onZoomValueChanged(mZoomMax); + } else if (state == ZoomControl.ZOOM_OUT){ + VideoCamera.this.onZoomValueChanged(0); + } else { + mTargetZoomValue = -1; + if (mZoomState == ZOOM_START) { + mZoomState = ZOOM_STOPPING; + mCameraDevice.stopSmoothZoom(); + } + } + } + } + private void initializeZoomControl() { mZoomControl = (ZoomControl) findViewById(R.id.zoom_control); - if (!mParameters.isZoomSupported()) { - mZoomControl.setZoomSupported(false); - return; - } + if (!mParameters.isZoomSupported()) return; mZoomControl.initialize(this); mZoomMax = mParameters.getMaxZoom(); mSmoothZoomSupported = mParameters.isSmoothZoomSupported(); - if (mZoomControl != null) { - if (Util.isTabletUI()) ((ZoomPicker) mZoomControl).initialize(this); - mZoomControl.setZoomMax(mZoomMax); - mZoomControl.setZoomIndex(mParameters.getZoom()); - mZoomControl.setSmoothZoomSupported(mSmoothZoomSupported); - mZoomControl.setOnZoomChangeListener( - new ZoomPicker.OnZoomChangedListener() { - // only for immediate zoom - @Override - public void onZoomValueChanged(int index) { - VideoCamera.this.onZoomValueChanged(index); - } - - // only for smooth zoom - @Override - public void onZoomStateChanged(int state) { - if (mPausing) return; - - Log.v(TAG, "zoom picker state=" + state); - if (state == ZoomPicker.ZOOM_IN) { - VideoCamera.this.onZoomValueChanged(mZoomMax); - } else if (state == ZoomPicker.ZOOM_OUT){ - VideoCamera.this.onZoomValueChanged(0); - } else { - mTargetZoomValue = -1; - if (mZoomState == ZOOM_START) { - mZoomState = ZOOM_STOPPING; - mCameraDevice.stopSmoothZoom(); - } - } - } - }); - } - + mZoomControl.setZoomMax(mZoomMax); + mZoomControl.setZoomIndex(mParameters.getZoom()); + mZoomControl.setSmoothZoomSupported(mSmoothZoomSupported); + mZoomControl.setOnZoomChangeListener(new ZoomChangeListener() ); mCameraDevice.setZoomChangeListener(mZoomListener); } @@ -1894,7 +1895,7 @@ public class VideoCamera extends ActivityBase mZoomValue = value; // Update the UI when we get zoom value. - if (mZoomControl != null) mZoomControl.setZoomIndex(value); + mZoomControl.setZoomIndex(value); // Keep mParameters up to date. We do not getParameter again in // takePicture. If we do not do this, wrong zoom value will be set. diff --git a/src/com/android/camera/ui/IndicatorControl.java b/src/com/android/camera/ui/IndicatorControl.java index d97646a..b31c751 100644 --- a/src/com/android/camera/ui/IndicatorControl.java +++ b/src/com/android/camera/ui/IndicatorControl.java @@ -74,18 +74,8 @@ public abstract class IndicatorControl extends RelativeLayout implements mOnIndicatorEventListener = listener; } - // For the initialization of first-level indicator control. - public void initialize(Context context, PreferenceGroup group, - String flashSetting, String[] keys, String[] otherSettingKeys) { - initialize(context, group, keys, otherSettingKeys); - } - - public void initialize(Context context, PreferenceGroup group, - String[] keys, String[] otherSettingKeys) { - // Initialize all variables and icons. + public void setPreferenceGroup(PreferenceGroup group) { mPreferenceGroup = group; - addControls(keys, otherSettingKeys); - requestLayout(); } protected void addControls(String[] keys, String[] otherSettingKeys) { diff --git a/src/com/android/camera/ui/IndicatorControlBar.java b/src/com/android/camera/ui/IndicatorControlBar.java index 6c2d15f..748e23c 100644 --- a/src/com/android/camera/ui/IndicatorControlBar.java +++ b/src/com/android/camera/ui/IndicatorControlBar.java @@ -21,6 +21,7 @@ import com.android.camera.R; import android.content.Context; import android.util.AttributeSet; +import android.view.MotionEvent; import android.view.View; import android.widget.ImageView; @@ -28,7 +29,7 @@ import android.widget.ImageView; * A view that contains the top-level indicator control. */ public class IndicatorControlBar extends IndicatorControl implements - View.OnClickListener { + View.OnClickListener, View.OnTouchListener { private static final String TAG = "IndicatorControlBar"; private ImageView mZoomIcon; @@ -41,7 +42,8 @@ public class IndicatorControlBar extends IndicatorControl implements public void initialize(Context context, PreferenceGroup group, String flashSetting, boolean zoomSupported) { // From UI spec, we have camera_flash setting on the first level. - super.initialize(context, group, new String[] {flashSetting}, null); + setPreferenceGroup(group); + addControls(new String[] {flashSetting}, null); // Add CameraPicker control. initializeCameraPicker(); @@ -49,7 +51,7 @@ public class IndicatorControlBar extends IndicatorControl implements // add Zoom Icon. if (zoomSupported) { mZoomIcon = (ImageView) findViewById(R.id.zoom_control_icon); - mZoomIcon.setOnClickListener(this); + mZoomIcon.setOnTouchListener(this); mZoomIcon.setVisibility(View.VISIBLE); } @@ -58,15 +60,21 @@ public class IndicatorControlBar extends IndicatorControl implements requestLayout(); } - public void onClick(View view) { + public boolean onTouch(View v, MotionEvent event) { dismissSettingPopup(); - if (view == mZoomIcon) { - mOnIndicatorEventListener.onIndicatorEvent( - OnIndicatorEventListener.EVENT_ENTER_ZOOM_CONTROL_BAR); - } else if (view == mSecondLevelIcon) { + if (event.getAction() == MotionEvent.ACTION_DOWN) { mOnIndicatorEventListener.onIndicatorEvent( - OnIndicatorEventListener.EVENT_ENTER_SECOND_LEVEL_INDICATOR_BAR); + OnIndicatorEventListener.EVENT_ENTER_ZOOM_CONTROL); + return true; } + return false; + } + + public void onClick(View view) { + dismissSettingPopup(); + // Only for the click on mSecondLevelIcon. + mOnIndicatorEventListener.onIndicatorEvent( + OnIndicatorEventListener.EVENT_ENTER_SECOND_LEVEL_INDICATOR_BAR); } @Override diff --git a/src/com/android/camera/ui/IndicatorControlBarContainer.java b/src/com/android/camera/ui/IndicatorControlBarContainer.java index 3695d56..0ca378d 100644 --- a/src/com/android/camera/ui/IndicatorControlBarContainer.java +++ b/src/com/android/camera/ui/IndicatorControlBarContainer.java @@ -22,6 +22,7 @@ import com.android.camera.R; import android.content.Context; import android.util.AttributeSet; +import android.view.MotionEvent; import android.view.View; import android.view.animation.Animation; import android.view.animation.AnimationUtils; @@ -30,8 +31,8 @@ import android.view.animation.AnimationUtils; * The IndicatorControlBarContainer is a IndicatorControl containing * IndicatorControlBar, SecondIndicatorControlBar and ZoomControlBar for Phone UI. */ -public class IndicatorControlBarContainer extends IndicatorControl implements - OnIndicatorEventListener { +public class IndicatorControlBarContainer extends IndicatorControlContainer + implements OnIndicatorEventListener { private static final String TAG = "IndicatorControlBarContainer"; private Animation mFadeIn, mFadeOut; @@ -45,8 +46,8 @@ public class IndicatorControlBarContainer extends IndicatorControl implements @Override public void initialize(Context context, PreferenceGroup group, - String flashSetting, String[] secondLevelKeys, - String[] secondLevelOtherSettingKeys) { + String flashSetting, boolean isZoomSupported, + String[] secondLevelKeys, String[] secondLevelOtherSettingKeys) { mZoomControlBar = (ZoomControlBar) findViewById(R.id.zoom_control); mZoomControlBar.setOnIndicatorEventListener(this); @@ -56,7 +57,7 @@ public class IndicatorControlBarContainer extends IndicatorControl implements mIndicatorControlBar = (IndicatorControlBar) findViewById(R.id.indicator_bar); mIndicatorControlBar.initialize(context, group, flashSetting, - mZoomControlBar.isZoomSupported()); + isZoomSupported); mIndicatorControlBar.setOnIndicatorEventListener(this); mSecondLevelIndicatorControlBar = (SecondLevelIndicatorControlBar) @@ -77,6 +78,18 @@ public class IndicatorControlBarContainer extends IndicatorControl implements mZoomControlBar.setDegree(degree); } + @Override + public boolean dispatchTouchEvent(MotionEvent event) { + if (mIndicatorControlBar.getVisibility() == View.VISIBLE) { + return mIndicatorControlBar.dispatchTouchEvent(event); + } else if (mSecondLevelIndicatorControlBar.getVisibility() == View.VISIBLE) { + return mSecondLevelIndicatorControlBar.dispatchTouchEvent(event); + } else if (mZoomControlBar.getVisibility() == View.VISIBLE) { + return mZoomControlBar.dispatchTouchEvent(event); + } + return false; + } + public void onIndicatorEvent(int event) { switch (event) { case OnIndicatorEventListener.EVENT_ENTER_SECOND_LEVEL_INDICATOR_BAR: @@ -91,12 +104,13 @@ public class IndicatorControlBarContainer extends IndicatorControl implements mIndicatorControlBar.setVisibility(View.VISIBLE); break; - case OnIndicatorEventListener.EVENT_ENTER_ZOOM_CONTROL_BAR: + case OnIndicatorEventListener.EVENT_ENTER_ZOOM_CONTROL: mIndicatorControlBar.setVisibility(View.GONE); mZoomControlBar.setVisibility(View.VISIBLE); + mZoomControlBar.startZoomControl(); break; - case OnIndicatorEventListener.EVENT_LEAVE_ZOOM_CONTROL_BAR: + case OnIndicatorEventListener.EVENT_LEAVE_ZOOM_CONTROL: mZoomControlBar.setVisibility(View.GONE); mIndicatorControlBar.setVisibility(View.VISIBLE); break; diff --git a/src/com/android/camera/ui/IndicatorControlContainer.java b/src/com/android/camera/ui/IndicatorControlContainer.java new file mode 100644 index 0000000..2e6711f --- /dev/null +++ b/src/com/android/camera/ui/IndicatorControlContainer.java @@ -0,0 +1,33 @@ +/* + * Copyright (C) 2011 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package com.android.camera.ui; + +import com.android.camera.PreferenceGroup; + +import android.content.Context; +import android.util.AttributeSet; + +public abstract class IndicatorControlContainer extends IndicatorControl { + public abstract void initialize(Context context, PreferenceGroup group, + String flashSetting, boolean isZoomSupported, + String[] keys, String[] otherSettingKeys); + + public IndicatorControlContainer(Context context, AttributeSet attrs) { + super(context, attrs); + } + +} diff --git a/src/com/android/camera/ui/IndicatorControlWheel.java b/src/com/android/camera/ui/IndicatorControlWheel.java index e432f6d..8d37b19 100644 --- a/src/com/android/camera/ui/IndicatorControlWheel.java +++ b/src/com/android/camera/ui/IndicatorControlWheel.java @@ -56,6 +56,7 @@ public class IndicatorControlWheel extends IndicatorControl implements private static final int SECOND_LEVEL_START_DEGREES = 60; private static final int SECOND_LEVEL_END_DEGREES = 300; private static final int CLOSE_ICON_DEFAULT_DEGREES = 315; + private static final int ZOOM_ICON_DEFAULT_DEGREES = 180; private static final int ANIMATION_TIME = 300; // milliseconds @@ -109,9 +110,7 @@ public class IndicatorControlWheel extends IndicatorControl implements private double mSectorRadians[] = new double[2]; private double mTouchSectorRadians[] = new double[2]; - // TODO: we won't need these buttons later once we switch to new zoom control. - private View mZoomIn; - private View mZoomOut; + private View mZoomIcon; public IndicatorControlWheel(Context context, AttributeSet attrs) { super(context, attrs); @@ -140,6 +139,7 @@ public class IndicatorControlWheel extends IndicatorControl implements @Override public void onClick(View view) { + if (view == mZoomIcon) return; mPressedIndex = -1; dismissSettingPopup(); mInAnimation = true; @@ -148,15 +148,23 @@ public class IndicatorControlWheel extends IndicatorControl implements } public void initialize(Context context, PreferenceGroup group, - String flashSetting, String[] keys, String[] otherSettingKeys) { + String flashSetting, boolean isZoomSupported, String[] keys, + String[] otherSettingKeys) { mShutterButtonRadius = IndicatorControlWheelContainer.SHUTTER_BUTTON_RADIUS; mStrokeWidth = Util.dpToPixel(IndicatorControlWheelContainer.STROKE_WIDTH); mWheelRadius = mShutterButtonRadius + mStrokeWidth * 0.5; + setPreferenceGroup(group); + // Add first-level controls. - super.initialize(context, group, new String[] {flashSetting}, null); + addControls(new String[] {flashSetting}, null); + + // Add Zoom Icon. + if (isZoomSupported) { + mZoomIcon = (ImageView) addImageButton(context, R.drawable.ic_zoom_holo_light, false); + } - // Add CameraPicker control. + // Add CameraPicker. initializeCameraPicker(); // Add second-level Indicator Icon. @@ -245,7 +253,16 @@ public class IndicatorControlWheel extends IndicatorControl implements } } if ((index != -1) && (action != MotionEvent.ACTION_MOVE)) { - getChildAt(index).dispatchTouchEvent(event); + View view = getChildAt(index); + // Switch to zoom control only if a touch down event is received. + if ((view == mZoomIcon) && (action == MotionEvent.ACTION_DOWN)) { + mPressedIndex = -1; + mOnIndicatorEventListener.onIndicatorEvent( + OnIndicatorEventListener.EVENT_ENTER_ZOOM_CONTROL); + return true; + } else { + getChildAt(index).dispatchTouchEvent(event); + } } // Once the button is up, reset the press index. mPressedIndex = (action == MotionEvent.ACTION_UP) ? -1 : index; @@ -319,7 +336,18 @@ public class IndicatorControlWheel extends IndicatorControl implements int sectors = (count <= 1) ? 0 : (count - 1); double sectorDegrees = FIRST_LEVEL_SECTOR_DEGREES; mSectorRadians[0] = Math.toRadians(sectorDegrees); - double degrees = (FIRST_LEVEL_END_DEGREES - sectors * sectorDegrees); + int zoomIndex = indexOfChild(mZoomIcon); + double degrees; + + // Make sure the zoom button is located at 180 degrees. If there are + // more buttons than we could show in the visible angle from 90 degrees + // to 270 degrees, the modification of FIRST_LEVEL_SECTOR_DEGREES is + // required then. + if (zoomIndex >= 0) { + degrees = ZOOM_ICON_DEFAULT_DEGREES - (zoomIndex * sectorDegrees); + } else { + degrees = FIRST_LEVEL_END_DEGREES - (sectors * sectorDegrees); + } mStartVisibleRadians[0] = Math.toRadians(degrees); int startIndex = 0; diff --git a/src/com/android/camera/ui/IndicatorControlWheelContainer.java b/src/com/android/camera/ui/IndicatorControlWheelContainer.java index 27f5455..b7b338f 100644 --- a/src/com/android/camera/ui/IndicatorControlWheelContainer.java +++ b/src/com/android/camera/ui/IndicatorControlWheelContainer.java @@ -31,7 +31,8 @@ import android.view.View; * ShutterButton, a IndicatorControlWheel (which combines first-level and * second-level indicators) and a ZoomControlWheel. */ -public class IndicatorControlWheelContainer extends IndicatorControl { +public class IndicatorControlWheelContainer extends IndicatorControlContainer + implements OnIndicatorEventListener { public static final int STROKE_WIDTH = 87; public static final int SHUTTER_BUTTON_RADIUS = 74; public static final int FULL_WHEEL_RADIUS = 93; @@ -41,6 +42,7 @@ public class IndicatorControlWheelContainer extends IndicatorControl { private View mShutterButton; private double mShutterButtonRadius; private IndicatorControlWheel mIndicatorControlWheel; + private ZoomControlWheel mZoomControlWheel; private int mCenterX, mCenterY; public IndicatorControlWheelContainer(Context context, AttributeSet attrs) { @@ -51,16 +53,35 @@ public class IndicatorControlWheelContainer extends IndicatorControl { protected void onFinishInflate() { mShutterButton = findViewById(R.id.shutter_button); mShutterButtonRadius = Util.dpToPixel(SHUTTER_BUTTON_RADIUS); + + mZoomControlWheel = (ZoomControlWheel) findViewById(R.id.zoom_control); + mZoomControlWheel.setOnIndicatorEventListener(this); + mIndicatorControlWheel = (IndicatorControlWheel) findViewById( R.id.indicator_control_wheel); } - @Override public void initialize(Context context, PreferenceGroup group, - String flashSetting, String[] keys, String[] otherSettingKeys) { - mIndicatorControlWheel.initialize(context, group, - flashSetting, keys, otherSettingKeys); - // TODO: add ZoomControlWheel here. + String flashSetting, boolean isZoomSupported, + String[] keys, String[] otherSettingKeys) { + mIndicatorControlWheel.initialize(context, group, flashSetting, + isZoomSupported, keys, otherSettingKeys); + mIndicatorControlWheel.setOnIndicatorEventListener(this); + } + + public void onIndicatorEvent(int event) { + switch (event) { + case OnIndicatorEventListener.EVENT_ENTER_ZOOM_CONTROL: + mIndicatorControlWheel.setVisibility(View.GONE); + mZoomControlWheel.setVisibility(View.VISIBLE); + mZoomControlWheel.startZoomControl(); + break; + + case OnIndicatorEventListener.EVENT_LEAVE_ZOOM_CONTROL: + mZoomControlWheel.setVisibility(View.GONE); + mIndicatorControlWheel.setVisibility(View.VISIBLE); + break; + } } @Override @@ -75,7 +96,11 @@ public class IndicatorControlWheelContainer extends IndicatorControl { // Check if the event should be dispatched to the shutter button. if (radius <= mShutterButtonRadius) { - mIndicatorControlWheel.onTouchOutBound(); + if (mIndicatorControlWheel.getVisibility() == View.VISIBLE) { + mIndicatorControlWheel.onTouchOutBound(); + } else { + return mZoomControlWheel.dispatchTouchEvent(event); + } if (action == MotionEvent.ACTION_DOWN || action == MotionEvent.ACTION_UP) { return mShutterButton.dispatchTouchEvent(event); } @@ -89,8 +114,11 @@ public class IndicatorControlWheelContainer extends IndicatorControl { return true; } - // TODO: dispatch event to ZoomControlWheel instead if it is visible. - return mIndicatorControlWheel.dispatchTouchEvent(event); + if (mIndicatorControlWheel.getVisibility() == View.VISIBLE) { + return mIndicatorControlWheel.dispatchTouchEvent(event); + } else { + return mZoomControlWheel.dispatchTouchEvent(event); + } } @Override @@ -108,6 +136,7 @@ public class IndicatorControlWheelContainer extends IndicatorControl { mCenterY + shutterButtonHeight - shutterButtonHeight / 2); // Layout the control wheel. mIndicatorControlWheel.layout(0, 0, right - left, bottom - top); + mZoomControlWheel.layout(0, 0, right - left, bottom - top); } @Override @@ -116,6 +145,7 @@ public class IndicatorControlWheelContainer extends IndicatorControl { int freeSpec = MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED); mShutterButton.measure(freeSpec, freeSpec); mIndicatorControlWheel.measure(freeSpec, freeSpec); + mZoomControlWheel.measure(freeSpec, freeSpec); // Measure myself. Add some buffer for highlight arc. int desiredWidth = mShutterButton.getMeasuredWidth() @@ -165,6 +195,7 @@ public class IndicatorControlWheelContainer extends IndicatorControl { @Override public void setDegree(int degree) { mIndicatorControlWheel.setDegree(degree); + mZoomControlWheel.setDegree(degree); } public void startTimeLapseAnimation(int timeLapseInterval, long startTime) { @@ -179,6 +210,7 @@ public class IndicatorControlWheelContainer extends IndicatorControl { @Override public void setEnabled(boolean enabled) { mIndicatorControlWheel.setEnabled(enabled); + mZoomControlWheel.setEnabled(enabled); } @Override diff --git a/src/com/android/camera/ui/OnIndicatorEventListener.java b/src/com/android/camera/ui/OnIndicatorEventListener.java index f4e1deb..566f5c7 100644 --- a/src/com/android/camera/ui/OnIndicatorEventListener.java +++ b/src/com/android/camera/ui/OnIndicatorEventListener.java @@ -19,7 +19,7 @@ package com.android.camera.ui; public interface OnIndicatorEventListener { public static int EVENT_ENTER_SECOND_LEVEL_INDICATOR_BAR = 0; public static int EVENT_LEAVE_SECOND_LEVEL_INDICATOR_BAR = 1; - public static int EVENT_ENTER_ZOOM_CONTROL_BAR = 2; - public static int EVENT_LEAVE_ZOOM_CONTROL_BAR = 3; + public static int EVENT_ENTER_ZOOM_CONTROL = 2; + public static int EVENT_LEAVE_ZOOM_CONTROL = 3; void onIndicatorEvent(int event); } diff --git a/src/com/android/camera/ui/SecondLevelIndicatorControlBar.java b/src/com/android/camera/ui/SecondLevelIndicatorControlBar.java index 8fb3599..5ce586e 100644 --- a/src/com/android/camera/ui/SecondLevelIndicatorControlBar.java +++ b/src/com/android/camera/ui/SecondLevelIndicatorControlBar.java @@ -40,7 +40,6 @@ public class SecondLevelIndicatorControlBar extends IndicatorControl implements super(context, attrs); } - @Override public void initialize(Context context, PreferenceGroup group, String[] keys, String[] otherSettingKeys) { if (mCloseIcon == null) { @@ -49,7 +48,8 @@ public class SecondLevelIndicatorControlBar extends IndicatorControl implements mCloseIcon.setOnClickListener(this); addView(mCloseIcon); } - super.initialize(context, group, keys, otherSettingKeys); + setPreferenceGroup(group); + addControls(keys, otherSettingKeys); if (mDegree != 0) setDegree(mDegree); } diff --git a/src/com/android/camera/ui/ZoomControl.java b/src/com/android/camera/ui/ZoomControl.java index 142e4b8..6bb22a9 100644 --- a/src/com/android/camera/ui/ZoomControl.java +++ b/src/com/android/camera/ui/ZoomControl.java @@ -19,8 +19,10 @@ package com.android.camera.ui; import com.android.camera.R; import android.content.Context; +import android.os.Handler; import android.util.AttributeSet; import android.view.View; +import android.widget.ImageView; import android.widget.RelativeLayout; /** @@ -30,15 +32,23 @@ import android.widget.RelativeLayout; public abstract class ZoomControl extends RelativeLayout { private static final String TAG = "ZoomControl"; + public static final int ZOOMING_INTERVAL = 300; // milliseconds + + protected ImageView mZoomIn; + protected ImageView mZoomOut; + protected ImageView mZoomSlider; + protected int mSliderPosition = 0; + protected int mDegree; + protected Handler mHandler; + public interface OnZoomChangedListener { void onZoomValueChanged(int index); // only for immediate zoom void onZoomStateChanged(int state); // only for smooth zoom } - private int mZoomMax, mZoomIndex; + protected int mZoomMax, mZoomIndex; private boolean mSmoothZoomSupported; private OnZoomChangedListener mListener; - private boolean mZoomSupported = true; // The state of zoom button. public static final int ZOOM_IN = 0; @@ -47,22 +57,53 @@ public abstract class ZoomControl extends RelativeLayout { protected OnIndicatorEventListener mOnIndicatorEventListener; + protected final Runnable mRunnable = new Runnable() { + public void run() { + if (mSliderPosition < 0) { + zoomIn(); + } else if (mSliderPosition > 0) { + zoomOut(); + } else { + stopZooming(); + } + mHandler.postDelayed(mRunnable, ZOOMING_INTERVAL); + } + }; + public ZoomControl(Context context, AttributeSet attrs) { super(context, attrs); } - public abstract void initialize(Context context); + public void initialize(Context context) { + mZoomIn = addImageView(context, R.drawable.ic_zoom_in_holo_light); + mZoomSlider = addImageView(context, R.drawable.btn_zoom_slider); + mZoomOut = addImageView(context, R.drawable.ic_zoom_out_holo_light); + mHandler = new Handler(); + } - public void setZoomMax(int zoomMax) { - mZoomMax = zoomMax; + public void startZoomControl() { + mZoomSlider.setPressed(true); + mHandler.postDelayed(mRunnable, ZOOMING_INTERVAL); } - public void setZoomSupported(boolean supported) { - mZoomSupported = supported; + protected ImageView addImageView(Context context, int iconResourceId) { + ImageView image = new RotateImageView(context); + image.setImageResource(iconResourceId); + addView(image); + return image; } - public boolean isZoomSupported() { - return mZoomSupported; + public void closeZoomControl() { + mHandler.removeCallbacks(mRunnable); + mSliderPosition = 0; + mZoomSlider.setPressed(false); + stopZooming(); + mOnIndicatorEventListener.onIndicatorEvent( + OnIndicatorEventListener.EVENT_LEAVE_ZOOM_CONTROL); + } + + public void setZoomMax(int zoomMax) { + mZoomMax = zoomMax; } public void setOnZoomChangeListener(OnZoomChangedListener listener) { @@ -78,6 +119,7 @@ public abstract class ZoomControl extends RelativeLayout { throw new IllegalArgumentException("Invalid zoom value:" + index); } mZoomIndex = index; + invalidate(); } public void setSmoothZoomSupported(boolean smoothZoomSupported) { @@ -108,13 +150,15 @@ public abstract class ZoomControl extends RelativeLayout { } } else { mListener.onZoomStateChanged(index); + mZoomIndex = index; + invalidate(); } - mZoomIndex = index; } return true; } public void setDegree(int degree) { + mDegree = degree; int count = getChildCount(); for (int i = 0 ; i < count ; ++i) { View view = getChildAt(i); @@ -123,8 +167,4 @@ public abstract class ZoomControl extends RelativeLayout { } } } - - protected int getZoomIndex() { - return mZoomIndex; - } } diff --git a/src/com/android/camera/ui/ZoomControlBar.java b/src/com/android/camera/ui/ZoomControlBar.java index 07ad143..fdfeb50 100644 --- a/src/com/android/camera/ui/ZoomControlBar.java +++ b/src/com/android/camera/ui/ZoomControlBar.java @@ -19,38 +19,16 @@ package com.android.camera.ui; import com.android.camera.R; import android.content.Context; -import android.os.Handler; import android.util.AttributeSet; import android.view.MotionEvent; import android.view.View; -import android.widget.ImageView; /** * A view that contains camera zoom control and its layout. */ public class ZoomControlBar extends ZoomControl { private static final String TAG = "ZoomControlBar"; - - private static final int ZOOMING_INTERVAL = 300; // milliseconds - - private ImageView mZoomIn; - private ImageView mZoomOut; - private ImageView mZoomSlider; private View mBar; - private int mSliderPosition = 0; - private Handler mHandler; - private int mDegree; - - private final Runnable mRunnable = new Runnable() { - public void run() { - if (mSliderPosition < 0) { - zoomIn(); - } else if (mSliderPosition > 0) { - zoomOut(); - } - if (mSliderPosition != 0) mHandler.postDelayed(mRunnable, ZOOMING_INTERVAL); - } - }; public ZoomControlBar(Context context, AttributeSet attrs) { super(context, attrs); @@ -58,28 +36,10 @@ public class ZoomControlBar extends ZoomControl { @Override public void initialize(Context context) { - mZoomIn = addImageView(context, R.drawable.ic_zoom_in_holo_light); + super.initialize(context); mBar = new View(context); mBar.setBackgroundResource(R.drawable.ic_zoom_big); addView(mBar); - mZoomSlider = addImageView(context, R.drawable.btn_zoom_slider); - mZoomOut = addImageView(context, R.drawable.ic_zoom_out_holo_light); - mHandler = new Handler(); - } - - ImageView addImageView(Context context, int iconResourceId) { - ImageView image = new RotateImageView(context); - image.setImageResource(iconResourceId); - addView(image); - return image; - } - - private void closeControl() { - mHandler.removeCallbacks(mRunnable); - mSliderPosition = 0; - stopZooming(); - mOnIndicatorEventListener.onIndicatorEvent( - OnIndicatorEventListener.EVENT_LEAVE_ZOOM_CONTROL_BAR); } @Override @@ -104,15 +64,10 @@ public class ZoomControlBar extends ZoomControl { // TODO: add fast zoom change here switch (action) { - case MotionEvent.ACTION_DOWN: - mHandler.postDelayed(mRunnable, ZOOMING_INTERVAL); - mZoomSlider.setPressed(true); - break; case MotionEvent.ACTION_OUTSIDE: case MotionEvent.ACTION_UP: case MotionEvent.ACTION_CANCEL: - mZoomSlider.setPressed(false); - closeControl(); + closeZoomControl(); break; default: requestLayout(); @@ -124,7 +79,6 @@ public class ZoomControlBar extends ZoomControl { public void setDegree(int degree) { // layout for the left-hand camera control if ((degree == 180) || (mDegree == 180)) requestLayout(); - mDegree = degree; super.setDegree(degree); } diff --git a/src/com/android/camera/ui/ZoomControlWheel.java b/src/com/android/camera/ui/ZoomControlWheel.java new file mode 100644 index 0000000..40c1124 --- /dev/null +++ b/src/com/android/camera/ui/ZoomControlWheel.java @@ -0,0 +1,180 @@ +/* + * Copyright (C) 2011 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package com.android.camera.ui; + +import com.android.camera.R; +import com.android.camera.Util; + +import android.content.Context; +import android.content.res.Resources; +import android.graphics.Canvas; +import android.graphics.Paint; +import android.graphics.RectF; +import android.util.AttributeSet; +import android.view.MotionEvent; +import android.view.View; + +/** + * A view that contains camera zoom control and its layout. + */ +public class ZoomControlWheel extends ZoomControl { + private static final String TAG = "ZoomControlWheel"; + private static final int HIGHLIGHT_WIDTH = 4; + private static final int HIGHLIGHT_DEGREES = 30; + private static final int TRAIL_WIDTH = 2; + private static final int ZOOM_IN_ICON_DEGREES = 60; + private static final int ZOOM_OUT_ICON_DEGREES = 300; + private static final int DEFAULT_SLIDER_POSITION = 180; + private static final int MAX_SLIDER_ANGLE = + ZOOM_OUT_ICON_DEGREES - (HIGHLIGHT_DEGREES / 2); + private static final int MIN_SLIDER_ANGLE = + ZOOM_IN_ICON_DEGREES + (HIGHLIGHT_DEGREES / 2); + private static final float EDGE_STROKE_WIDTH = 6f; + private static final double BUFFER_RADIANS = Math.toRadians(HIGHLIGHT_DEGREES / 2); + private double mSliderRadians = Math.toRadians(DEFAULT_SLIDER_POSITION); + + private final int HIGHLIGHT_COLOR; + private final int TRAIL_COLOR; + + // The center of the shutter button. + private int mCenterX, mCenterY; + // The width of the wheel stroke. + private int mStrokeWidth; + private double mShutterButtonRadius; + private double mWheelRadius; + private Paint mBackgroundPaint; + private RectF mBackgroundRect; + + public ZoomControlWheel(Context context, AttributeSet attrs) { + super(context, attrs); + setWillNotDraw(false); + + mBackgroundPaint = new Paint(); + mBackgroundPaint.setStyle(Paint.Style.STROKE); + mBackgroundPaint.setAntiAlias(true); + + mBackgroundRect = new RectF(); + Resources resources = context.getResources(); + HIGHLIGHT_COLOR = resources.getColor(R.color.review_control_pressed_color); + TRAIL_COLOR = resources.getColor(R.color.icon_disabled_color); + } + + @Override + public void initialize(Context context) { + super.initialize(context); + mShutterButtonRadius = IndicatorControlWheelContainer.SHUTTER_BUTTON_RADIUS; + mStrokeWidth = Util.dpToPixel(IndicatorControlWheelContainer.STROKE_WIDTH); + mWheelRadius = mShutterButtonRadius + mStrokeWidth * 0.5; + requestLayout(); + } + + @Override + public boolean dispatchTouchEvent(MotionEvent event) { + if (!onFilterTouchEventForSecurity(event)) return false; + int action = event.getAction(); + + double dx = event.getX() - mCenterX; + double dy = mCenterY - event.getY(); + double radius = Math.sqrt(dx * dx + dy * dy); + // Ignore the event if too far from the shutter button. + mSliderRadians = Math.atan2(dy, dx); + if (mSliderRadians < 0) mSliderRadians += Math.PI * 2; + if (mSliderRadians > (Math.PI + BUFFER_RADIANS)) { + mSliderPosition = 1; + } else { + mSliderPosition = (mSliderRadians < (Math.PI - BUFFER_RADIANS)) ? -1 : 0; + } + // We assume the slider button is pressed all the time when the + // zoom control is active. So we take care of the following events + // only. + switch (action) { + case MotionEvent.ACTION_OUTSIDE: + case MotionEvent.ACTION_UP: + case MotionEvent.ACTION_CANCEL: + closeZoomControl(); + break; + default: + requestLayout(); + } + return true; + } + + @Override + public void startZoomControl() { + super.startZoomControl(); + mSliderRadians = Math.toRadians(DEFAULT_SLIDER_POSITION); + } + + private void layoutIcon(View view, double radian) { + int x = mCenterX + (int)(mWheelRadius * Math.cos(radian)); + int y = mCenterY - (int)(mWheelRadius * Math.sin(radian)); + int width = view.getMeasuredWidth(); + int height = view.getMeasuredHeight(); + view.layout(x - width / 2, y - height / 2, x + width / 2, + y + height / 2); + } + + private double getSliderDrawAngle() { + double sliderAngle = mSliderRadians; + if (sliderAngle > Math.toRadians(MAX_SLIDER_ANGLE)) { + return Math.toRadians(MAX_SLIDER_ANGLE); + } else if (sliderAngle < Math.toRadians(MIN_SLIDER_ANGLE)) { + return Math.toRadians(MIN_SLIDER_ANGLE); + } + return sliderAngle; + } + + @Override + protected void onLayout( + boolean changed, int left, int top, int right, int bottom) { + mCenterX = right - left - Util.dpToPixel( + IndicatorControlWheelContainer.FULL_WHEEL_RADIUS); + mCenterY = (bottom - top) / 2; + layoutIcon(mZoomIn, Math.toRadians(ZOOM_IN_ICON_DEGREES)); + layoutIcon(mZoomOut, Math.toRadians(ZOOM_OUT_ICON_DEGREES)); + layoutIcon(mZoomSlider, getSliderDrawAngle()); + } + + private double getZoomIndexAngle() { + return Math.toRadians(MAX_SLIDER_ANGLE - + (MAX_SLIDER_ANGLE - MIN_SLIDER_ANGLE) * mZoomIndex / mZoomMax); + } + + private void drawArc(Canvas canvas, int startAngle, int sweepAngle, + double radius, int color, int width) { + mBackgroundRect.set((float) (mCenterX - radius), (float) (mCenterY - radius), + (float) (mCenterX + radius), (float) (mCenterY + radius)); + mBackgroundPaint.setStrokeWidth(width); + mBackgroundPaint.setStrokeCap(Paint.Cap.ROUND); + mBackgroundPaint.setColor(color); + canvas.drawArc(mBackgroundRect, startAngle, sweepAngle, false, mBackgroundPaint); + } + + @Override + protected void onDraw(Canvas canvas) { + // Draw slider highlight. + float delta = mStrokeWidth * 0.5f; + float radius = (float) (mWheelRadius + mStrokeWidth * 0.5 + EDGE_STROKE_WIDTH); + int degree = (int) Math.toDegrees(getZoomIndexAngle()); + drawArc(canvas, (-degree - HIGHLIGHT_DEGREES / 2), HIGHLIGHT_DEGREES, + radius, HIGHLIGHT_COLOR, HIGHLIGHT_WIDTH); + // Draw the slider trail. + drawArc(canvas, -MAX_SLIDER_ANGLE, (MAX_SLIDER_ANGLE - MIN_SLIDER_ANGLE), + mWheelRadius, TRAIL_COLOR, TRAIL_WIDTH); + super.onDraw(canvas); + } +} diff --git a/src/com/android/camera/ui/ZoomPicker.java b/src/com/android/camera/ui/ZoomPicker.java deleted file mode 100644 index d25b6f8..0000000 --- a/src/com/android/camera/ui/ZoomPicker.java +++ /dev/null @@ -1,100 +0,0 @@ -/* - * Copyright (C) 2010 The Android Open Source Project - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package com.android.camera.ui; - -import com.android.camera.R; - -import android.content.Context; -import android.os.Handler; -import android.util.AttributeSet; -import android.view.MotionEvent; -import android.view.View; -import android.view.View.OnTouchListener; - -/** - * A class to increase or decrease zoom - */ -public class ZoomPicker extends ZoomControl { - private final String TAG = "ZoomPicker"; - - private View mIncrementButton; - private View mDecrementButton; - private int mState = ZOOM_STOP; - - private Handler mHandler; - - public ZoomPicker(Context context, AttributeSet attrs) { - super(context, attrs); - } - - private final Runnable mRunnable = new Runnable() { - public void run() { - if (zooming()) mHandler.postDelayed(this, 65); - } - }; - - private boolean zooming() { - switch (mState) { - case ZOOM_IN: - return zoomIn(); - case ZOOM_OUT: - return zoomOut(); - default: - return false; - } - } - - @Override - public void initialize(Context context) { - final View increment = getRootView().findViewById(R.id.zoom_increment); - final View decrement = getRootView().findViewById(R.id.zoom_decrement); - - mHandler = new Handler(); - - OnTouchListener touchListener = new OnTouchListener() { - public boolean onTouch(View v, MotionEvent event) { - int action = event.getAction(); - if (action == MotionEvent.ACTION_DOWN) { - mState = (v == increment) ? ZOOM_IN : ZOOM_OUT; - if (zooming()) mHandler.postDelayed(mRunnable, 300); - } else if (action == MotionEvent.ACTION_UP - || action == MotionEvent.ACTION_CANCEL) { - int eventState = (v == increment) ? ZOOM_IN : ZOOM_OUT; - // Ignore the event if the current state does not match. - if (eventState == mState) { - stopZooming(); - mState = ZOOM_STOP; - } - } - return false; - } - }; - - mIncrementButton = increment; - mIncrementButton.setOnTouchListener(touchListener); - mIncrementButton.setVisibility(View.VISIBLE); - mDecrementButton = decrement; - mDecrementButton.setOnTouchListener(touchListener); - mDecrementButton.setVisibility(View.VISIBLE); - } - - public void setEnabled(boolean enabled) { - mIncrementButton.setEnabled(enabled); - mDecrementButton.setEnabled(enabled); - } - -} |