summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorAngus Kong <shkong@google.com>2011-08-11 18:00:29 +0800
committerAngus Kong <shkong@google.com>2011-08-15 13:12:43 +0800
commitef91f8514bf3c21091dde6b292f9616464dc32e8 (patch)
tree36464cf7aec9981dd52a6db6c1d2493af59bd692 /src
parent63364838e1f742ac74d47498ae8f51e1e6e7e902 (diff)
downloadLegacyCamera-ef91f8514bf3c21091dde6b292f9616464dc32e8.zip
LegacyCamera-ef91f8514bf3c21091dde6b292f9616464dc32e8.tar.gz
LegacyCamera-ef91f8514bf3c21091dde6b292f9616464dc32e8.tar.bz2
Generate High-res panorama.
bug:5105037 Change-Id: I06a5527b9b614ff3aedf7e1b5d1efd38938dbd3d
Diffstat (limited to 'src')
-rw-r--r--src/com/android/camera/panorama/PanoramaActivity.java98
1 files changed, 45 insertions, 53 deletions
diff --git a/src/com/android/camera/panorama/PanoramaActivity.java b/src/com/android/camera/panorama/PanoramaActivity.java
index d9645ff..c442404 100644
--- a/src/com/android/camera/panorama/PanoramaActivity.java
+++ b/src/com/android/camera/panorama/PanoramaActivity.java
@@ -60,7 +60,7 @@ import java.util.List;
public class PanoramaActivity extends Activity implements
ModePicker.OnModeChangeListener,
SurfaceTexture.OnFrameAvailableListener {
- public static final int DEFAULT_SWEEP_ANGLE = 60;
+ public static final int DEFAULT_SWEEP_ANGLE = 160;
public static final int DEFAULT_BLEND_MODE = Mosaic.BLENDTYPE_HORIZONTAL;
public static final int DEFAULT_CAPTURE_PIXELS = 960 * 720;
@@ -87,8 +87,6 @@ public class PanoramaActivity extends Activity implements
private MosaicRendererSurfaceView mRealTimeMosaicView;
private ShutterButton mShutterButton;
- private byte[] mFinalJpegData;
-
private int mPreviewWidth;
private int mPreviewHeight;
private Camera mCameraDevice;
@@ -372,7 +370,13 @@ public class PanoramaActivity extends Activity implements
Thread t = new Thread() {
@Override
public void run() {
- generateAndStoreFinalMosaic(false);
+ byte[] jpegData = generateFinalMosaic(false);
+ Bitmap bitmap = null;
+ if (jpegData != null) {
+ bitmap = BitmapFactory.decodeByteArray(jpegData, 0, jpegData.length);
+ }
+ mMainHandler.sendMessage(mMainHandler.obtainMessage(
+ MSG_FINAL_MOSAIC_READY, bitmap));
}
};
t.start();
@@ -446,7 +450,9 @@ public class PanoramaActivity extends Activity implements
Thread t = new Thread() {
@Override
public void run() {
- saveFinalMosaic();
+ byte[] jpegData = generateFinalMosaic(true);
+ savePanorama(jpegData);
+ mMainHandler.sendMessage(mMainHandler.obtainMessage(MSG_RESET_TO_PREVIEW));
}
};
t.start();
@@ -477,22 +483,21 @@ public class PanoramaActivity extends Activity implements
private void showFinalMosaic(Bitmap bitmap) {
if (bitmap != null) {
mReview.setImageBitmap(bitmap);
- mCaptureLayout.setVisibility(View.GONE);
- mPreview.setVisibility(View.INVISIBLE);
- mReviewLayout.setVisibility(View.VISIBLE);
- mCaptureView.setStatusText("");
- mCaptureView.setSweepAngle(0);
- mCaptureView.invalidate();
}
- }
-
- private void saveFinalMosaic() {
- if (mFinalJpegData != null) {
- Storage.addImage(getContentResolver(), mCurrentImagePath, mTimeTaken, null, 0,
- mFinalJpegData);
- mFinalJpegData = null;
+ mCaptureLayout.setVisibility(View.GONE);
+ mPreview.setVisibility(View.INVISIBLE);
+ mReviewLayout.setVisibility(View.VISIBLE);
+ mCaptureView.setStatusText("");
+ mCaptureView.setSweepAngle(0);
+ }
+
+ private void savePanorama(byte[] jpegData) {
+ if (jpegData != null) {
+ String imagePath = PanoUtil.createName(
+ getResources().getString(R.string.pano_file_name_format), mTimeTaken);
+ Storage.addImage(getContentResolver(), imagePath, mTimeTaken, null, 0,
+ jpegData);
}
- mMainHandler.sendMessage(mMainHandler.obtainMessage(MSG_RESET_TO_PREVIEW));
}
private void clearMosaicFrameProcessorIfNeeded() {
@@ -575,45 +580,32 @@ public class PanoramaActivity extends Activity implements
}
};
- public void generateAndStoreFinalMosaic(boolean highRes) {
+ public byte[] generateFinalMosaic(boolean highRes) {
mMosaicFrameProcessor.createMosaic(highRes);
- mCurrentImagePath = PanoUtil.createName(
- getResources().getString(R.string.pano_file_name_format), mTimeTaken);
-
- if (highRes) {
- mCurrentImagePath += "_HR";
- } else {
- mCurrentImagePath += "_LR";
+ byte[] imageData = mMosaicFrameProcessor.getFinalMosaicNV21();
+ if (imageData == null) {
+ Log.e(TAG, "getFinalMosaicNV21() returned null.");
+ return null;
}
- byte[] imageData = mMosaicFrameProcessor.getFinalMosaicNV21();
- int len = imageData.length - 8;
-
- int width = (imageData[len + 0] << 24) + ((imageData[len + 1] & 0xFF) << 16)
- + ((imageData[len + 2] & 0xFF) << 8) + (imageData[len + 3] & 0xFF);
- int height = (imageData[len + 4] << 24) + ((imageData[len + 5] & 0xFF) << 16)
- + ((imageData[len + 6] & 0xFF) << 8) + (imageData[len + 7] & 0xFF);
- Log.v(TAG, "ImLength = " + (len) + ", W = " + width + ", H = " + height);
-
- YuvImage yuvimage = new YuvImage(imageData, ImageFormat.NV21, width, height, null);
- ByteArrayOutputStream out = new ByteArrayOutputStream();
- yuvimage.compressToJpeg(new Rect(0, 0, width, height), 100, out);
- try {
- out.close();
- } catch (Exception e) {
- Log.e(TAG, "Exception in storing final mosaic", e);
- return;
- }
+ int len = imageData.length - 8;
+ int width = (imageData[len + 0] << 24) + ((imageData[len + 1] & 0xFF) << 16)
+ + ((imageData[len + 2] & 0xFF) << 8) + (imageData[len + 3] & 0xFF);
+ int height = (imageData[len + 4] << 24) + ((imageData[len + 5] & 0xFF) << 16)
+ + ((imageData[len + 6] & 0xFF) << 8) + (imageData[len + 7] & 0xFF);
+ Log.v(TAG, "ImLength = " + (len) + ", W = " + width + ", H = " + height);
- mFinalJpegData = out.toByteArray();
- Bitmap bitmap = BitmapFactory.decodeByteArray(mFinalJpegData, 0, mFinalJpegData.length);
- mMainHandler.sendMessage(mMainHandler.obtainMessage(MSG_FINAL_MOSAIC_READY, bitmap));
- // Now's a good time to run the GC. Since we won't do any explicit
- // allocation during the test, the GC should stay dormant and not
- // influence our results.
- System.runFinalization();
- System.gc();
+ YuvImage yuvimage = new YuvImage(imageData, ImageFormat.NV21, width, height, null);
+ ByteArrayOutputStream out = new ByteArrayOutputStream();
+ yuvimage.compressToJpeg(new Rect(0, 0, width, height), 100, out);
+ try {
+ out.close();
+ } catch (Exception e) {
+ Log.e(TAG, "Exception in storing final mosaic", e);
+ return null;
+ }
+ return out.toByteArray();
}
private void setPreviewTexture(SurfaceTexture surface) {