作用:帮助去跟踪屏幕上的flinging事件,个人认为可能就是手指的触摸移动事件
使用方法:1 调用 VelocityTracker mVelocityTracker = VelocityTracker.obtain(); 实例化对象
2 调用 mVelocityTracker.addMovement(event); ,为对象添加监听的事件
3 调用 mVelocityTracker.computeCurrentVelocity(1, (float)0.01); 计算速度
4 mVelocityTracker.getXVelocity( ); 和 mVelocityTracker.getYVelocity( ); 计算X和Y的速度(可以传递参数来指定移动对象)
5 使用结束调用 mVelocityTracker.clear(); 和 mVelocityTracker.recycle(); 来清理对象
测试代码:
public class VelocityTrackerTestActivity extends Activity { private TextView mInfo; private VelocityTracker mVelocityTracker; private int mMaxVelocity; private int mPointerId; public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.velocity_trackerl ); mInfo = (TextView) findViewById( R.id.text); // mInfo = new TextView(this); // mInfo.setLines(4); // mInfo.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT)); // mInfo.setTextColor(Color.WHITE); // this.addContentView(mInfo , null); // setContentView(mInfo); mMaxVelocity = ViewConfiguration.get(this).getMaximumFlingVelocity(); } @Override public boolean onTouchEvent(MotionEvent event) { final int action = event.getAction(); acquireVelocityTracker(event); switch (action) { case MotionEvent.ACTION_DOWN: //求第一个触点的id, 此时可能有多个触点,但至少一个 mPointerId = event.getPointerId(0); break; case MotionEvent.ACTION_MOVE: //求伪瞬时速度 // mVelocityTracker.computeCurrentVelocity(1000, mMaxVelocity); mVelocityTracker.computeCurrentVelocity(1, (float)0.01); final float velocityX = mVelocityTracker.getXVelocity(mPointerId); final float velocityY = mVelocityTracker.getYVelocity(mPointerId); recodeInfo(velocityX, velocityY); break; case MotionEvent.ACTION_UP: releaseVelocityTracker(); break; case MotionEvent.ACTION_CANCEL: releaseVelocityTracker(); break; default: break; } return super.onTouchEvent(event); } private void acquireVelocityTracker(final MotionEvent event) { if(null == mVelocityTracker) { mVelocityTracker = VelocityTracker.obtain(); } mVelocityTracker.addMovement(event); } /** * 释放VelocityTracker * * @see android.view.VelocityTracker#clear() * @see android.view.VelocityTracker#recycle() */ private void releaseVelocityTracker() { if(null != mVelocityTracker) { mVelocityTracker.clear(); mVelocityTracker.recycle(); mVelocityTracker = null; } } private static final String sFormatStr = "velocityX=%f\nvelocityY=%f"; /** * 记录当前速度 * * @param velocityX x轴速度 * @param velocityY y轴速度 */ private void recodeInfo(final float velocityX, final float velocityY) { final String info = String.format(sFormatStr, velocityX, velocityY); mInfo.setText(info); } }
2 xml
<?xml version = "1.0" encoding = "utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_gravity="center" android:gravity="top" android:orientation="vertical" > <TextView android:id="@+id/text" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_margin="1dp" android:text="富字体样式"/> </LinearLayout>
相关推荐
复写onTouchEvent,里面添加四步骤即可
详细讲解自定义ViewGroup+Scroller+VelocityTracker做出Launcher滑动
* 创建VelocityTracker对象,并将触摸content界面的滑动事件加入到VelocityTracker当中。 * * @param event * content界面的滑动事件 */ private void createVelocityTracker(MotionEvent event) { if...
速度轨迹追踪器VelocityTracker的用法 如何处理滑动事件冲突 dispatchTouchEvent:(外部拦截)告诉此ScrollLayout的父布局,什么时候该拦截触摸事件,什么时候不该拦截触摸事件 onInterceptTouchEvent:(内部拦截...
虽然android本身是一个完整的系统,它主要运行在移动设备的特性决定了我们在它上面开的app绝大数属于客户端程序,主要目标就是显示界面处理交互,这点和web前端以及桌面上的应用类似。 作为“客
MultiTouch VelocityTracker Pointer2Draw 几个多点触控的测试程序 MultiTouch VelocityTracker Pointer2Draw 几个多点触控的测试程序
自绘控件、继承控件、组合控件、Scroller详解及源码浅析、ViewDragHelper详解及源码浅析、自定义View触摸工具类解析(ViewConfiguration基础参数工具类、VelocityTracker手势速率工具类、GestureDetector手势工具类...
private VelocityTracker mVelocityTracker; private int mMinimumVelocity; private int mMaximumVelocity; private float mBaseLineFlingVelocity; private float mFlingVelocityInfluence; private int ...
8.5.2 速度跟踪器VelocityTracker 273 8.5.3 触摸滑屏的分步实现 274 8.6 练习作业 285 第九章 侧边栏 287 9.1 概述 287 9.2 使用二进制保存标识数据 289 9.2.1 位运算符 289 9.2.2 位运算的常用功能 292 9.3 继承...
第1章 Android计算平台简介 1.1 面向新PC的全新平台 1.2 Android的历史 1.3 Dalvik VM剖析 1.4 理解Android软件栈 1.5 使用Android SDK开发最终用户应用程序 1.5.1 Android模拟器 1.5.2 ...
第1章 Android计算平台简介 1.1 面向新PC的全新平台 1.2 Android的历史 1.3 Dalvik VM剖析 1.4 理解Android软件栈 1.5 使用Android SDK开发最终用户应用程序 1.5.1 Android模拟器 1.5.2 ...
实现了一个可滑动显示图片的控件,用于了解Android的触控机制,Scroller和VelocityTracker的用法
字体移动: 波浪控件: View知识大盘点目录 View的定义 View的坐标系 MotionEvent mTouchSlop VelocityTracker GestureDetector View的滑动 View的动画 自定义View 滑动冲突 进阶学习 1.View的定义 View:Android中...
自定义ViewGroup 涉及的知识点 - ViewGroup的测量与布局 - View的测量与布局 - 滑动冲突的处理 - VelocityTracker滑动速率跟踪 - Scroller实现弹性滑动 - 屏幕宽高的获取等
UI2018.zip,该项目将会集结 “Android高级UI” 的知识。 目前已有章节: 1、贝塞尔曲线 2、PathMeasure 3、属性动画 4、Xfermode 5、VelocityTracker和Scroller 6、绘制流程 7、svg
MultiTouch VelocityTracker Pointer2Draw几个多点触控的测试程序
在开发客户的一款应用中,在布局方面由于涉及到了Scroller、VelocityTracker类的使用、还有自定义组件、一些比较实用的布局方式、如LinearLayout、RelativeLayout、等等,可以将一些布局设计分享给大家,对于这一类...
final VelocityTracker velocityTracker = mVelocityTracker; velocityTracker.computeCurrentVelocity(100); float xVelocity = velocityTracker.getXVelocity(); int oldScrollX = mSlidingView....
这是研究了网上大神双向左右滑动后实现的上下双向滑动特效,有兴趣的朋友可以看下面代码,注释很详细,原理就是根据手指滑动的方向,来将上下两...import android.view.VelocityTracker; import android.view.View; imp
3.1.4 VelocityTracker、GestureDetector和Scroller 126 3.2 View的滑动 129 3.2.1 使用scrollTo/scrollBy 129 3.2.2 使用动画 131 3.2.3 改变布局参数 133 3.2.4 各种滑动方式的对比 133 3.3 弹性滑动 135 ...