VelocityTracker简介

本文详细介绍Android中的VelocityTracker类,用于跟踪触摸屏事件的速率。包括如何获取实例、添加触摸事件、计算速度等,并提供了一个完整的示例代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

参照自:  http://blog.jrj.com.cn/4586793646,5298605a.html  

android.view.VelocityTracker 主要用跟踪触摸屏事件(flinging事件和其他gestures手势事件)的速率。用 addMovement(MotionEvent) 函数将Motion event加入到VelocityTracker类实例中.你可以使用 getXVelocity()  getXVelocity() 获得横向和竖向的速率到速率时,但是使用它们之前请先调用 computeCurrentVelocity (int) 来初始化速率的单位 。
主要函数
Public Methods
void addMovement( MotionEvent event)
Add a user's movement to the tracker.
void clear()
Reset the velocity tracker back to its initial state.
void computeCurrentVelocity(int units, float maxVelocity)
Compute the current velocity based on the points that have been collected.
int  unitis表示速率的基本时间单位。unitis值为 1的表示是,一毫秒时间单位内运动了多少个像素, unitis值为 1000表示一秒(1000毫秒)时间单位内运动了多少个像素
float Velocity表示速率的最大值
void computeCurrentVelocity(int units)
Equivalent to invoking  computeCurrentVelocity(int, float) with a maximum velocity of Float.MAX_VALUE.
abstract T getNextPoolable()
float getXVelocity()
Retrieve the last computed X velocity.
float getXVelocity(int id)
Retrieve the last computed X velocity.
float getYVelocity(int id)
Retrieve the last computed Y velocity.
float getYVelocity()
Retrieve the last computed Y velocity.
abstract boolean isPooled()
static  VelocityTracker obtain()
Retrieve a new VelocityTracker object to watch the velocity of a motion.
void recycle()
Return a VelocityTracker object back to be re-used by others.
abstract void setNextPoolable(T element)
abstract void setPooled(boolean isPooled)
示例: 
    private VelocityTracker mVelocityTracker;//生命变量 
    //在onTouchEvent(MotionEvent ev)中 
    if (mVelocityTracker == null) { 
             mVelocityTracker = VelocityTracker. obtain () ;//获得VelocityTracker类实例 
    } 
     mVelocityTracker. addMovement (ev); //将事件加入到VelocityTracker类实例中 
     //判断当ev事件是MotionEvent.ACTION_UP时:计算速率 
    final VelocityTracker velocityTracker = mVelocityTracker; 
     // 1000 provides pixels per second 
     velocityTracker.computeCurrentVelocity(1, (float)0.01) ;  //设置maxVelocity值为0.1时,速率大于0.01时,显示的速率都是0.01,速率小于0.01时,显示正常 
    Log.i("test","velocityTraker"+velocityTracker.getXVelocity());                     
    velocityTracker.computeCurrentVelocity(1000);  //设置units的值为1000,意思为一秒时间内运动了多少个像素 
    Log.i("test","velocityTraker"+velocityTracker.getXVelocity()); 
大体的使用是这样的:
当你需要跟踪触摸屏事件的速度的时候,使用 obtain() 方法来获得 VelocityTracker 类的一个实例对象
onTouchEvent 回调函数中,使用 addMovement(MotionEvent) 函数将当前的移动事件传递给 VelocityTracker 对象

使用computeCurrentVelocity  (int units)函数来计算当前的速度,使用 getXVelocity  ()、 getYVelocity  ()函数来获得当前的速度

示例:

1
2
3
4
5
6
7
8
9
10
11
12
13
private VelocityTracker mVelocityTracker; //生命变量  
//在onTouchEvent(MotionEvent ev)中  
if  (mVelocityTracker ==  null ) {  
     mVelocityTracker = VelocityTracker.obtain(); //获得VelocityTracker类实例  
}  
mVelocityTracker.addMovement(ev); //将事件加入到VelocityTracker类实例中  
//判断当ev事件是MotionEvent.ACTION_UP时:计算速率  
final VelocityTracker velocityTracker = mVelocityTracker;  
// 1000 provides pixels per second  
velocityTracker.computeCurrentVelocity(1, (float)0.01); //设置maxVelocity值为0.1时,速率大于0.01时,显示的速率都是0.01,速率小于0.01时,显示正常  
Log.i( "test" , "velocityTraker" +velocityTracker.getXVelocity());  
velocityTracker.computeCurrentVelocity(1000);  //设置units的值为1000,意思为一秒时间内运动了多少个像素  
Log.i( "test" , "velocityTraker" +velocityTracker.getXVelocity());

 

大体的使用是这样的:

当你需要跟踪触摸屏事件的速度的时候,使用obtain()方法来获得VelocityTracker类的一个实例对象

onTouchEvent回调函数中,使用addMovement(MotionEvent)函数将当前的移动事件传递给VelocityTracker对象 

使用computeCurrentVelocity (int units)函数来计算当前的速度,使用getXVelocity ()、 getYVelocity ()函数来获得当前的速度

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

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

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

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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值