summaryrefslogtreecommitdiffstats
path: root/src/com/android/camera
diff options
context:
space:
mode:
Diffstat (limited to 'src/com/android/camera')
-rw-r--r--src/com/android/camera/Camera.java49
-rwxr-xr-xsrc/com/android/camera/ImageManager.java3
-rw-r--r--src/com/android/camera/MenuHelper.java12
-rw-r--r--src/com/android/camera/PhotoAppWidgetBind.java (renamed from src/com/android/camera/PhotoGadgetBind.java)40
-rw-r--r--src/com/android/camera/PhotoAppWidgetConfigure.java (renamed from src/com/android/camera/PhotoGadgetConfigure.java)32
-rw-r--r--src/com/android/camera/PhotoAppWidgetProvider.java (renamed from src/com/android/camera/PhotoGadgetProvider.java)58
-rw-r--r--src/com/android/camera/VideoCamera.java31
-rw-r--r--src/com/android/camera/ViewImage.java22
8 files changed, 150 insertions, 97 deletions
diff --git a/src/com/android/camera/Camera.java b/src/com/android/camera/Camera.java
index 3564508..71ed339 100644
--- a/src/com/android/camera/Camera.java
+++ b/src/com/android/camera/Camera.java
@@ -129,7 +129,6 @@ public class Camera extends Activity implements View.OnClickListener,
private android.hardware.Camera.Parameters mParameters;
private VideoPreview mSurfaceView;
private SurfaceHolder mSurfaceHolder = null;
- private View mBlackout = null;
private int mOriginalViewFinderWidth, mOriginalViewFinderHeight;
private int mViewFinderWidth, mViewFinderHeight;
@@ -204,7 +203,7 @@ public class Camera extends Activity implements View.OnClickListener,
case RESTART_PREVIEW: {
if (mStatus == SNAPSHOT_IN_PROGRESS) {
// We are still in the processing of taking the picture, wait.
- // This is is strange. Why are we polling?
+ // This is strange. Why are we polling?
// TODO remove polling
mHandler.sendEmptyMessageDelayed(RESTART_PREVIEW, 100);
} else if (mStatus == SNAPSHOT_COMPLETED){
@@ -293,15 +292,20 @@ public class Camera extends Activity implements View.OnClickListener,
mShutterCallbackTime = System.currentTimeMillis();
Log.v(TAG, "Shutter lag was " + (mShutterCallbackTime - mCaptureStartTime) + " ms.");
}
- if (mClickSound != null) {
- mClickSound.start();
- }
- mBlackout.setVisibility(View.VISIBLE);
- Size pictureSize = mParameters.getPictureSize();
+ // We are going to change the size of surface view and show captured
+ // image. Set it to invisible now and set it back to visible in
+ // surfaceChanged() so that users won't see the image is resized on
+ // the screen.
+ mSurfaceView.setVisibility(View.INVISIBLE);
// Resize the SurfaceView to the aspect-ratio of the still image
// and so that we can see the full image that was taken.
+ Size pictureSize = mParameters.getPictureSize();
mSurfaceView.setAspectRatio(pictureSize.width, pictureSize.height);
+
+ if (mClickSound != null) {
+ mClickSound.start();
+ }
}
};
@@ -314,7 +318,6 @@ public class Camera extends Activity implements View.OnClickListener,
Log.v(TAG, (mRawPictureCallbackTime - mShutterCallbackTime) + "ms elapsed between" +
" ShutterCallback and RawPictureCallback.");
}
- mBlackout.setVisibility(View.GONE);
}
};
@@ -326,6 +329,9 @@ public class Camera extends Activity implements View.OnClickListener,
}
public void onPictureTaken(byte [] jpegData, android.hardware.Camera camera) {
+ if (!canHandleCameraEvent()) {
+ return;
+ }
if (Config.LOGV)
Log.v(TAG, "got JpegPictureCallback...");
@@ -581,6 +587,9 @@ public class Camera extends Activity implements View.OnClickListener,
}
public void onSnap() {
+ if (!canHandleCameraEvent()) {
+ return;
+ }
if (DEBUG_TIME_OPERATIONS) mCaptureStartTime = System.currentTimeMillis();
// If we are already in the middle of taking a snapshot then we should just save
@@ -739,8 +748,6 @@ public class Camera extends Activity implements View.OnClickListener,
holder.addCallback(this);
holder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);
- mBlackout = findViewById(R.id.blackout);
-
if (!isImageCaptureIntent()) {
mLastPictureButton = (ImageView) findViewById(R.id.last_picture_button);
mLastPictureButton.setOnClickListener(this);
@@ -823,6 +830,9 @@ public class Camera extends Activity implements View.OnClickListener,
}
private void doAttach() {
+ if (!canHandleCameraEvent()) {
+ return;
+ }
Bitmap bitmap = mImageCapture.getLastBitmap();
String cropValue = null;
@@ -928,7 +938,16 @@ public class Camera extends Activity implements View.OnClickListener,
finish();
}
+ private boolean canHandleCameraEvent() {
+ // don't handle any shutter event before we have a valid
+ // imageCapture object.
+ return mImageCapture != null;
+ }
+
public void onShutterButtonFocus(ShutterButton button, boolean pressed) {
+ if (!canHandleCameraEvent()) {
+ return;
+ }
switch (button.getId()) {
case R.id.shutter_button:
doFocus(pressed);
@@ -937,6 +956,9 @@ public class Camera extends Activity implements View.OnClickListener,
}
public void onShutterButtonClick(ShutterButton button) {
+ if (!canHandleCameraEvent()) {
+ return;
+ }
switch (button.getId()) {
case R.id.shutter_button:
doSnap();
@@ -1010,8 +1032,6 @@ public class Camera extends Activity implements View.OnClickListener,
Log.w(TAG, "Exception caught while creating local tone generator: " + e);
mFocusToneGenerator = null;
}
-
- mBlackout.setVisibility(View.GONE);
}
private ImageManager.DataLocation dataLocation() {
@@ -1129,7 +1149,7 @@ public class Camera extends Activity implements View.OnClickListener,
mImageCapture.clearLastBitmap();
mImageCapture = null;
hidePostCaptureAlert();
-
+
super.onPause();
}
@@ -1279,10 +1299,11 @@ public class Camera extends Activity implements View.OnClickListener,
}
public void surfaceChanged(SurfaceHolder holder, int format, int w, int h) {
+ mSurfaceView.setVisibility(View.VISIBLE);
// if we're creating the surface, start the preview as well.
boolean preview = holder.isCreating();
setViewFinder(w, h, preview);
- mCaptureObject = mImageCapture;
+ mCaptureObject = mImageCapture;
}
public void surfaceCreated(SurfaceHolder holder) {
diff --git a/src/com/android/camera/ImageManager.java b/src/com/android/camera/ImageManager.java
index 6c3472b..b470f95 100755
--- a/src/com/android/camera/ImageManager.java
+++ b/src/com/android/camera/ImageManager.java
@@ -2095,6 +2095,9 @@ public class ImageManager {
} catch (NullPointerException ex) {
// we seem to get this if the file doesn't exist anymore
Log.e(TAG, "couldn't open thumbnail " + thumbUri + "; " + ex);
+ } catch (OutOfMemoryError ex) {
+ Log.e(TAG, "failed to allocate memory for thumbnail "
+ + thumbUri + "; " + ex);
}
}
} catch (Exception ex) {
diff --git a/src/com/android/camera/MenuHelper.java b/src/com/android/camera/MenuHelper.java
index 2bb532e..568b3a6 100644
--- a/src/com/android/camera/MenuHelper.java
+++ b/src/com/android/camera/MenuHelper.java
@@ -82,6 +82,8 @@ public class MenuHelper {
static public final int MENU_VIDEO_SHARE = 24;
static public final int MENU_VIDEO_TOSS = 27;
+ static private final long SHARE_FILE_LENGTH_LIMIT = 3L * 1024L * 1024L;
+
public static final int NO_STORAGE_ERROR = -1;
public static final int CANNOT_STAT_ERROR = -2;
@@ -226,8 +228,13 @@ public class MenuHelper {
public boolean onMenuItemClick(MenuItem item) {
onInvoke.run(new MenuCallback() {
public void run(Uri u, ImageManager.IImage image) {
- if (image == null)
+ if (image == null) return;
+ if (!isImage && getImageFileSize(image) > SHARE_FILE_LENGTH_LIMIT ) {
+ Toast.makeText(activity,
+ R.string.too_large_to_attach, Toast.LENGTH_LONG).show();
return;
+ }
+
Intent intent = new Intent();
intent.setAction(Intent.ACTION_SEND);
String mimeType = image.getMimeType();
@@ -564,6 +571,7 @@ public class MenuHelper {
Uri target = Images.Media.INTERNAL_CONTENT_URI.buildUpon().appendQueryParameter("bucketId",
ImageManager.CAMERA_IMAGE_BUCKET_ID).build();
Intent intent = new Intent(Intent.ACTION_VIEW, target);
+ intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
intent.putExtra("windowTitle", activity.getString(windowTitleId));
intent.putExtra("mediaTypes", mediaTypes);
// Request unspecified so that we match the current camera orientation rather than
@@ -586,6 +594,7 @@ public class MenuHelper {
new MenuItem.OnMenuItemClickListener() {
public boolean onMenuItemClick(MenuItem item) {
Intent intent = new Intent(MediaStore.INTENT_ACTION_STILL_IMAGE_CAMERA);
+ intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
try {
activity.startActivity(intent);
} catch (android.content.ActivityNotFoundException e) {
@@ -601,6 +610,7 @@ public class MenuHelper {
new MenuItem.OnMenuItemClickListener() {
public boolean onMenuItemClick(MenuItem item) {
Intent intent = new Intent(MediaStore.INTENT_ACTION_VIDEO_CAMERA);
+ intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
try {
activity.startActivity(intent);
} catch (android.content.ActivityNotFoundException e) {
diff --git a/src/com/android/camera/PhotoGadgetBind.java b/src/com/android/camera/PhotoAppWidgetBind.java
index fff19de..5e71a54 100644
--- a/src/com/android/camera/PhotoGadgetBind.java
+++ b/src/com/android/camera/PhotoAppWidgetBind.java
@@ -16,11 +16,11 @@
package com.android.camera;
-import com.android.camera.PhotoGadgetProvider.PhotoDatabaseHelper;
+import com.android.camera.PhotoAppWidgetProvider.PhotoDatabaseHelper;
import android.app.Activity;
+import android.appwidget.AppWidgetManager;
import android.content.Intent;
-import android.gadget.GadgetManager;
import android.graphics.Bitmap;
import android.os.Bundle;
import android.util.Log;
@@ -28,10 +28,10 @@ import android.widget.RemoteViews;
import java.util.ArrayList;
-public class PhotoGadgetBind extends Activity {
- static final String TAG = "PhotoGadgetBind";
+public class PhotoAppWidgetBind extends Activity {
+ static final String TAG = "PhotoAppWidgetBind";
- static final String EXTRA_GADGET_BITMAPS = "com.android.camera.gadgetbitmaps";
+ static final String EXTRA_APPWIDGET_BITMAPS = "com.android.camera.appwidgetbitmaps";
@Override
protected void onCreate(Bundle icicle) {
@@ -39,33 +39,33 @@ public class PhotoGadgetBind extends Activity {
finish();
// The caller has requested that we bind a given bitmap to a specific
- // gadgetId, which probably is happening during a Launcher upgrade. This
- // is dangerous because the caller could set bitmaps on gadgetIds they
+ // appWidgetId, which probably is happening during a Launcher upgrade. This
+ // is dangerous because the caller could set bitmaps on appWidgetIds they
// don't own, so we guard this call at the manifest level by requiring
- // the BIND_GADGET permission.
+ // the BIND_APPWIDGET permission.
final Intent intent = getIntent();
final Bundle extras = intent.getExtras();
- final int[] gadgetIds = extras.getIntArray(GadgetManager.EXTRA_GADGET_IDS);
- final ArrayList<Bitmap> bitmaps = extras.getParcelableArrayList(EXTRA_GADGET_BITMAPS);
+ final int[] appWidgetIds = extras.getIntArray(AppWidgetManager.EXTRA_APPWIDGET_IDS);
+ final ArrayList<Bitmap> bitmaps = extras.getParcelableArrayList(EXTRA_APPWIDGET_BITMAPS);
- if (gadgetIds == null || bitmaps == null ||
- gadgetIds.length != bitmaps.size()) {
- Log.e(TAG, "Problem parsing photo gadget bind request");
+ if (appWidgetIds == null || bitmaps == null ||
+ appWidgetIds.length != bitmaps.size()) {
+ Log.e(TAG, "Problem parsing photo widget bind request");
return;
}
- GadgetManager gadgetManager = GadgetManager.getInstance(this);
+ AppWidgetManager appWidgetManager = AppWidgetManager.getInstance(this);
PhotoDatabaseHelper helper = new PhotoDatabaseHelper(this);
- for (int i = 0; i < gadgetIds.length; i++) {
+ for (int i = 0; i < appWidgetIds.length; i++) {
// Store the cropped photo in our database
- int gadgetId = gadgetIds[i];
- helper.setPhoto(gadgetId, bitmaps.get(i));
+ int appWidgetId = appWidgetIds[i];
+ helper.setPhoto(appWidgetId, bitmaps.get(i));
- // Push newly updated gadget to surface
- RemoteViews views = PhotoGadgetProvider.buildUpdate(this, gadgetId, helper);
- gadgetManager.updateGadget(new int[] { gadgetId }, views);
+ // Push newly updated widget to surface
+ RemoteViews views = PhotoAppWidgetProvider.buildUpdate(this, appWidgetId, helper);
+ appWidgetManager.updateAppWidget(new int[] { appWidgetId }, views);
}
helper.close();
diff --git a/src/com/android/camera/PhotoGadgetConfigure.java b/src/com/android/camera/PhotoAppWidgetConfigure.java
index a94b5a3..14e6112 100644
--- a/src/com/android/camera/PhotoGadgetConfigure.java
+++ b/src/com/android/camera/PhotoAppWidgetConfigure.java
@@ -16,13 +16,13 @@
package com.android.camera;
-import com.android.camera.PhotoGadgetProvider.PhotoDatabaseHelper;
+import com.android.camera.PhotoAppWidgetProvider.PhotoDatabaseHelper;
import android.app.Activity;
+import android.appwidget.AppWidgetManager;
import android.content.ContentValues;
import android.content.Intent;
import android.database.sqlite.SQLiteDatabase;
-import android.gadget.GadgetManager;
import android.graphics.Bitmap;
import android.os.Bundle;
import android.os.Parcelable;
@@ -32,22 +32,22 @@ import android.widget.RemoteViews;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
-public class PhotoGadgetConfigure extends Activity {
- static final private String TAG = "PhotoGadgetConfigure";
+public class PhotoAppWidgetConfigure extends Activity {
+ static final private String TAG = "PhotoAppWidgetConfigure";
static final int REQUEST_GET_PHOTO = 2;
- int gadgetId = -1;
+ int appWidgetId = -1;
@Override
protected void onCreate(Bundle icicle) {
super.onCreate(icicle);
- // Someone is requesting that we configure the given gadgetId, which means
+ // Someone is requesting that we configure the given appWidgetId, which means
// we prompt the user to pick and crop a photo.
- gadgetId = getIntent().getIntExtra(GadgetManager.EXTRA_GADGET_ID, -1);
- if (gadgetId == -1) {
+ appWidgetId = getIntent().getIntExtra(AppWidgetManager.EXTRA_APPWIDGET_ID, -1);
+ if (appWidgetId == -1) {
setResult(Activity.RESULT_CANCELED);
finish();
}
@@ -69,27 +69,27 @@ public class PhotoGadgetConfigure extends Activity {
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
- if (resultCode == RESULT_OK && gadgetId != -1) {
+ if (resultCode == RESULT_OK && appWidgetId != -1) {
// Store the cropped photo in our database
Bitmap bitmap = (Bitmap) data.getParcelableExtra("data");
PhotoDatabaseHelper helper = new PhotoDatabaseHelper(this);
- if (helper.setPhoto(gadgetId, bitmap)) {
+ if (helper.setPhoto(appWidgetId, bitmap)) {
resultCode = Activity.RESULT_OK;
- // Push newly updated gadget to surface
- RemoteViews views = PhotoGadgetProvider.buildUpdate(this, gadgetId, helper);
- GadgetManager gadgetManager = GadgetManager.getInstance(this);
- gadgetManager.updateGadget(new int[] { gadgetId }, views);
+ // Push newly updated widget to surface
+ RemoteViews views = PhotoAppWidgetProvider.buildUpdate(this, appWidgetId, helper);
+ AppWidgetManager appWidgetManager = AppWidgetManager.getInstance(this);
+ appWidgetManager.updateAppWidget(new int[] { appWidgetId }, views);
}
helper.close();
} else {
resultCode = Activity.RESULT_CANCELED;
}
- // Make sure we pass back the original gadgetId
+ // Make sure we pass back the original appWidgetId
Intent resultValue = new Intent();
- resultValue.putExtra(GadgetManager.EXTRA_GADGET_ID, gadgetId);
+ resultValue.putExtra(AppWidgetManager.EXTRA_APPWIDGET_ID, appWidgetId);
setResult(resultCode, resultValue);
finish();
}
diff --git a/src/com/android/camera/PhotoGadgetProvider.java b/src/com/android/camera/PhotoAppWidgetProvider.java
index b03217d..398528e 100644
--- a/src/com/android/camera/PhotoGadgetProvider.java
+++ b/src/com/android/camera/PhotoAppWidgetProvider.java
@@ -23,6 +23,8 @@ import org.xmlpull.v1.XmlPullParserException;
import android.app.Activity;
import android.app.PendingIntent;
+import android.appwidget.AppWidgetManager;
+import android.appwidget.AppWidgetProvider;
import android.content.BroadcastReceiver;
import android.content.ComponentName;
import android.content.ContentResolver;
@@ -36,8 +38,6 @@ import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteException;
import android.database.sqlite.SQLiteOpenHelper;
-import android.gadget.GadgetManager;
-import android.gadget.GadgetProvider;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.net.Uri;
@@ -61,41 +61,41 @@ import java.io.FileReader;
import java.io.IOException;
/**
- * Simple gadget to show a user-selected picture.
+ * Simple widget to show a user-selected picture.
*/
-public class PhotoGadgetProvider extends GadgetProvider {
- static final String TAG = "PhotoGadgetProvider";
+public class PhotoAppWidgetProvider extends AppWidgetProvider {
+ static final String TAG = "PhotoAppWidgetProvider";
static final boolean LOGD = Config.LOGD || true;
@Override
- public void onUpdate(Context context, GadgetManager gadgetManager, int[] gadgetIds) {
- // Update each requested gadgetId with its unique photo
+ public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {
+ // Update each requested appWidgetId with its unique photo
PhotoDatabaseHelper helper = new PhotoDatabaseHelper(context);
- for (int gadgetId : gadgetIds) {
- int[] specificGadget = new int[] { gadgetId };
- RemoteViews views = buildUpdate(context, gadgetId, helper);
- if (LOGD) Log.d(TAG, "sending out views="+views+" for id="+gadgetId);
- gadgetManager.updateGadget(specificGadget, views);
+ for (int appWidgetId : appWidgetIds) {
+ int[] specificAppWidget = new int[] { appWidgetId };
+ RemoteViews views = buildUpdate(context, appWidgetId, helper);
+ if (LOGD) Log.d(TAG, "sending out views="+views+" for id="+appWidgetId);
+ appWidgetManager.updateAppWidget(specificAppWidget, views);
}
helper.close();
}
@Override
- public void onDeleted(Context context, int[] gadgetIds) {
+ public void onDeleted(Context context, int[] appWidgetIds) {
// Clean deleted photos out of our database
PhotoDatabaseHelper helper = new PhotoDatabaseHelper(context);
- for (int gadgetId : gadgetIds) {
- helper.deletePhoto(gadgetId);
+ for (int appWidgetId : appWidgetIds) {
+ helper.deletePhoto(appWidgetId);
}
helper.close();
}
/**
- * Load photo for given gadget and build {@link RemoteViews} for it.
+ * Load photo for given widget and build {@link RemoteViews} for it.
*/
- static RemoteViews buildUpdate(Context context, int gadgetId, PhotoDatabaseHelper helper) {
+ static RemoteViews buildUpdate(Context context, int appWidgetId, PhotoDatabaseHelper helper) {
RemoteViews views = null;
- Bitmap bitmap = helper.getPhoto(gadgetId);
+ Bitmap bitmap = helper.getPhoto(appWidgetId);
if (bitmap != null) {
views = new RemoteViews(context.getPackageName(), R.layout.photo_frame);
views.setImageViewBitmap(R.id.photo, bitmap);
@@ -111,7 +111,7 @@ public class PhotoGadgetProvider extends GadgetProvider {
private static final int DATABASE_VERSION = 1;
static final String TABLE_PHOTOS = "photos";
- static final String FIELD_GADGET_ID = "gadgetId";
+ static final String FIELD_APPWIDGET_ID = "appWidgetId";
static final String FIELD_PHOTO_BLOB = "photoBlob";
PhotoDatabaseHelper(Context context) {
@@ -122,7 +122,7 @@ public class PhotoGadgetProvider extends GadgetProvider {
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL("CREATE TABLE " + TABLE_PHOTOS + " (" +
- FIELD_GADGET_ID + " INTEGER PRIMARY KEY," +
+ FIELD_APPWIDGET_ID + " INTEGER PRIMARY KEY," +
FIELD_PHOTO_BLOB + " BLOB" +
");");
}
@@ -139,9 +139,9 @@ public class PhotoGadgetProvider extends GadgetProvider {
}
/**
- * Store the given bitmap in this database for the given gadgetId.
+ * Store the given bitmap in this database for the given appWidgetId.
*/
- public boolean setPhoto(int gadgetId, Bitmap bitmap) {
+ public boolean setPhoto(int appWidgetId, Bitmap bitmap) {
boolean success = false;
try {
// Try go guesstimate how much space the icon will take when serialized
@@ -153,7 +153,7 @@ public class PhotoGadgetProvider extends GadgetProvider {
out.close();
ContentValues values = new ContentValues();
- values.put(PhotoDatabaseHelper.FIELD_GADGET_ID, gadgetId);
+ values.put(PhotoDatabaseHelper.FIELD_APPWIDGET_ID, appWidgetId);
values.put(PhotoDatabaseHelper.FIELD_PHOTO_BLOB, out.toByteArray());
SQLiteDatabase db = getWritableDatabase();
@@ -176,14 +176,14 @@ public class PhotoGadgetProvider extends GadgetProvider {
static final int INDEX_PHOTO_BLOB = 0;
/**
- * Inflate and return a bitmap for the given gadgetId.
+ * Inflate and return a bitmap for the given appWidgetId.
*/
- public Bitmap getPhoto(int gadgetId) {
+ public Bitmap getPhoto(int appWidgetId) {
Cursor c = null;
Bitmap bitmap = null;
try {
SQLiteDatabase db = getReadableDatabase();
- String selection = String.format("%s=%d", FIELD_GADGET_ID, gadgetId);
+ String selection = String.format("%s=%d", FIELD_APPWIDGET_ID, appWidgetId);
c = db.query(TABLE_PHOTOS, PHOTOS_PROJECTION, selection, null,
null, null, null, null);
@@ -206,12 +206,12 @@ public class PhotoGadgetProvider extends GadgetProvider {
}
/**
- * Remove any bitmap associated with the given gadgetId.
+ * Remove any bitmap associated with the given appWidgetId.
*/
- public void deletePhoto(int gadgetId) {
+ public void deletePhoto(int appWidgetId) {
try {
SQLiteDatabase db = getWritableDatabase();
- String whereClause = String.format("%s=%d", FIELD_GADGET_ID, gadgetId);
+ String whereClause = String.format("%s=%d", FIELD_APPWIDGET_ID, appWidgetId);
db.delete(TABLE_PHOTOS, whereClause, null);
} catch (SQLiteException e) {
Log.e(TAG, "Could not delete photo from database", e);
diff --git a/src/com/android/camera/VideoCamera.java b/src/com/android/camera/VideoCamera.java
index 70b1646..1fb22e1 100644
--- a/src/com/android/camera/VideoCamera.java
+++ b/src/com/android/camera/VideoCamera.java
@@ -84,6 +84,7 @@ public class VideoCamera extends Activity implements View.OnClickListener,
private static final long NO_STORAGE_ERROR = -1L;
private static final long CANNOT_STAT_ERROR = -2L;
private static final long LOW_STORAGE_THRESHOLD = 512L * 1024L;
+ private static final long SHARE_FILE_LENGTH_LIMIT = 3L * 1024L * 1024L;
private static final int STORAGE_STATUS_OK = 0;
private static final int STORAGE_STATUS_LOW = 1;
@@ -264,6 +265,24 @@ public class VideoCamera extends Activity implements View.OnClickListener,
mVideoFrame = (ImageView) findViewById(R.id.video_frame);
}
+ private void startShareVideoActivity() {
+ long fileLength = new File(mCurrentVideoFilename).length();
+ if (fileLength > SHARE_FILE_LENGTH_LIMIT) {
+ Toast.makeText(VideoCamera.this,
+ R.string.too_large_to_attach, Toast.LENGTH_LONG).show();
+ return;
+ }
+ Intent intent = new Intent();
+ intent.setAction(Intent.ACTION_SEND);
+ intent.setType("video/3gpp");
+ intent.putExtra(Intent.EXTRA_STREAM, mCurrentVideoUri);
+ try {
+ startActivity(Intent.createChooser(intent, getText(R.string.sendVideo)));
+ } catch (android.content.ActivityNotFoundException ex) {
+ Toast.makeText(VideoCamera.this, R.string.no_way_to_share_video, Toast.LENGTH_SHORT).show();
+ }
+ }
+
public void onClick(View v) {
switch (v.getId()) {
@@ -285,16 +304,7 @@ public class VideoCamera extends Activity implements View.OnClickListener,
}
case R.id.share: {
- Intent intent = new Intent();
- intent.setAction(Intent.ACTION_SEND);
- intent.setType("video/3gpp");
- intent.putExtra(Intent.EXTRA_STREAM, mCurrentVideoUri);
- try {
- startActivity(Intent.createChooser(intent, getText(R.string.sendVideo)));
- } catch (android.content.ActivityNotFoundException ex) {
- Toast.makeText(VideoCamera.this, R.string.no_way_to_share_video, Toast.LENGTH_SHORT).show();
- }
-
+ startShareVideoActivity();
break;
}
@@ -932,6 +942,7 @@ public class VideoCamera extends Activity implements View.OnClickListener,
for(int id : hideIds) {
mPostPictureAlert.findViewById(id).setVisibility(View.GONE);
}
+
connectAndFadeIn(connectIds);
connectAndFadeIn(alwaysOnIds);
mPostPictureAlert.setVisibility(View.VISIBLE);
diff --git a/src/com/android/camera/ViewImage.java b/src/com/android/camera/ViewImage.java
index a5a3821..7963e66 100644
--- a/src/com/android/camera/ViewImage.java
+++ b/src/com/android/camera/ViewImage.java
@@ -249,14 +249,10 @@ public class ViewImage extends Activity implements View.OnClickListener
mGestureDetector = new GestureDetector(getContext(), new MyGestureListener());
mGestureDetector.setOnDoubleTapListener(new MyDoubleTapListener());
mZoomButtonsController = new ZoomButtonsController(context, this);
- mZoomButtonsController.setOverviewVisible(false);
mZoomButtonsController.setCallback(new ZoomButtonsController.OnZoomListener() {
public void onCenter(int x, int y) {
}
- public void onOverview() {
- }
-
public void onVisibilityChanged(boolean visible) {
if (visible) {
updateButtonsEnabled();
@@ -338,7 +334,9 @@ public class ViewImage extends Activity implements View.OnClickListener
// On double tap, we show the zoom controls.
public boolean onDoubleTapEvent(MotionEvent e) {
mViewImage.setMode(MODE_NORMAL);
- mZoomButtonsController.handleDoubleTapEvent(e);
+ if (mZoomButtonsController.handleDoubleTapEvent(e)) {
+ ZoomButtonsController.finishZoomTutorial(mViewImage, true);
+ }
return true;
}
@@ -901,7 +899,8 @@ public class ViewImage extends Activity implements View.OnClickListener
return;
}
- final boolean left = mCurrentPosition > pos;
+ final boolean left = (pos == mCurrentPosition - 1);
+ final boolean right = (pos == mCurrentPosition + 1);
mCurrentPosition = pos;
@@ -919,7 +918,7 @@ public class ViewImage extends Activity implements View.OnClickListener
if (left) {
mImageViews[2].copyFrom(mImageViews[1]);
mImageViews[1].copyFrom(mImageViews[0]);
- } else {
+ } else if (right) {
mImageViews[0].copyFrom(mImageViews[1]);
mImageViews[1].copyFrom(mImageViews[2]);
}
@@ -1449,6 +1448,15 @@ public class ViewImage extends Activity implements View.OnClickListener
}
@Override
+ public void onWindowFocusChanged(boolean hasFocus) {
+ if (hasFocus) {
+ ZoomButtonsController.showZoomTutorialOnce(this);
+ } else {
+ ZoomButtonsController.finishZoomTutorial(this, false);
+ }
+ }
+
+ @Override
public void onPause()
{
super.onPause();