diff options
Diffstat (limited to 'src/com/android')
-rw-r--r-- | src/com/android/camera/GalleryPicker.java | 3 | ||||
-rw-r--r-- | src/com/android/camera/ImageGallery.java | 26 | ||||
-rw-r--r-- | src/com/android/camera/ViewImage.java | 74 | ||||
-rw-r--r-- | src/com/android/camera/gallery/BaseImageList.java | 9 | ||||
-rw-r--r-- | src/com/android/camera/gallery/ImageListUber.java | 21 | ||||
-rw-r--r-- | src/com/android/camera/gallery/VideoObject.java | 4 |
6 files changed, 55 insertions, 82 deletions
diff --git a/src/com/android/camera/GalleryPicker.java b/src/com/android/camera/GalleryPicker.java index 6bfe2e4..d37b9be 100644 --- a/src/com/android/camera/GalleryPicker.java +++ b/src/com/android/camera/GalleryPicker.java @@ -413,8 +413,7 @@ public class GalleryPicker extends Activity { allImages = ImageManager.allImages( getContentResolver(), ImageManager.DataLocation.ALL, - ImageManager.INCLUDE_IMAGES - | ImageManager.INCLUDE_VIDEOS, + ImageManager.INCLUDE_IMAGES | ImageManager.INCLUDE_VIDEOS, ImageManager.SORT_DESCENDING); } else { allImages = ImageManager.emptyImageList(); diff --git a/src/com/android/camera/ImageGallery.java b/src/com/android/camera/ImageGallery.java index 062de68..24f6d29 100644 --- a/src/com/android/camera/ImageGallery.java +++ b/src/com/android/camera/ImageGallery.java @@ -637,28 +637,18 @@ public class ImageGallery extends Activity implements if (isPickIntent()) { launchCropperOrFinish(img); } else { - Uri targetUri = img.fullSizeImageUri(); - Uri thisUri = getIntent().getData(); - if (thisUri != null) { - String bucket = thisUri.getQueryParameter("bucketId"); - if (bucket != null) { - targetUri = targetUri.buildUpon() - .appendQueryParameter("bucketId", bucket) - .build(); - } - } - Intent intent = new Intent(Intent.ACTION_VIEW, targetUri); - + Intent intent; if (img instanceof VideoObject) { + intent = new Intent( + Intent.ACTION_VIEW, img.fullSizeImageUri()); intent.putExtra(MediaStore.EXTRA_SCREEN_ORIENTATION, ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE); + } else { + intent = new Intent(this, ViewImage.class); + intent.putExtra(ViewImage.KEY_IMAGE_LIST, mAllImages); + intent.setData(img.fullSizeImageUri()); } - - try { - startActivity(intent); - } catch (Exception ex) { - // sdcard removal?? - } + startActivity(intent); } } } diff --git a/src/com/android/camera/ViewImage.java b/src/com/android/camera/ViewImage.java index 9ce5e5c..4cfa544 100644 --- a/src/com/android/camera/ViewImage.java +++ b/src/com/android/camera/ViewImage.java @@ -19,6 +19,8 @@ package com.android.camera; import com.android.camera.gallery.Cancelable; import com.android.camera.gallery.IImage; import com.android.camera.gallery.IImageList; +import com.android.camera.gallery.SingleImageList; +import com.android.camera.gallery.VideoObject; import android.app.Activity; import android.content.Context; @@ -60,6 +62,8 @@ import java.util.concurrent.ExecutionException; // button to see the previous or next image. In slide show mode it shows one // image after another, with some transition effect. public class ViewImage extends Activity implements View.OnClickListener { + private static final String KEY_URI = "uri"; + private static final String TAG = "ViewImage"; private ImageGetter mGetter; @@ -83,7 +87,6 @@ public class ViewImage extends Activity implements View.OnClickListener { private boolean mShowActionIcons; private View mActionIconPanel; - private boolean mSortAscending = false; private int mSlideShowInterval; private int mLastSlideShowImage; private ThumbnailController mThumbController; @@ -106,6 +109,8 @@ public class ViewImage extends Activity implements View.OnClickListener { static final int HYSTERESIS = PADDING * 2; static final int BASE_SCROLL_DURATION = 1000; // ms + public static final String KEY_IMAGE_LIST = "image_list"; + IImageList mAllImages; private int mSlideShowImageCurrent = 0; @@ -374,7 +379,6 @@ public class ViewImage extends Activity implements View.OnClickListener { .setAlphabeticShortcut('z') .setVisible(false); - return true; } @@ -562,17 +566,15 @@ public class ViewImage extends Activity implements View.OnClickListener { } Uri uri = getIntent().getData(); - + IImageList imageList = getIntent().getParcelableExtra(KEY_IMAGE_LIST); if (instanceState != null) { - if (instanceState.containsKey("uri")) { - uri = Uri.parse(instanceState.getString("uri")); - } + uri = instanceState.getParcelable(KEY_URI); + imageList = instanceState.getParcelable(KEY_IMAGE_LIST); } - if (uri == null) { + if (!init(uri, imageList)) { finish(); return; } - init(uri); Bundle b = getIntent().getExtras(); @@ -847,38 +849,15 @@ public class ViewImage extends Activity implements View.OnClickListener { mGetter = new ImageGetter(this); } - private boolean desiredSortOrder() { - String sortOrder = mPrefs.getString("pref_gallery_sort_key", null); - boolean sortAscending = false; - if (sortOrder != null) { - sortAscending = sortOrder.equals("ascending"); - } - if (mCameraReviewMode) { - // Force left-arrow older pictures, right-arrow newer pictures. - sortAscending = true; - } - return sortAscending; - } - - private void init(Uri uri) { - if (uri == null) { - return; - } - - mSortAscending = desiredSortOrder(); - int sort = mSortAscending - ? ImageManager.SORT_ASCENDING - : ImageManager.SORT_DESCENDING; - mAllImages = ImageManager.makeImageList(uri, getContentResolver(), - sort); - - uri = uri.buildUpon().query(null).build(); - + private boolean init(Uri uri, IImageList imageList) { + if (uri == null) return false; + mAllImages = imageList == null ? new SingleImageList(uri) : imageList; + mAllImages.open(getContentResolver()); IImage image = mAllImages.getImageForUri(uri); - if (image != null) { - mCurrentPosition = mAllImages.getImageIndex(image); - mLastSlideShowImage = mCurrentPosition; - } + if (image == null) return false; + mCurrentPosition = mAllImages.getImageIndex(image); + mLastSlideShowImage = mCurrentPosition; + return true; } private Uri getCurrentUri() { @@ -902,22 +881,16 @@ public class ViewImage extends Activity implements View.OnClickListener { @Override public void onSaveInstanceState(Bundle b) { super.onSaveInstanceState(b); - - Uri uri = getCurrentUri(); - if (uri != null) { - b.putString("uri", uri.toString()); - } - - if (mMode == MODE_SLIDESHOW) { - b.putBoolean("slideshow", true); - } + b.putParcelable(KEY_URI, + mAllImages.getImageAt(mCurrentPosition).fullSizeImageUri()); + b.putBoolean("slideshow", mMode == MODE_SLIDESHOW); } @Override public void onStart() { super.onStart(); - init(mSavedUri); + init(mSavedUri, mAllImages); if (mCameraReviewMode) { updateLastImage(); } @@ -1358,7 +1331,8 @@ class ImageGetter { if (imageNumber >= 0 && imageNumber < imageCount) { IImage image = mViewImage.mAllImages .getImageAt(lastPosition + offset); - if (mCB.wantsFullImage(lastPosition, offset)) { + if (mCB.wantsFullImage(lastPosition, offset) + && !(image instanceof VideoObject)) { int sizeToUse = mCB.fullImageSizeToUse( lastPosition, offset); if (image != null && !isCanceled()) { diff --git a/src/com/android/camera/gallery/BaseImageList.java b/src/com/android/camera/gallery/BaseImageList.java index a006689..a1d2c5d 100644 --- a/src/com/android/camera/gallery/BaseImageList.java +++ b/src/com/android/camera/gallery/BaseImageList.java @@ -423,9 +423,12 @@ public abstract class BaseImageList implements IImageList { cursor.moveToPosition(-1); // before first for (int i = 0; cursor.moveToNext(); ++i) { if (getImageId(cursor) == matchId) { - Log.v(TAG, "find object at " + i + ", it takes" - + (SystemClock.elapsedRealtime() - startTimestamp)); - return loadImageFromCursor(cursor); + BaseImage image = mCache.get(i); + if (image == null) { + image = loadImageFromCursor(cursor); + mCache.put(i, image); + } + return image; } } return null; diff --git a/src/com/android/camera/gallery/ImageListUber.java b/src/com/android/camera/gallery/ImageListUber.java index 69bc2e1..06651ed 100644 --- a/src/com/android/camera/gallery/ImageListUber.java +++ b/src/com/android/camera/gallery/ImageListUber.java @@ -21,9 +21,9 @@ import com.android.camera.Util; import android.content.ContentResolver; import android.net.Uri; -import android.util.Log; import android.os.Parcel; import android.os.Parcelable; +import android.util.Log; import java.io.IOException; import java.util.Arrays; @@ -32,7 +32,9 @@ import java.util.HashMap; import java.util.PriorityQueue; /** - * A union of different <code>IImageList</code>. + * A union of different <code>IImageList</code>. This class can merge several + * <code>IImageList</code> into one list and sort them according to the + * timestamp (The sorting must be same as all the given lists). */ public class ImageListUber implements IImageList { @SuppressWarnings("unused") @@ -70,7 +72,8 @@ public class ImageListUber implements IImageList { } protected ImageListUber(Parcel in) { - Parcelable array[] = in.readParcelableArray(null); + Parcelable array[] = + in.readParcelableArray(ImageListUber.class.getClassLoader()); mSubList = new IImageList[array.length]; System.arraycopy(array, 0, mSubList, 0, array.length); int sort = in.readInt(); @@ -79,10 +82,6 @@ public class ImageListUber implements IImageList { sort == ImageManager.SORT_ASCENDING ? new AscendingComparator() : new DescendingComparator()); - for (int i = 0, n = mSubList.length; i < n; ++i) { - MergeSlot slot = new MergeSlot(mSubList[i], i); - if (slot.next()) mQueue.add(slot); - } } public static final Creator<ImageListUber> CREATOR = @@ -311,6 +310,14 @@ public class ImageListUber implements IImageList { } } + /** + * A merging slot is used to trace the current position of a sublist. For + * each given sub list, there will be one corresponding merge slot. We + * use merge-sort-like algorithm to build the merged list. At begining, + * we put all the slots in a sorted heap (by timestamp). Each time, we + * pop the slot with earliest timestamp out, get the image, and then move + * the index forward, and put it back to the heap. + */ private static class MergeSlot { private int mOffset = -1; private final IImageList mList; diff --git a/src/com/android/camera/gallery/VideoObject.java b/src/com/android/camera/gallery/VideoObject.java index 5da63bf..40a5f74 100644 --- a/src/com/android/camera/gallery/VideoObject.java +++ b/src/com/android/camera/gallery/VideoObject.java @@ -16,7 +16,7 @@ package com.android.camera.gallery; -import com.android.camera.ImageManager; +import com.android.camera.Util; import android.content.ContentResolver; import android.graphics.Bitmap; @@ -64,7 +64,7 @@ public class VideoObject extends BaseImage implements IImage { @Override public Bitmap fullSizeBitmap(int targetWidthHeight) { - return ImageManager.NO_IMAGE_BITMAP; + return Util.createVideoThumbnail(mDataPath); } @Override |