2013-04-30 8 views
0

나는 ScrollView에서 바운스 효과를 구현하는 방법을 알고 있지만 여기에서는 한 가지 문제로 하루 종일 고민하고 있습니다. Parallax ScrollView와 바운스 효과 사이에 무언가를 만들고 있습니다. 시차있는 ScrollView 여기에서 가져온 것입니다 Parallax Android ScrollView 지금과 같이 보이는 구현은 ObservableScrollView에 영향을 반송 :Android ScrollView가 아래로 당길 때만 튀어 오름

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를 당길 때만. 예를 들어 내가 ScrollView의 시작 부분에있을 때 그것을 내립니다. ScrollView의 끝에 도달하면 바운스 효과를 사용하지 않도록 설정하고 싶습니다.

어떤 제안/아이디어를 어떻게 달성 할 수 있습니까? 그리고이 맞춤 설정을 만드는 가장 좋은 방법은 View입니까?

답변

1

는 API 9에 도입 된 onOverscrolled 방법 당신은 이런 식으로 원하는 효과를 얻을 수있다 : 당신이 아래로있는 ScrollView를 당겨 때

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

그래서 오버 스크롤 만 일어날 것, 그리고 scrollY 부정적인된다. 반대 효과를 얻으려면 (scrollY > 0)으로 전환하십시오.

관련 문제