diff options
author | Wu-cheng Li <wuchengli@google.com> | 2011-10-24 17:24:41 +0800 |
---|---|---|
committer | Wu-cheng Li <wuchengli@google.com> | 2011-10-24 17:43:14 +0800 |
commit | eb47ed18eb3eec902d1ce18d20530e296bd83d9e (patch) | |
tree | 8ec70f7bea271c3e6a272400cd92aa7129d4a6a6 /src | |
parent | 37eac5970dcac64ddb547f32f4a642c77b83a28f (diff) | |
download | LegacyCamera-eb47ed18eb3eec902d1ce18d20530e296bd83d9e.zip LegacyCamera-eb47ed18eb3eec902d1ce18d20530e296bd83d9e.tar.gz LegacyCamera-eb47ed18eb3eec902d1ce18d20530e296bd83d9e.tar.bz2 |
Fix video thumbnail is not displayed when intent passes the fd.
bug:5494625
Change-Id: I2bc482c05b9ca47bb566e351746a6e4dccdd6111
Diffstat (limited to 'src')
-rw-r--r-- | src/com/android/camera/Thumbnail.java | 15 | ||||
-rwxr-xr-x | src/com/android/camera/VideoCamera.java | 52 |
2 files changed, 45 insertions, 22 deletions
diff --git a/src/com/android/camera/Thumbnail.java b/src/com/android/camera/Thumbnail.java index a0f892b..165614b 100644 --- a/src/com/android/camera/Thumbnail.java +++ b/src/com/android/camera/Thumbnail.java @@ -36,6 +36,7 @@ import java.io.BufferedOutputStream; import java.io.DataInputStream; import java.io.DataOutputStream; import java.io.File; +import java.io.FileDescriptor; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; @@ -244,11 +245,23 @@ public class Thumbnail { return createThumbnail(uri, bitmap, orientation); } + public static Bitmap createVideoThumbnail(FileDescriptor fd, int targetWidth) { + return createVideoThumbnail(null, fd, targetWidth); + } + public static Bitmap createVideoThumbnail(String filePath, int targetWidth) { + return createVideoThumbnail(filePath, null, targetWidth); + } + + private static Bitmap createVideoThumbnail(String filePath, FileDescriptor fd, int targetWidth) { Bitmap bitmap = null; MediaMetadataRetriever retriever = new MediaMetadataRetriever(); try { - retriever.setDataSource(filePath); + if (filePath != null) { + retriever.setDataSource(filePath); + } else { + retriever.setDataSource(fd); + } bitmap = retriever.getFrameAtTime(-1); } catch (IllegalArgumentException ex) { // Assume this is a corrupt video file diff --git a/src/com/android/camera/VideoCamera.java b/src/com/android/camera/VideoCamera.java index 5ad9205..9f47d5c 100755 --- a/src/com/android/camera/VideoCamera.java +++ b/src/com/android/camera/VideoCamera.java @@ -949,6 +949,7 @@ public class VideoCamera extends ActivityBase } finishRecorderAndCloseCamera(); + closeVideoFileDescriptor(); if (mSharePopup != null) mSharePopup.dismiss(); @@ -1136,6 +1137,7 @@ public class VideoCamera extends ActivityBase Bundle myExtras = intent.getExtras(); long requestedSizeLimit = 0; + closeVideoFileDescriptor(); if (mIsVideoCaptureIntent && myExtras != null) { Uri saveUri = (Uri) myExtras.getParcelable(MediaStore.EXTRA_OUTPUT); if (saveUri != null) { @@ -1276,6 +1278,7 @@ public class VideoCamera extends ActivityBase Bundle myExtras = intent.getExtras(); long requestedSizeLimit = 0; + closeVideoFileDescriptor(); if (mIsVideoCaptureIntent && myExtras != null) { Uri saveUri = (Uri) myExtras.getParcelable(MediaStore.EXTRA_OUTPUT); if (saveUri != null) { @@ -1328,14 +1331,6 @@ public class VideoCamera extends ActivityBase mMediaRecorder = null; } mVideoFilename = null; - if (mVideoFileDescriptor != null) { - try { - mVideoFileDescriptor.close(); - } catch (IOException e) { - Log.e(TAG, "Fail to close fd", e); - } - mVideoFileDescriptor = null; - } } private void releaseEffectsRecorder() { @@ -1600,19 +1595,23 @@ public class VideoCamera extends ActivityBase } private void showAlert() { - if (mCurrentVideoFilename != null) { - Bitmap bitmap = Thumbnail.createVideoThumbnail(mCurrentVideoFilename, + Bitmap bitmap = null; + if (mVideoFileDescriptor != null) { + bitmap = Thumbnail.createVideoThumbnail(mVideoFileDescriptor.getFileDescriptor(), + mPreviewFrameLayout.getWidth()); + } else if (mCurrentVideoFilename != null) { + bitmap = Thumbnail.createVideoThumbnail(mCurrentVideoFilename, mPreviewFrameLayout.getWidth()); - if (bitmap != null) { - // MetadataRetriever already rotates the thumbnail. We should rotate - // it to match the UI orientation (and mirror if it is front-facing camera). - CameraInfo[] info = CameraHolder.instance().getCameraInfo(); - boolean mirror = (info[mCameraId].facing == CameraInfo.CAMERA_FACING_FRONT); - bitmap = Util.rotateAndMirror(bitmap, -mOrientationCompensationAtRecordStart, - mirror); - mReviewImage.setImageBitmap(bitmap); - mReviewImage.setVisibility(View.VISIBLE); - } + } + if (bitmap != null) { + // MetadataRetriever already rotates the thumbnail. We should rotate + // it to match the UI orientation (and mirror if it is front-facing camera). + CameraInfo[] info = CameraHolder.instance().getCameraInfo(); + boolean mirror = (info[mCameraId].facing == CameraInfo.CAMERA_FACING_FRONT); + bitmap = Util.rotateAndMirror(bitmap, -mOrientationCompensationAtRecordStart, + mirror); + mReviewImage.setImageBitmap(bitmap); + mReviewImage.setVisibility(View.VISIBLE); } Util.fadeOut(mShutterButton); @@ -1649,7 +1648,7 @@ public class VideoCamera extends ActivityBase try { if (effectsActive()) { - // This is asynchronous, so we cant add to media store now because thumbnail + // This is asynchronous, so we can't add to media store now because thumbnail // may not be ready. In such case addVideoToMediaStore is called later // through a callback from the MediaEncoderFilter to EffectsRecorder, // and then to the VideoCamera. @@ -2374,4 +2373,15 @@ public class VideoCamera extends ActivityBase } return ".3gp"; } + + private void closeVideoFileDescriptor() { + if (mVideoFileDescriptor != null) { + try { + mVideoFileDescriptor.close(); + } catch (IOException e) { + Log.e(TAG, "Fail to close fd", e); + } + mVideoFileDescriptor = null; + } + } } |