ScrollView的反弹效果
来源:互联网 发布:银行业发展前景知乎 编辑:程序博客网 时间:2024/04/29 10:13
public class ReboundScrollview extends ScrollView { // 拖动的距离 size = 4 的意思 只允许拖动屏幕的1/4 private static final int size = 3; private View inner; private float y; private Rect normal = new Rect(); public ReboundScrollview(Context context) { super(context); } public ReboundScrollview(Context context, AttributeSet attrs) { super(context, attrs); } public ReboundScrollview(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); } @Override protected void onFinishInflate() { if (getChildCount() > 0) { inner = getChildAt(0); } } @Override public void requestChildFocus(View child, View focused) { if (focused instanceof WebView || focused instanceof ListView) { return; } super.requestChildFocus(child, focused); } @Override public boolean onTouchEvent(MotionEvent ev) { if (inner == null) { return super.onTouchEvent(ev); } else { commOnTouchEvent(ev); } return super.onTouchEvent(ev); } public void commOnTouchEvent(MotionEvent ev) { int action = ev.getAction(); switch (action) { case MotionEvent.ACTION_DOWN: y = ev.getY(); break; case MotionEvent.ACTION_UP: if (isNeedAnimation()) { // Log.v("mlguitar", "will up and animation"); animation(); } break; case MotionEvent.ACTION_MOVE: final float preY = y; float nowY = ev.getY(); /** * size=4 表示 拖动的距离为屏幕的高度的1/4 */ int deltaY = (int) (preY - nowY) / size; // 滚动 // scrollBy(0, deltaY); y = nowY; // 当滚动到最上或者最下时就不会再滚动,这时移动布局 if (isNeedMove()) { if (normal.isEmpty()) { // 保存正常的布局位置 normal.set(inner.getLeft(), inner.getTop(), inner.getRight(), inner.getBottom()); return; } int yy = inner.getTop() - deltaY; // 移动布局 inner.layout(inner.getLeft(), yy, inner.getRight(), inner.getBottom() - deltaY); } break; default: break; } } // 开启动画移动 public void animation() { // 开启移动动画 TranslateAnimation ta = new TranslateAnimation(0, 0, inner.getTop(), normal.top); ta.setDuration(200); inner.startAnimation(ta); // 设置回到正常的布局位置 inner.layout(normal.left, normal.top, normal.right, normal.bottom); normal.setEmpty(); } // 是否需要开启动画 public boolean isNeedAnimation() { return !normal.isEmpty(); } // 是否需要移动布局 public boolean isNeedMove() { int offset = inner.getMeasuredHeight() - getHeight(); int scrollY = getScrollY(); if (scrollY == 0 || scrollY == offset) { return true; } return false; } private OnScrollViewListener scrollViewListener; public void setOnScrollListener(OnScrollViewListener onScrollListener) { this.scrollViewListener = onScrollListener; } public interface OnScrollViewListener { void onScrollChanged(int x, int y, int oldx, int oldy); } @Override protected void onScrollChanged(int x, int y, int oldx, int oldy) { if (scrollViewListener != null) { scrollViewListener.onScrollChanged(x, y, oldx, oldy); } super.onScrollChanged(x, y, oldx, oldy); }}
0 0
- ScrollView的反弹效果
- ScrollView反弹效果的实现
- ScrollView反弹效果的实现
- ScrollView反弹效果的实现
- ScrollView的反弹效果的实现
- Android ScrollView反弹效果的实现
- Android ScrollView反弹效果的实现
- Android 具有反弹效果的ScrollView
- 自己的ScrollView实现反弹效果
- Android ScrollView反弹效果的实现
- Android ScrollView反弹效果的实现
- android ScrollView反弹效果的实现
- Android ScrollView反弹效果的实现
- Android ScrollView反弹效果的实现
- 做一个有反弹效果的ScrollView
- android 自定义具有反弹效果的ScrollView
- 反弹效果的 ScrollView(FlexibleScrollView)
- ScrollView反弹效果实现
- c++的一些优化技巧
- 第十三周-阅读程序
- Linux的inode的理解
- 统计学里“P”的故事:蚊子、皇帝的新衣和不育的风流才子
- Django认证系统
- ScrollView的反弹效果
- 第十三周项目1-分数类中的运算符重载(3)
- HTML5鼠标悬停在矩形上可以看到坐标
- 浏览器与cdn缓存
- log4j的基本使用详解
- 手把手教你做视频播放器(二)-获取视频信息
- python 实现清水河畔的模拟登陆
- 用springmail写发送邮件服务和一个困扰我很久但是很简单的问题
- HTML中 meta http-equiv属性