0

ScrollView にバウンス効果を実装する方法の例があることは知っていますが、ここでは 1 つの問題で 1 日中苦労しています。Parallax ScrollView とバウンス効果の間に何かを作成しています。Parallax ScrollView はここから取得されます: Parallax Android ScrollViewと実装されているバウンス効果は、ObservableScrollView次のようになります。

public class ObservableScrollView extends ScrollView {
private ScrollCallbacks mCallbacks;

private static final int MAX_Y_OVERSCROLL_DISTANCE = 150;

private Context mContext;
private int mMaxYOverscrollDistance;

public ObservableScrollView(Context context, AttributeSet attrs) {
    super(context, attrs);
    this.mContext = context;
    initBounceScrollView();
}

@Override
protected void onScrollChanged(int l, int t, int oldl, int oldt) {
    super.onScrollChanged(l, t, oldl, oldt);
    if (mCallbacks != null) {
        mCallbacks.onScrollChanged(l, t, oldl, oldt);
    }
}

@Override
public int computeVerticalScrollRange() {
    return super.computeVerticalScrollRange();
}

public void setCallbacks(ScrollCallbacks listener) {
    mCallbacks = listener;
}

private void initBounceScrollView() {
    // get the density of the screen and do some maths with it on the max
    // overscroll distance
    // variable so that you get similar behaviors no matter what the screen
    // size

    final DisplayMetrics metrics = mContext.getResources()
            .getDisplayMetrics();
    final float density = metrics.density;

    mMaxYOverscrollDistance = (int) (density * MAX_Y_OVERSCROLL_DISTANCE);

}

@Override
public void draw(Canvas canvas) {
    super.draw(canvas);
}

static interface ScrollCallbacks {
    public void onScrollChanged(int l, int t, int oldl, int oldt);
}

@SuppressLint("NewApi")
@Override
protected boolean overScrollBy(int deltaX, int deltaY, int scrollX,
        int scrollY, int scrollRangeX, int scrollRangeY,
        int maxOverScrollX, int maxOverScrollY, boolean isTouchEvent) {
    // This is where the magic happens, we have replaced the incoming
    // maxOverScrollY with our own custom variable mMaxYOverscrollDistance;
    return super.overScrollBy(deltaX, deltaY, scrollX, scrollY,
            scrollRangeX, scrollRangeY, maxOverScrollX,
            mMaxYOverscrollDistance, isTouchEvent);
}

今私が達成したいのは、視差スクロールビューでのバウンス効果ですが、スクロールビューをプルダウンしているときにのみバウンス効果が表示されるようにしたいです。たとえば、私が ScrollView の先頭にいて、それをプルダウンしたとき。の最後に到達したときにバウンス効果を無効にしたいScrollView

どうすればこれを達成できますか..そして、Viewこのようなカスタムを作成するための最良の方法はありますか?

4

1 に答える 1

1

API 9 で導入されたメソッドがありonOverscrolledます。次のような目的の効果を得ることができます。

 @Override
    protected void onOverScrolled(int scrollX, int scrollY, boolean clampedX, boolean clampedY) {
        if (scrollY < 0)
            super.onOverScrolled(scrollX, scrollY, clampedX, clampedY);
    }

したがって、オーバースクロールは、スクロールビューを下に引っ張っているときにのみ発生し、scrollY は負になります。(scrollY > 0)反対の効果を達成するためにそれを切り替えます。

于 2013-10-24T08:16:59.687 に答える