VelocityTracker顾名思义即速度跟踪,在android中主要应用于touch event, VelocityTracker通过跟踪一连串事件实时计算出

当前的速度,这样的用法在android系统空间中随处可见,比如Gestures中的Fling, Scrolling等,下面简单介绍一下用法。

  1. //获取一个VelocityTracker对象, 用完后记得回收
  2. //回收后代表你不需要使用了,系统将此对象在此分配到其他请求者
  3. static public VelocityTracker obtain();
  4. public void recycle();
  5. //计算当前速度, 其中units是单位表示, 1代表px/毫秒, 1000代表px/秒, ..
  6. //maxVelocity此次计算速度你想要的最大值
  7. public void computeCurrentVelocity(int units, float maxVelocity);
  8. //经过一次computeCurrentVelocity后你就可以用一下几个方法获取此次计算的值
  9. //id是touch event触摸点的ID, 来为多点触控标识,有这个标识在计算时可以忽略
  10. //其他触点干扰,当然干扰肯定是有的
  11. public float getXVelocity();
  12. public float getYVelocity();
  13. public float getXVelocity(int id);
  14. public float getYVelocity(int id);

下面是我写的一个简单Demo:

  1. package com.bxwu.demo.component.activity;
  2. import android.app.Activity;
  3. import android.graphics.Color;
  4. import android.os.Bundle;
  5. import android.view.MotionEvent;
  6. import android.view.VelocityTracker;
  7. import android.view.ViewConfiguration;
  8. import android.view.ViewGroup.LayoutParams;
  9. import android.widget.TextView;
  10. public class VelocityTrackerTest extends Activity {
  11. private TextView mInfo;
  12. private VelocityTracker mVelocityTracker;
  13. private int mMaxVelocity;
  14. private int mPointerId;
  15. @Override
  16. protected void onCreate(Bundle savedInstanceState) {
  17. super.onCreate(savedInstanceState);
  18. mInfo = new TextView(this);
  19. mInfo.setLines(4);
  20. mInfo.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));
  21. mInfo.setTextColor(Color.WHITE);
  22. setContentView(mInfo);
  23. mMaxVelocity = ViewConfiguration.get(this).getMaximumFlingVelocity();
  24. }
  25. @Override
  26. public boolean onTouchEvent(MotionEvent event) {
  27. final int action = event.getAction();
  28. acquireVelocityTracker(event);
  29. final VelocityTracker verTracker = mVelocityTracker;
  30. switch (action) {
  31. case MotionEvent.ACTION_DOWN:
  32. //求第一个触点的id, 此时可能有多个触点,但至少一个
  33. mPointerId = event.getPointerId(0);
  34. break;
  35. case MotionEvent.ACTION_MOVE:
  36. //求伪瞬时速度
  37. verTracker.computeCurrentVelocity(1000, mMaxVelocity);
  38. final float velocityX = verTracker.getXVelocity(mPointerId);
  39. final float velocityY = verTracker.getYVelocity(mPointerId);
  40. recodeInfo(velocityX, velocityY);
  41. break;
  42. case MotionEvent.ACTION_UP:
  43. releaseVelocityTracker();
  44. break;
  45. case MotionEvent.ACTION_CANCEL:
  46. releaseVelocityTracker();
  47. break;
  48. default:
  49. break;
  50. }
  51. return super.onTouchEvent(event);
  52. }
  53. /**
  54. *
  55. * @param event 向VelocityTracker添加MotionEvent
  56. *
  57. * @see android.view.VelocityTracker#obtain()
  58. * @see android.view.VelocityTracker#addMovement(MotionEvent)
  59. */
  60. private void acquireVelocityTracker(final MotionEvent event) {
  61. if(null == mVelocityTracker) {
  62. mVelocityTracker = VelocityTracker.obtain();
  63. }
  64. mVelocityTracker.addMovement(event);
  65. }
  66. /**
  67. * 释放VelocityTracker
  68. *
  69. * @see android.view.VelocityTracker#clear()
  70. * @see android.view.VelocityTracker#recycle()
  71. */
  72. private void releaseVelocityTracker() {
  73. if(null != mVelocityTracker) {
  74. mVelocityTracker.clear();
  75. mVelocityTracker.recycle();
  76. mVelocityTracker = null;
  77. }
  78. }
  79. private static final String sFormatStr = "velocityX=%f\nvelocityY=%f";
  80. /**
  81. * 记录当前速度
  82. *
  83. * @param velocityX x轴速度
  84. * @param velocityY y轴速度
  85. */
  86. private void recodeInfo(final float velocityX, final float velocityY) {
  87. final String info = String.format(sFormatStr, velocityX, velocityY);
  88. mInfo.setText(info);
  89. }
  90. }

代码很简单,我们可以求出move过程中的伪瞬时速度, 这样在做很多控件的时候都是可以用到的,比如系统Launcher的分页,

ScrollView滑动等, 可根据此时的速度来计算ACTION_UP后的减速运动等。实现一些非常棒的效果。

VelocityTracker的更多相关文章

  1. android VelocityTracker 速度追踪器的使用及创建

    VelocityTracker 速度追踪 第一,创建方式: VelocityTracker  mVelocityTracker  = new VelocityTracker .obtain() 第二, ...

  2. 使用VelocityTracker来完成MotionEvent移动速率计算

    先看效果图 关键代码(此处记录单点): switch (event.getAction()){ case MotionEvent.ACTION_DOWN: if (veloctiy==null) { ...

  3. TouchSlop与VelocityTracker认识

    TouchSlop是处理触摸事件中的一个常量,被系统认为滑动和点击事件的临界点.理 解这个touchSlop是一个滑动距离值的常量,也就是说当我们手触摸在屏幕上滑动时,如果滑动距离没有超过touchS ...

  4. VelocityTracker简介

    android.view.VelocityTracker主要用跟踪触摸屏事件(flinging事件和其他gestures手势事件)的速率.用addMovement(MotionEvent)函数将Mot ...

  5. 手势识别官方教程(3)识别移动手势(识别速度用VelocityTracker)

    moving手势在onTouchEvent()或onTouch()中就可识别,编程时主要是识别积云的速度用VelocityTracker等, Tracking Movement This lesson ...

  6. 代码讲解Android Scroller、VelocityTracker

    在编写自定义滑动控件时常常会用到Android触摸机制和Scroller及VelocityTracker.Android Touch系统简介(二):实例详解onInterceptTouchEvent与 ...

  7. VelocityTracker简单介绍

    翻译自:http://developer.android.com/reference/android/view/VelocityTracker.html 參照自: http://blog.jrj.co ...

  8. Android UI 学习 自定义的布局 平滑移动 VelocityTracker()

    /**  * Helper for tracking the velocity of touch events, for implementing  * flinging and other such ...

  9. Android为TV端助力 VelocityTracker 速度追踪器的使用及创建

    VelocityTracker 速度追踪 第一,创建方式: VelocityTracker  mVelocityTracker  = new VelocityTracker .obtain() 第二, ...

随机推荐

  1. Atitit.木马 病毒 免杀 技术 360免杀 杀毒软件免杀 原理与原则 attilax 总结

    Atitit.木马 病毒 免杀 技术 360免杀 杀毒软件免杀 原理与原则 attilax 总结 1. ,免杀技术的用途2 1.1. 病毒木马的编写2 1.2. 软件保护所用的加密产品(比如壳)中,有 ...

  2. 桥牌笔记:Skill 4 Series A–Deal 5

    南主打5C. 此牌的难点在于:如果黑桃4-2分布时,有没有打成的希望?看来黑桃.红桃.方块各1个失张无法避免? 但希望还是有的,那就是东家拿2张黑桃,并且有3张将牌. 这时庄家可以清2轮将牌,拔2轮黑 ...

  3. 通过sftp实现文件分发功能

    1       环境: 分发服务器:ubuntu server 64bit,192.168.56.22 接受服务器:windows server 2008,192.168.56.102 2       ...

  4. android XMl 解析神奇xstream 二: 把对象转换成xml

    前言:对xstream不理解的请看:android XMl 解析神奇xstream 一: 解析android项目中 asset 文件夹 下的 aa.xml 文件 1.Javabeen 代码 packa ...

  5. Sublime Text 最佳插件列表(转)

    Package Control 安装方法 首先通过快捷键 ctrl+` 或者 View > Show Console 打开控制台,然后粘贴相应的 Python 安装代码. Sublime Tex ...

  6. Struts2(十六)Json

    一.JSON Json就是浏览器和服务器之间交换数据的一种轻量级对象 javaSctipt中类似的对象操作 $(function() { var person = { "name" ...

  7. 记录Hibernate的缓存知识

    一.Hibernate缓存的作用 Hibernate是一个持久层框架,Hibernate要经常访问物理数据库.为了降低应用程序对物理数据源访问的频次,从而提高应用程序的运行性能,Hibernate的缓 ...

  8. 内部类--毕向东Java基础教程学习笔记

    内部类的访问规则 1. 内部类可以直接访问外部类的成员,包括私有. 之所以可以直接访问外部类的成员,是因为内部类中持有外部类的引用,格式:外部类名.this 2.外部类要访问内部类,必须建立内部类对象 ...

  9. TFS配置过程中的错误

    有些人在配置TFS的过程中会报出[以前的更新或安装需要重新启动操作系统.……]的错误,但会发现无论重启多次操作系统,再配置的时候依然会报这个错误,很是让人苦恼哦. 这个错误在安装SharePoint的 ...

  10. 堆栈 & Stack and Heap

    What's the difference between a stack and a heap? The differences between the stack and the heap can ...