首頁 > 軟體

Android View滑動的實現分析範例

2022-08-02 18:09:02

實現View滑動有很多種方法,這篇貼文介紹6中滑動的方法,分別是:

layout()、offsetLeftAndRight()、offsetTopAndBottom()、LayoutParams、scrollTo、scrollBy、Scroller。

1.layout方法

繪製View的時候會呼叫onLayout方法來設定顯示的位置,因此我們同樣也可以通過修改View的left、top、right、bottom、這四個屬性來控制View的座標。首先我們要自定義一個View在onTouchEvent方法中獲取觸控點的座標:

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        //獲取手指觸控點的橫座標和縱座標
        int x = (int) event.getX();
        int y = (int) event.getY();
        switch (event.getAction()) {
            case MotionEvent.ACTION_DOWN:
                lastX = x;
                lastY = y;
                break;
        }
....
    }

接下來我們在ACTION_MOVE事件中計算偏移量,再呼叫layout方法重新放置這個自定義View的位置。

            case MotionEvent.ACTION_MOVE:
                //計算移動的距離
                int offsetX = x - lastX;
                int offsetY = y - lastY;
                //呼叫layout方法來重新放置它
                layout(getLeft() - offsetX, getTop() + offsetY, getRight() - offsetX, getBottom() - offsetY);
                break;

在每次移動時都會呼叫layout方法對螢幕重新佈局,從而達到移動View的效果。

2.offsetLeftAndRight()與offsetTopAndBottom()

其這兩種方法和layout方法效果差不多,其使用方法也差不多。我們將ACTION_MOVE中的程式碼替代如下:

            case MotionEvent.ACTION_MOVE:
                //計算移動的距離
                int offsetX = x - lastX;
                int offsetY = y - lastY;
                //對left和right進行偏移
                offsetLeftAndRight(offsetX);
                //對top和bottom進行偏移
                offsetTopAndBottom(offsetY);
                break;

3.LayoutParams(改變佈局引數)

LayoutParms 主要儲存了一個View的佈局引數 , 因此我們可以通過LayoutParams來改變View的採納數;從而達到改變View位置的效果。同樣,我們將ACTION_MOVE中的程式碼替換如下:

                LinearLayout.LayoutParams layoutParams = (LinearLayout.LayoutParams) getLayoutParams();
                layoutParams.leftMargin = getLeft() + offsetX;
                layoutParams.topMargin = getLeft() + offsetY;
                setLayoutParams(layoutParams);

4.scrollTo與scrollBy

scrollTo(x,y) 表示移動到一個具體的座標點,而scrollBy(dx.dy)則表示移動的增量為dx,dy。

其中,scrollBy最終也是要呼叫scrollTo的。View.java檔案中的scrollBy和scrollTo程式碼如下:

scrollTo、scrollBy 移動的是View的內容,如果在ViewGroup中使用,則是移動其所有的子View,我們將ACTION_MOVE中的程式碼替換如下:

                ((View) getParent()).scrollBy(-offsetX, -offsetY);

這裡若要實現View隨手指移動的效果,則需要將偏移量設定為負值,為什麼要設定負值呢?

假設我們正在用放大鏡來看報紙,放大鏡用來顯示子的內容,同樣我們可以吧放大鏡看作我們的手機螢幕,它們都是負責顯示內容,也就是報紙的內容不會隨著放大鏡的移動而消失,它一直存在,同樣,我們的手機螢幕看不到的檢視並不代表其不存在,上圖畫布中有3個控制元件,及Button、EditText和SwitchButton。只有Button在螢幕中顯示,它的Android座標為(60,60)。現在我們呼叫scrollBy(50,50),按照字面的意思,這個Button應該會在螢幕右下側,可事實並非如此。如果我們呼叫scrollBy(50,50)裡面的引數都會正值,則我們的手機螢幕想X軸正方向,也就是右邊平移50然後螢幕向Y正方向,也就是下方平移50,雖然我們設定的數值是正數並且在X軸和Y軸的正方向移動,但Button卻向反方向移動了,這就是參考物件不同導致的差異。

所以,當我們使用scrollBy方法的時候,要是設定負數才會達到自己想要的效果。

5.Scroller

我們在用scrollTo/scrollBy方法進行滑動時,這個過程是瞬間完成的,所以使用者體驗並不好,這裡我們可以使用Scroller來實現有過度效果的滑動,這個過程不是瞬間完成的,而是在一定的時間間隔內完成的。Scroller本身不能實現View的滑動,它需要與View的computeScroll方法配合才能實現彈性滑動效果

    public MyView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        mScroller = new Scroller(context);
    }

接下來重寫computeScroll方法,系統會在繪製View的時候在draw方法中呼叫該方法,在這個方法中,我們呼叫父類別的scrollTo方法並通過Scroller來不斷獲取當前的滑動值。每滑動一小段距離,我們就會呼叫invalidate方法不斷的進行重繪。重繪就會呼叫computeScroll方法,這樣我們通過不斷地移動一個小的距離並連貫起來就實現了平滑移動的效果。

    @Override
    public void computeScroll() {
        super.computeScroll();
        if (mScroller.computeScrollOffset()) {
            ((View) getParent()).scrollTo(mScroller.getCurrX(), mScroller.getCurrY());
            invalidate();
        }
    }

我們會在View中寫一個smoothScrollTo方法,呼叫Scroller的startScroll方法,在200ms內沿X軸平移delta畫素

    public void smoothScrollTo(int destX, int destY) {
        int scrollX = getScrollX();
        int delta = destX - scrollX;
        mScroller.startScroll(scrollX, 0, delta, 0, 2000);
        invalidate();
    }

最後我們在ViewSlideActivity.Java中呼叫View的smoothScrollTo方法。在此我們設定View沿V軸向右平移400畫素

mCustomView.smoothScrollTo(-400,0);

到此這篇關於Android View滑動的實現分析範例的文章就介紹到這了,更多相關Android View滑動內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com