summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorAngus Kong <shkong@google.com>2011-10-31 20:00:05 +0000
committerAndroid Git Automerger <android-git-automerger@android.com>2011-10-31 20:00:05 +0000
commitbe6fec51025dbaadf3f23467e0233d4fba50ad73 (patch)
tree5c3b3bc076c84c2a61f74410c853bc6e67d5a2d2 /src
parent2f2eea563073f0a69f53c9ce858889d69cc790d6 (diff)
parent174b8b7fc4d55e8c63eb3ed0b71f1519a13e345d (diff)
downloadpackages_apps_LegacyCamera-be6fec51025dbaadf3f23467e0233d4fba50ad73.zip
packages_apps_LegacyCamera-be6fec51025dbaadf3f23467e0233d4fba50ad73.tar.gz
packages_apps_LegacyCamera-be6fec51025dbaadf3f23467e0233d4fba50ad73.tar.bz2
am 174b8b7f: Add forced sound for panorama mode.
* commit '174b8b7fc4d55e8c63eb3ed0b71f1519a13e345d': Add forced sound for panorama mode.
Diffstat (limited to 'src')
-rwxr-xr-xsrc/com/android/camera/panorama/PanoramaActivity.java42
1 files changed, 42 insertions, 0 deletions
diff --git a/src/com/android/camera/panorama/PanoramaActivity.java b/src/com/android/camera/panorama/PanoramaActivity.java
index d95ac03..81859ec 100755
--- a/src/com/android/camera/panorama/PanoramaActivity.java
+++ b/src/com/android/camera/panorama/PanoramaActivity.java
@@ -26,6 +26,7 @@ import com.android.camera.ModePicker;
import com.android.camera.OnClickAttr;
import com.android.camera.R;
import com.android.camera.ShutterButton;
+import com.android.camera.SoundPlayer;
import com.android.camera.Storage;
import com.android.camera.Thumbnail;
import com.android.camera.Util;
@@ -37,6 +38,7 @@ import android.app.ProgressDialog;
import android.content.ContentResolver;
import android.content.Context;
import android.content.DialogInterface;
+import android.content.res.AssetFileDescriptor;
import android.content.res.Resources;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
@@ -54,6 +56,8 @@ import android.net.Uri;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
+import android.os.ParcelFileDescriptor;
+import android.os.SystemProperties;
import android.util.Log;
import android.view.Gravity;
import android.view.Menu;
@@ -65,6 +69,7 @@ import android.widget.ImageView;
import android.widget.TextView;
import java.io.ByteArrayOutputStream;
+import java.io.FileNotFoundException;
import java.io.File;
import java.util.List;
@@ -99,6 +104,8 @@ public class PanoramaActivity extends ActivityBase implements
// Ratio of nanosecond to second
private static final float NS2S = 1.0f / 1000000000.0f;
+ private static final String VIDEO_RECORD_SOUND = "/system/media/audio/ui/VideoRecord.ogg";
+
private boolean mPausing;
private View mPanoLayout;
@@ -161,6 +168,8 @@ public class PanoramaActivity extends ActivityBase implements
private float[] mTransformMatrix;
private float mHorizontalViewAngle;
+ private SoundPlayer mRecordSound;
+
// Prefer FOCUS_MODE_INFINITY to FOCUS_MODE_CONTINUOUS_VIDEO because of
// getting a better image quality by the former.
private String mTargetFocusMode = Parameters.FOCUS_MODE_INFINITY;
@@ -706,9 +715,11 @@ public class PanoramaActivity extends ActivityBase implements
// right now.
switch (mCaptureState) {
case CAPTURE_STATE_VIEWFINDER:
+ if (mRecordSound != null) mRecordSound.play();
startCapture();
break;
case CAPTURE_STATE_MOSAIC:
+ if (mRecordSound != null) mRecordSound.play();
stopCapture(false);
}
}
@@ -900,6 +911,34 @@ public class PanoramaActivity extends ActivityBase implements
mMosaicFrameProcessor.initialize();
}
+ private void initSoundRecorder() {
+ // Construct sound player; use enforced sound output if necessary
+ File recordSoundFile = new File(VIDEO_RECORD_SOUND);
+ try {
+ ParcelFileDescriptor recordSoundParcel =
+ ParcelFileDescriptor.open(recordSoundFile,
+ ParcelFileDescriptor.MODE_READ_ONLY);
+ AssetFileDescriptor recordSoundAsset =
+ new AssetFileDescriptor(recordSoundParcel, 0,
+ AssetFileDescriptor.UNKNOWN_LENGTH);
+ if (SystemProperties.get("ro.camera.sound.forced", "0").equals("0")) {
+ mRecordSound = new SoundPlayer(recordSoundAsset, false);
+ } else {
+ mRecordSound = new SoundPlayer(recordSoundAsset, true);
+ }
+ } catch (java.io.FileNotFoundException e) {
+ Log.e(TAG, "System video record sound not found");
+ mRecordSound = null;
+ }
+ }
+
+ private void releaseSoundRecorder() {
+ if (mRecordSound != null) {
+ mRecordSound.release();
+ mRecordSound = null;
+ }
+ }
+
@Override
protected void onPause() {
super.onPause();
@@ -918,6 +957,7 @@ public class PanoramaActivity extends ActivityBase implements
}
releaseCamera();
+ releaseSoundRecorder();
mMosaicView.onPause();
clearMosaicFrameProcessorIfNeeded();
mOrientationEventListener.disable();
@@ -933,6 +973,8 @@ public class PanoramaActivity extends ActivityBase implements
mCaptureState = CAPTURE_STATE_VIEWFINDER;
setupCamera();
+ initSoundRecorder();
+
// Camera must be initialized before MosaicFrameProcessor is initialized. The preview size
// has to be decided by camera device.
initMosaicFrameProcessorIfNeeded();