Android ScrollView反弹效果的实现
来源:互联网 发布:网络平台公司组织架构 编辑:程序博客网 时间:2024/04/30 13:05
/** * ScrollView反弹效果的实现 */public class BounceScrollView extends ScrollView {private View inner;// 孩子Viewprivate float y;// 点击时y坐标private Rect normal = new Rect();// 矩形(这里只是个形式,只是用于判断是否需要动画.)private boolean isCount = false;// 是否开始计算public BounceScrollView(Context context, AttributeSet attrs) {super(context, attrs);}/*** * 根据 XML 生成视图工作完成.该函数在生成视图的最后调用,在所有子视图添加完之后. 即使子类覆盖了 onFinishInflate * 方法,也应该调用父类的方法,使该方法得以执行. */@Overrideprotected void onFinishInflate() {if (getChildCount() > 0) {inner = getChildAt(0);}}/*** * 监听touch */@Overridepublic boolean onTouchEvent(MotionEvent ev) {if (inner != null) {commOnTouchEvent(ev);}return super.onTouchEvent(ev);}/*** * 触摸事件 * * @param ev */public void commOnTouchEvent(MotionEvent ev) {int action = ev.getAction();switch (action) {case MotionEvent.ACTION_DOWN:break;case MotionEvent.ACTION_UP:// 手指松开.if (isNeedAnimation()) {animation();isCount = false;}break;/*** * 排除出第一次移动计算,因为第一次无法得知y坐标, 在MotionEvent.ACTION_DOWN中获取不到, * 因为此时是MyScrollView的touch事件传递到到了LIstView的孩子item上面.所以从第二次计算开始. * 然而我们也要进行初始化,就是第一次移动的时候让滑动距离归0. 之后记录准确了就正常执行. */case MotionEvent.ACTION_MOVE:final float preY = y;// 按下时的y坐标float nowY = ev.getY();// 时时y坐标int deltaY = (int) (preY - nowY);// 滑动距离if (!isCount) {deltaY = 0; // 在这里要归0.}y = nowY;// 当滚动到最上或者最下时就不会再滚动,这时移动布局if (isNeedMove()) {// 初始化头部矩形if (normal.isEmpty()) {// 保存正常的布局位置normal.set(inner.getLeft(), inner.getTop(),inner.getRight(), inner.getBottom());}Log.e("jj", "矩形:" + inner.getLeft() + "," + inner.getTop()+ "," + inner.getRight() + "," + inner.getBottom());// 移动布局inner.layout(inner.getLeft(), inner.getTop() - deltaY / 2,inner.getRight(), inner.getBottom() - deltaY / 2);}isCount = true;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);Log.e("jj", "回归:" + normal.left + "," + normal.top + "," + normal.right+ "," + normal.bottom);normal.setEmpty();}// 是否需要开启动画public boolean isNeedAnimation() {return !normal.isEmpty();}/*** * 是否需要移动布局 inner.getMeasuredHeight():获取的是控件的总高度 * * getHeight():获取的是屏幕的高度 * * @return */public boolean isNeedMove() {int offset = inner.getMeasuredHeight() - getHeight();int scrollY = getScrollY();Log.e("jj", "scrolly=" + scrollY);// 0是顶部,后面那个是底部if (scrollY == 0 || scrollY == offset) {return true;}return false;}}
使用方法
<com.techrare.view.BounceScrollView android:layout_width="fill_parent" android:layout_height="fill_parent" android:background="@color/tab_chart_bg" android:scrollbars="none" > <LinearLayout android:layout_width="fill_parent" android:layout_height="match_parent" android:gravity="center_horizontal" android:orientation="vertical" android:paddingLeft="20dp" android:paddingRight="20dp" > <span style="white-space:pre"> </span><!-- 这里可以尽情的布局 --> </LinearLayout> </com.techrare.view.BounceScrollView>
原文地址http://blog.csdn.net/h7870181/article/details/8960430
- Android ScrollView反弹效果的实现
- Android ScrollView反弹效果的实现
- Android ScrollView反弹效果的实现
- Android ScrollView反弹效果的实现
- android ScrollView反弹效果的实现
- Android ScrollView反弹效果的实现
- Android ScrollView反弹效果的实现
- ScrollView反弹效果的实现
- ScrollView反弹效果的实现
- ScrollView反弹效果的实现
- ScrollView反弹效果实现
- Android自定义ScrollView实现反弹效果
- Android自定义ScrollView实现反弹效果
- Android自定义ScrollView实现反弹效果
- Android自定义ScrollView实现上下反弹效果
- ScrollView的反弹效果的实现
- 自己的ScrollView实现反弹效果
- Android 具有反弹效果的ScrollView
- ExtJs4 笔记(7) Ext.tip.ToolTip 提示
- Puppet Installation Guide on Ubuntu12.04
- POP3重复接收邮件的问题研究
- android 开发 checkBox的显示和隐藏
- Android 完全关闭应用程序
- Android ScrollView反弹效果的实现
- ExtJs4 笔记(8) Ext.slider 滚轴控件、 Ext.ProgressBar 进度条控件、 Ext.Editor 编辑控件
- ubuntu13.04 环境下中谷歌chromium中安装Adobe Flsher Player 插件
- sgu 223 状态压缩+方案数
- IOS 如何实现灵活的瀑布流界面(1)
- View的绘制和invalidate
- 服务器与本机文件拷贝
- ExtJs4 笔记(9) Ext.Panel 面板控件、 Ext.window.Window 窗口控件、 Ext.container.Viewport 布局控件
- HTML骨架 -- 解剖一下HTML