diff options
author | Ray Chen <raychen@google.com> | 2011-10-04 15:19:44 +0800 |
---|---|---|
committer | Ray Chen <raychen@google.com> | 2011-10-06 10:43:09 +0800 |
commit | 73e791c4c42b66b7de3e6a4fa7ca05d9daa10cde (patch) | |
tree | 763cdcc1e942d151e2cd9beb59ea0eb632b758da /src/com/android/gallery3d/app | |
parent | ab83e37376705de78048188e0e28ee167d34a815 (diff) | |
download | android_packages_apps_Snap-73e791c4c42b66b7de3e6a4fa7ca05d9daa10cde.tar.gz android_packages_apps_Snap-73e791c4c42b66b7de3e6a4fa7ca05d9daa10cde.tar.bz2 android_packages_apps_Snap-73e791c4c42b66b7de3e6a4fa7ca05d9daa10cde.zip |
Fix 5250813 Use new standardized no account screen on first launch
This CL also fixes a bug in AlbumSetDataAdapter's ReloadTask, which
causes empty screen after pause/resume.
Change-Id: I7991d40a790384105ccb3021e1e51ba3e5ec8635
Diffstat (limited to 'src/com/android/gallery3d/app')
-rw-r--r-- | src/com/android/gallery3d/app/AlbumSetDataAdapter.java | 16 | ||||
-rw-r--r-- | src/com/android/gallery3d/app/AlbumSetPage.java | 15 | ||||
-rw-r--r-- | src/com/android/gallery3d/app/Gallery.java | 20 |
3 files changed, 27 insertions, 24 deletions
diff --git a/src/com/android/gallery3d/app/AlbumSetDataAdapter.java b/src/com/android/gallery3d/app/AlbumSetDataAdapter.java index 8322d2b19..6a8e7022e 100644 --- a/src/com/android/gallery3d/app/AlbumSetDataAdapter.java +++ b/src/com/android/gallery3d/app/AlbumSetDataAdapter.java @@ -16,6 +16,9 @@ package com.android.gallery3d.app; +import android.os.Handler; +import android.os.Message; + import com.android.gallery3d.common.Utils; import com.android.gallery3d.data.ContentListener; import com.android.gallery3d.data.DataManager; @@ -25,9 +28,6 @@ import com.android.gallery3d.data.MediaSet; import com.android.gallery3d.ui.AlbumSetView; import com.android.gallery3d.ui.SynchronizedHandler; -import android.os.Handler; -import android.os.Message; - import java.util.ArrayList; import java.util.Arrays; import java.util.concurrent.Callable; @@ -70,7 +70,7 @@ public class AlbumSetDataAdapter implements AlbumSetView.Model { private final Handler mMainHandler; - private MySourceListener mSourceListener = new MySourceListener(); + private final MySourceListener mSourceListener = new MySourceListener(); public AlbumSetDataAdapter(GalleryActivity activity, MediaSet albumSet, int cacheSize) { mSource = Utils.checkNotNull(albumSet); @@ -260,8 +260,7 @@ public class AlbumSetDataAdapter implements AlbumSetView.Model { @Override public UpdateInfo call() throws Exception { int index = getInvalidIndex(mVersion); - if (index == INDEX_NONE - && mSourceVersion == mVersion) return null; + if (index == INDEX_NONE && mSourceVersion == mVersion) return null; UpdateInfo info = new UpdateInfo(); info.version = mSourceVersion; info.index = index; @@ -271,13 +270,16 @@ public class AlbumSetDataAdapter implements AlbumSetView.Model { } private class UpdateContent implements Callable<Void> { - private UpdateInfo mUpdateInfo; + private final UpdateInfo mUpdateInfo; public UpdateContent(UpdateInfo info) { mUpdateInfo = info; } public Void call() { + // Avoid notifying listeners of status change after pause + // Otherwise gallery will be in inconsistent state after resume. + if (mReloadTask == null) return null; UpdateInfo info = mUpdateInfo; mSourceVersion = info.version; if (mSize != info.size) { diff --git a/src/com/android/gallery3d/app/AlbumSetPage.java b/src/com/android/gallery3d/app/AlbumSetPage.java index 644d56578..74d60c402 100644 --- a/src/com/android/gallery3d/app/AlbumSetPage.java +++ b/src/com/android/gallery3d/app/AlbumSetPage.java @@ -43,6 +43,7 @@ import com.android.gallery3d.ui.ActionModeHandler.ActionModeListener; import com.android.gallery3d.ui.AlbumSetView; import com.android.gallery3d.ui.DetailsHelper; import com.android.gallery3d.ui.DetailsHelper.CloseListener; +import com.android.gallery3d.util.GalleryUtils; import com.android.gallery3d.ui.GLCanvas; import com.android.gallery3d.ui.GLView; import com.android.gallery3d.ui.GridDrawer; @@ -53,7 +54,6 @@ import com.android.gallery3d.ui.PositionRepository.Position; import com.android.gallery3d.ui.SelectionManager; import com.android.gallery3d.ui.SlotView; import com.android.gallery3d.ui.StaticBackground; -import com.android.gallery3d.util.GalleryUtils; public class AlbumSetPage extends ActivityState implements SelectionManager.SelectionListener, GalleryActionBar.ClusterRunner, @@ -100,8 +100,8 @@ public class AlbumSetPage extends ActivityState implements private float mY; private float mZ; - private GLView mRootPane = new GLView() { - private float mMatrix[] = new float[16]; + private final GLView mRootPane = new GLView() { + private final float mMatrix[] = new float[16]; @Override protected void onLayout( @@ -238,7 +238,6 @@ public class AlbumSetPage extends ActivityState implements } public void doCluster(int clusterType) { - Log.v(TAG, "doCluster: " + clusterType); String basePath = mMediaSet.getPath().toString(); String newPath = FilterUtils.switchClusterPath(basePath, clusterType); Bundle data = new Bundle(getData()); @@ -284,7 +283,6 @@ public class AlbumSetPage extends ActivityState implements @Override public void onPause() { super.onPause(); - Log.v(TAG, "onPause"); mIsActive = false; mActionModeHandler.pause(); mAlbumSetDataAdapter.pause(); @@ -298,7 +296,6 @@ public class AlbumSetPage extends ActivityState implements @Override public void onResume() { super.onResume(); - Log.v(TAG, "onResume"); mIsActive = true; setContentPane(mRootPane); mAlbumSetDataAdapter.resume(); @@ -306,7 +303,9 @@ public class AlbumSetPage extends ActivityState implements mEyePosition.resume(); mActionModeHandler.resume(); GalleryActionBar actionBar = mActivity.getGalleryActionBar(); - if (mShowClusterMenu && actionBar != null) actionBar.showClusterMenu(mSelectedAction, this); + if (mShowClusterMenu && actionBar != null) { + actionBar.showClusterMenu(mSelectedAction, this); + } } private void initializeData(Bundle data) { @@ -478,7 +477,7 @@ public class AlbumSetPage extends ActivityState implements final PositionRepository repository = PositionRepository.getInstance(mActivity); mAlbumSetView.startTransition(new PositionProvider() { - private Position mTempPosition = new Position(); + private final Position mTempPosition = new Position(); public Position getPosition(long identity, Position target) { Position p = repository.get(identity); if (p == null) { diff --git a/src/com/android/gallery3d/app/Gallery.java b/src/com/android/gallery3d/app/Gallery.java index 4408dbaef..15534bc08 100644 --- a/src/com/android/gallery3d/app/Gallery.java +++ b/src/com/android/gallery3d/app/Gallery.java @@ -16,15 +16,6 @@ package com.android.gallery3d.app; -import com.android.gallery3d.R; -import com.android.gallery3d.common.Utils; -import com.android.gallery3d.data.DataManager; -import com.android.gallery3d.data.MediaItem; -import com.android.gallery3d.data.MediaSet; -import com.android.gallery3d.data.Path; -import com.android.gallery3d.ui.GLRoot; -import com.android.gallery3d.util.GalleryUtils; - import android.content.ContentResolver; import android.content.Intent; import android.net.Uri; @@ -34,6 +25,16 @@ import android.view.MenuItem; import android.view.Window; import android.widget.Toast; +import com.android.gallery3d.R; +import com.android.gallery3d.common.Utils; +import com.android.gallery3d.data.DataManager; +import com.android.gallery3d.data.MediaItem; +import com.android.gallery3d.data.MediaSet; +import com.android.gallery3d.data.Path; +import com.android.gallery3d.picasasource.PicasaSource; +import com.android.gallery3d.ui.GLRoot; +import com.android.gallery3d.util.GalleryUtils; + public final class Gallery extends AbstractGalleryActivity { public static final String EXTRA_SLIDESHOW = "slideshow"; public static final String EXTRA_CROP = "crop"; @@ -90,6 +91,7 @@ public final class Gallery extends AbstractGalleryActivity { } public void startDefaultPage() { + PicasaSource.showSignInReminder(this); Bundle data = new Bundle(); data.putString(AlbumSetPage.KEY_MEDIA_PATH, getDataManager().getTopSetPath(DataManager.INCLUDE_ALL)); |