Android:View隨手指移動


View的自動移動,我們可以設置動畫,如之類提到的 ViewCompatAnimation

如何是View隨着手指的移動而移動呢? 

onTouch事件實現

@Override
public boolean onTouch(View v, MotionEvent event) {
    switch (event.getAction()) {
        case MotionEvent.ACTION_DOWN:
            break;
        case MotionEvent.ACTION_MOVE:
            moveView(view, event.getRawX(), event.getRawY());
            break;
        case MotionEvent.ACTION_UP:
            break;
    }
    return true;
}

 

說明:

onTouch(View view,MotionEvent event)這個方法

getRawX()和getRawY()獲得的是相對屏幕的位置,

getX()和getY()獲得的永遠是view的觸摸位置坐標這兩個值不會超過view的長度和寬度)。

如是Activity的 onTouchEvent(MotionEvent event) 方法,這個時候獲得的是屏幕點擊位置的坐標。getRawX()與getX()訪求獲取的值是一樣的。

 

方法1:setLayoutParams

/**

   * 設置View的布局屬性,使得view隨着手指移動 注意:view所在的布局必須使用RelativeLayout 而且不得設置居中等樣式  

   */

 private void moveView(View view, float rawX, float rawY) {
    RelativeLayout.LayoutParams params = (RelativeLayout.LayoutParams) view
            .getLayoutParams();
    params.leftMargin = (int) rawX - ivMove.getWidth() / 2;
    params.topMargin = (int) rawY - topTitleHeight - ivMove.getHeight() / 2;
    view.setLayoutParams(params);
}

 

 

方法2:view.layout(l,t,r,b)

/**
 * 通過layout方法,移動view 
 * 優點:對view所在的布局,要求不苛刻,不要是RelativeLayout,而且可以修改view的大小
 */
private void moveViewByLayout(View view, int rawX, int rawY) {
    int left = rawX - ivMove.getWidth() / 2;
    int top = rawY - topTitleHeight - ivMove.getHeight() / 2;
    int width = left + view.getWidth();
    int height = top + view.getHeight();
    view.layout(left, top, width, height);
}

 

方法3:ScrollBy()或者ScrollTo();

/** 

 * 在activity中實現
 * scrollBy() 相對於當前的坐標進行偏移
 * scrollTo() 相對於屏幕的左上角進行偏移
 @param event
 */
@Override
public boolean onTouchEvent(MotionEvent event) {
    switch (event.getAction()){
        case MotionEvent.ACTION_DOWN:
            currentX= (int) event.getX();
            currentY= (int) event.getY();
            break;
        case MotionEvent.ACTION_MOVE:
            int x2= (int) event.getX();
            int y2= (int) event.getY();
            container.scrollBy(currentX - x2, currentY - y2);
            currentY=y2;
            currentX=x2;
            xyValue.setText(x2+","+y2);
            break;
        case MotionEvent.ACTION_UP:
            break;
    }
    return true;
}

 






免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM