ViewDrawHelpr 鸿翔大神详解
http://blog.csdn.net/lmj623565791/article/details/46858663
仿淘宝的DEMO
https://github.com/xmuSistone/android-vertical-slide-view
仅供自己参考学习, 侵删。
今早看到github模仿淘宝详情界面的DEMO,参考学习。 具体效果就是 两个界面,上拉的时候实现阻尼效果,
DEMO中看到VIewDrawHelpr拖拽工具类,先介绍该工具类的使用。
1.创建实例
mDragger = ViewDragHelper.create(this, 1.0f, new ViewDragHelper.Callback()
第一个就是当前的ViewGroup,第二个sensitivity(灵敏度),主要用于设置touchSlop:传入越大,mTouchSlop的值就会越小。第三个参数就是Callback。
2.触摸相关的方法。
@Override public boolean
onInterceptTouchEvent(MotionEvent event) {
// 是否应该拦截当前的事件
return mDragger.shouldInterceptTouchEvent(event);
}
@Override public boolean onTouchEvent(MotionEvent event) {
// 处理事件
mDragger.processTouchEvent(event); return true;
}
3.ViewDragHelper.CallCack
new ViewDragHelper.Callback() {
@Override public boolean tryCaptureView(View child, int pointerId) {
return true;
}
@Override public int clampViewPositionHorizontal(View child, int left, int dx) {
return left;
}
@Override public int clampViewPositionVertical(View child, int top, int dy) {
return top;
}
}
****tryCaptureView如何返回ture则表示可以捕获该view,你可以根据传入的第一个view参数决定哪些可以捕获
所有的Callback方法,看看还有哪些没用过的:
onViewDragStateChanged
当ViewDragHelper状态发生变化时回调(IDLE,DRAGGING,SETTING[自动滚动时])
onViewPositionChanged
view的坐标发生改变,调用回调接口中的onViewPositionChanged方法
当captureview的位置发生改变时回调 。参数left和getleft一致,dx为当前的和初始值的差值
在2.3.3版本上。需要方法中调用 invalidate();
onViewCaptured
当captureview被捕获时回调
onViewReleased 已用 松手时候, 参数xvel松手时水平方向的速度
onEdgeTouched
当触摸到边界时回调。
onEdgeLock
true的时候会锁住当前的边界,false则unLock。
onEdgeDragStarted 已用
getOrderedChildIndex
改变同一个坐标(x,y)去寻找captureView位置的方法。(具体在:findTopChildUnder方法中)
getViewHorizontalDragRange 已用 松手后的动画时长。必须返回一个大于0的值,否者无法拖动。返回实际的拖拽范围即可
getViewVerticalDragRange 已用 这个用来控制拖拽过程中松手后,自动滑行的速度
tryCaptureView 已用
clampViewPositionHorizontal 已用
clampViewPositionVertical 已用
方法的大致的回调顺序:
shouldInterceptTouchEvent:
DOWN:
getOrderedChildIndex(findTopChildUnder)
->onEdgeTouched
MOVE:
getOrderedChildIndex(findTopChildUnder)
->getViewHorizontalDragRange &
getViewVerticalDragRange(checkTouchSlop)(MOVE中可能不止一次)
->clampViewPositionHorizontal&
clampViewPositionVertical
->onEdgeDragStarted
->tryCaptureView
->onViewCaptured
->onViewDragStateChanged
processTouchEvent:
DOWN:
getOrderedChildIndex(findTopChildUnder)
->tryCaptureView
->onViewCaptured
->onViewDragStateChanged
->onEdgeTouched
MOVE:
->STATE==DRAGGING:dragTo
->STATE!=DRAGGING:
onEdgeDragStarted
->getOrderedChildIndex(findTopChildUnder)
->getViewHorizontalDragRange&
getViewVerticalDragRange(checkTouchSlop)
->tryCaptureView
->onViewCaptured
->onViewDragStateChanged
!!!
1.onFinishInflate 当View中所有的子控件均被映射成xml后触发
2.computeScroll:主要功能是计算拖动的位移量、更新背景、设置要显示的屏幕(setCurrentScreen(mCurrentScreen);)。
重写computeScroll()的原因
调用startScroll()是不会有滚动效果的,只有在computeScroll()获取滚动情况,做出滚动的响应
computeScroll在父控件执行drawChild时,会调用这个方法
3.mDrawHelper.smoothSlideViewto();平滑移动到哪里
只有·覆写 computeScroll(){} 才能实现平滑的滚动。