summaryrefslogtreecommitdiffstats
path: root/src/com/android/browser/view/Gallery.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/com/android/browser/view/Gallery.java')
-rw-r--r--src/com/android/browser/view/Gallery.java62
1 files changed, 56 insertions, 6 deletions
diff --git a/src/com/android/browser/view/Gallery.java b/src/com/android/browser/view/Gallery.java
index 78d4bc6..2e2c75f 100644
--- a/src/com/android/browser/view/Gallery.java
+++ b/src/com/android/browser/view/Gallery.java
@@ -34,6 +34,8 @@ import android.view.SoundEffectConstants;
import android.view.View;
import android.view.ViewConfiguration;
import android.view.ViewGroup;
+import android.view.animation.BounceInterpolator;
+import android.view.animation.DecelerateInterpolator;
import android.view.animation.Transformation;
import android.widget.BaseAdapter;
import android.widget.LinearLayout;
@@ -130,6 +132,8 @@ public class Gallery extends ViewGroup implements
private float mLastMotionCoord;
private float mLastOrthoCoord;
+ private int mScrollValue;
+
public Gallery(Context context) {
this(context, null);
}
@@ -172,6 +176,7 @@ public class Gallery extends ViewGroup implements
mGap = 0;
// proguard
setGap(getGap());
+ setScrollValue(getScrollValue());
}
/**
@@ -180,7 +185,10 @@ public class Gallery extends ViewGroup implements
*/
public interface OnItemSelectedListener {
void onItemSelected(ViewGroup parent, View view, int position, long id);
+ }
+ public interface OnScrollFinishedListener {
+ void onScrollFinished();
}
/**
@@ -226,6 +234,11 @@ public class Gallery extends ViewGroup implements
return mGap;
}
+ public void setAdapter(BaseAdapter adapter, int selpos) {
+ mSelectedPosition = selpos;
+ setAdapter(adapter);
+ }
+
public void setAdapter(BaseAdapter adapter) {
mAdapter = adapter;
if (mAdapter != null) {
@@ -246,7 +259,7 @@ public class Gallery extends ViewGroup implements
handleDataChanged();
}
- void handleDataChanged() {
+ public void handleDataChanged() {
if (mAdapter != null) {
if (mGapAnimator != null) {
mGapAnimator.cancel();
@@ -427,7 +440,8 @@ public class Gallery extends ViewGroup implements
return;
}
boolean toLeft = deltaX < 0;
- int limitedDeltaX = getLimitedMotionScrollAmount(toLeft, deltaX);
+ int limitedDeltaX = mFlingRunnable.mScroller.isFinished()
+ ? deltaX : getLimitedMotionScrollAmount(toLeft, deltaX);
if (limitedDeltaX != deltaX) {
// The above call returned a limited amount, so stop any
// scrolls/flings
@@ -1178,7 +1192,7 @@ public class Gallery extends ViewGroup implements
}
}
- boolean moveNext() {
+ public boolean moveNext() {
if (mItemCount > 0 && mSelectedPosition < mItemCount - 1) {
scrollToChild(mSelectedPosition - mFirstPosition + 1);
return true;
@@ -1187,16 +1201,48 @@ public class Gallery extends ViewGroup implements
}
}
- protected boolean scrollToChild(int childPosition) {
+ public boolean scrollToChild(int childPosition) {
View child = getChildAt(childPosition);
if (child != null) {
int distance = getCenterOfGallery() - getCenterOfView(child);
- mFlingRunnable.startUsingDistance(distance);
+ mFlingRunnable.startUsingDistance(distance, 0);
return true;
}
return false;
}
+ /**
+ * use the scroller to scroll to a new position, independent
+ * of whether attached or not
+ * this uses trackMotionScroll, which will set the selection
+ */
+ public void smoothScrollToPosition(int pos, int duration,
+ final OnScrollFinishedListener listener) {
+ if (pos >= mAdapter.getCount() || getChildCount() < 1) return;
+ int dist = (mSelectedPosition - pos) * (mHorizontal ? getChildHeight(getChildAt(0))
+ : getChildWidth(getChildAt(0)));
+ ObjectAnimator scroll = ObjectAnimator.ofInt(this, "scrollValue", 0, dist);
+ scroll.setDuration(duration);
+ scroll.addListener(new AnimatorListenerAdapter() {
+ @Override
+ public void onAnimationEnd(Animator animation) {
+ mScrollValue = 0;
+ listener.onScrollFinished();
+ }
+ });
+ scroll.setInterpolator(new BounceInterpolator());
+ scroll.start();
+ }
+
+ public void setScrollValue(int scroll) {
+ trackMotionScroll(scroll - mScrollValue);
+ mScrollValue = scroll;
+ }
+
+ public int getScrollValue() {
+ return mScrollValue;
+ }
+
protected void setSelectedPositionInt(int position) {
mSelectedPosition = position;
updateSelectedItemMetadata();
@@ -1368,11 +1414,15 @@ public class Gallery extends ViewGroup implements
}
public void startUsingDistance(int distance) {
+ startUsingDistance(distance, mAnimationDuration);
+ }
+
+ public void startUsingDistance(int distance, int duration) {
if (distance == 0)
return;
startCommon();
mLastFlingX = 0;
- mScroller.startScroll(0, 0, -distance, 0, mAnimationDuration);
+ mScroller.startScroll(0, 0, -distance, 0, duration);
post(this);
}