zoukankan      html  css  js  c++  java
  • view之Scroller工具类和GestureDetector的简单用法

    转载:http://ipjmc.iteye.com/blog/1615828      

    Android里Scroller类是为了实现View平滑滚动的一个Helper类。通常在自定义的View时使用,在View中定义一个私有成员mScroller = new Scroller(context)。设置mScroller滚动的位置时,并不会导致View的滚动,通常是用mScroller记录/计算View滚动的位置,再重写View的computeScroll(),完成实际的滚动。 

    GestureDetector是手势识别工具类,需要在View的ontochEvent中默认返回GetureDetector的onTochEvent来管理所有的手势识别。

    最重要的也就是onTouch中的distanX和diantanY,也就是水平方向的有效的移动距离和垂直方向上的有效移动距离。结合scroller变能实现诸如下拉刷新,自定义ViewPager类似功能的View控件。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    mScroller.getCurrX() //获取mScroller当前水平滚动的位置
    mScroller.getCurrY() //获取mScroller当前竖直滚动的位置
    mScroller.getFinalX() //获取mScroller最终停止的水平位置
    mScroller.getFinalY() //获取mScroller最终停止的竖直位置
    mScroller.setFinalX(int newX) //设置mScroller最终停留的水平位置,没有动画效果,直接跳到目标位置
    mScroller.setFinalY(int newY) //设置mScroller最终停留的竖直位置,没有动画效果,直接跳到目标位置
     
    //滚动,startX, startY为开始滚动的位置,dx,dy为滚动的偏移量, duration为完成滚动的时间
    mScroller.startScroll(int startX, int startY, int dx, int dy) //使用默认完成时间250ms
    mScroller.startScroll(int startX, int startY, int dx, int dy, int duration)
     
    mScroller.computeScrollOffset() //返回值为boolean,true说明滚动尚未完成,false说明滚动已经完成。这是一个很重要的方法,通常放在View.computeScroll()中,用来判断是否滚动是否结束。

      举例说明,自定义一个CustomView,使用Scroller实现滚动: 

    复制代码
    import android.content.Context;
    import android.util.AttributeSet;
    import android.util.Log;
    import android.view.View;
    import android.widget.LinearLayout;
    import android.widget.Scroller;
    
    public class CustomView extends LinearLayout {
    
        private static final String TAG = "Scroller";
    
        private Scroller mScroller;
    
        public CustomView(Context context, AttributeSet attrs) {
            super(context, attrs);
            mScroller = new Scroller(context);
        }
    
        //调用此方法滚动到目标位置
        public void smoothScrollTo(int fx, int fy) {
            int dx = fx - mScroller.getFinalX();
            int dy = fy - mScroller.getFinalY();
            smoothScrollBy(dx, dy);
        }
    
        //调用此方法设置滚动的相对偏移
        public void smoothScrollBy(int dx, int dy) {
    
            //设置mScroller的滚动偏移量
            mScroller.startScroll(mScroller.getFinalX(), mScroller.getFinalY(), dx, dy);
            invalidate();//这里必须调用invalidate()才能保证computeScroll()会被调用,否则不一定会刷新界面,看不到滚动效果
        }
        
        @Override
        public void computeScroll() {
        
            //先判断mScroller滚动是否完成
            if (mScroller.computeScrollOffset()) {
            
                //这里调用View的scrollTo()完成实际的滚动
                scrollTo(mScroller.getCurrX(), mScroller.getCurrY());
                
                //必须调用该方法,否则不一定能看到滚动效果
                postInvalidate();
            }
            super.computeScroll();
        }
    }
    复制代码
  • 相关阅读:
    Shiro安全框架之集成 Web(下)
    Shiro安全框架之集成 Web(中)
    Shiro安全框架之集成 Web(上)
    01背包
    巴什博弈
    斐波那契博弈
    一. 至少转最多
    平面分割类问题
    求凸包(安德鲁算法)
    GCD和exGCD
  • 原文地址:https://www.cnblogs.com/awkflf11/p/6608169.html
Copyright © 2011-2022 走看看