zoukankan      html  css  js  c++  java
  • 滑轮控件研究四、VelocityTracker的简单研究

    帮助你追踪一个touch事件(flinging事件和其他手势事件)的速率。当你要跟踪一个touch事件的时候,使用obtain()方法得到这个类的实例,然后 用addMovement(MotionEvent)函数将你接受到的motion event加入到VelocityTracker类实例中。当你使用到速率时,使用computeCurrentVelocity(int)初始化速率的单位,并获得当前的事件的速率,然后使用getXVelocity() 或getXVelocity()获得横向和竖向的速率。

    从上面的介绍中,我们就可以很简单的明白,如何去使用VelocityTracker类去追踪一个移动事件的速率。

    用法详解:

    1、    //首先获得VelocityTracker的实例
                /**
                 * obtain()的方法介绍
                 * Retrieve a new VelocityTracker object to watch the velocity of a motion. 
                 * Be sure to call recycle() when done. You should generally only maintain 
                 * an active object while tracking a movement, so that the VelocityTracker 
                 * can be re-used elsewhere.
                 * 翻译:
                 * 得到一个速率追踪者对象去检测一个事件的速率。确认在完成的时候调用recycle()方法。
                 * 一般情况下,你只要维持一个活动的速率追踪者对象去追踪一个事件,那么,这个速率追踪者
                 * 可以在别的地方重复使用。
                 */
                VelocityTracker mVelocityTracker = null;
                if (mVelocityTracker == null) {
                    mVelocityTracker = VelocityTracker.obtain();
                }
                
            2、    //假设有一个事件event,将事件加入到VelocityTracker类实例中 
            /**
             * addMovement (MotionEvent event)方法介绍
             * Add a user's movement to the tracker. You should call this for the initial 
             * ACTION_DOWN, the following ACTION_MOVE events that you receive,
             *  and the final ACTION_UP. You can, however, call this for whichever events 
             *  you desire.
             *  翻译:向速率追踪者中加入一个用户的移动事件,你应该最先在ACTION_DOWN调用这个方法,
             *  然后在你接受的ACTION_MOVE,最后是ACTION_UP。你可以为任何一个你愿意的事件调用该方法
             */
                mVelocityTracker.addMovement(event);
                
            3、//判断当事件MotionEvent.ACTION_UP的时候,调用下面的方法
            /**
             * public void computeCurrentVelocity (int units, float maxVelocity)方法介绍:
             * Compute the current velocity based on the points that have been
             * collected. Only call this when you actually want to retrieve velocity
             * information, as it is relatively expensive. You can then retrieve the
             * velocity with {@link #getXVelocity()} and {@link #getYVelocity()}.
             * 
             * @param units
             *            The units you would like the velocity in. A value of 1
             *            provides pixels per millisecond, 1000 provides pixels per
             *            second, etc.
             * @param maxVelocity
             *            The maximum velocity that can be computed by this method. This
             *            value must be declared in the same unit as the units
             *            parameter. This value must be positive.
             * 翻译:基于你所收集到的点计算当前的速率。       当你确定要获得速率信息的时候,在调用该方法,
             * 因为使用它需要消耗很大的性能。然后,你可以通过getXVelocity()和getYVelocity()获得横向和竖向的速率。
             * 
             * 参数:units  你想要指定的得到的速度单位,如果值为1,代表1毫秒运动了多少像素。如果值为1000,代表
             * 1秒内运动了多少像素。
             * 
             * 参数:maxVelocity  该方法所能得到的最大速度,这个速度必须和你指定的units使用同样的单位,而且
             * 必须是整数。(也就是,你指定一个速度的最大值,如果计算超过这个最大值,就使用这个最大值,否则,使用计算的的结果)
             * 
             * public void computeCurrentVelocity (int units)方法介绍
             * 这个方法与上面的方法没什么差别,就是在maxVelocity上,他会自动使用Float.MAX_VALUE常量
             */
            mVelocityTracker.computeCurrentVelocity(1000, mMaximumFlingVelocity);    
            
            
            4、//然后调用getXVelocity ()、getXVelocity (int id)、getYVelocity ()、getYVelocity (int id)得到速率
            /**
             * 调用这几个方法之前,必须确定你之前调用了computeCurrentVelocity方法。
             * 参数 id   代表返回指定触点的速率
             */
            Log.i("test", mVelocityTracker.getXVelocity() + "");
            Log.i("test", mVelocityTracker.getYVelocity() + "");

    在附上一个使用实例:

    public class GestureTestActivity extends Activity {
        private GestureDetector gestureDetector;
        private VelocityTracker mVelocityTracker = null;
    
        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.main);
            gestureDetector = new GestureDetector(this, new GestureListener());
            gestureDetector.setIsLongpressEnabled(false);
        }
    
        @Override
        public boolean onTouchEvent(MotionEvent event) {
            int action = event.getAction();
            if (mVelocityTracker == null) {
                mVelocityTracker = VelocityTracker.obtain();
            }
            mVelocityTracker.addMovement(event);
            switch (action) {
            case MotionEvent.ACTION_DOWN:
                Log.i("test", "ACTION_DOWN");
                break;
    
            case MotionEvent.ACTION_MOVE:// 移动的时候
                Log.i("test", "ACTION_MOVE");
                break;
    
            case MotionEvent.ACTION_UP:
                mVelocityTracker.computeCurrentVelocity(1000);
                Log.i("test", "ACTION_UP");
                Log.i("11111", mVelocityTracker.getXVelocity(0) + "");
                Log.i("11111", mVelocityTracker.getYVelocity(0) + "");
                break;
            }
            return gestureDetector.onTouchEvent(event);
        }
    
        // 继承于SimpleOnGestureListener,实现所有事件监听方法
        private class GestureListener extends SimpleOnGestureListener {
            @Override
            public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
                Log.i("test", "onFling  -----------------------");
                Log.i("2222", velocityX + "");
                Log.i("2222", velocityY + "");
                return super.onFling(e1, e2, velocityX, velocityY);
            }
        }
        
        @Override
        protected void onDestroy() {
            super.onDestroy();
            //释放
            mVelocityTracker.recycle();
            mVelocityTracker=null;
        }
    }

    转 http://blog.csdn.net/lonelyroamer/article/details/7560598

  • 相关阅读:
    Android BroadcastAnyWhere(Google Bug 17356824)漏洞具体分析
    读写Word的组件DocX介绍与入门
    2015年终总结,忙碌与有所收获的一年,2016年继续努力!
    数据库题——高于部门平均工资查询问题
    Oracle 简单的列转行
    行香子·过尽千山
    ZOJ2599:Graduated Lexicographical Ordering(很经典的数位DP)
    【oracle11g,18】存储结构:暂时表,手工条带化,表/索引迁移表空间,删除表,外部表
    联想S820 MIUI刷机包 MIUI 4.4.30 流畅执行 在线主题破解
    android开发艺术探索学习 之 结合Activity的生命周期了解Activity的LaunchMode
  • 原文地址:https://www.cnblogs.com/622698abc/p/2983615.html
Copyright © 2011-2022 走看看