欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android實現(xiàn)View的拖拽

 更新時間:2020年05月29日 09:03:39   作者:lanlengran藍冷然  
這篇文章主要為大家詳細介紹了Android實現(xiàn)View的拖拽,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了Android實現(xiàn)View拖拽的具體代碼,供大家參考,具體內(nèi)容如下

前言

實現(xiàn)View的拖拽,其實原理很簡單。無非就是獲取手指的位移信息,然后view根據(jù)手指的位移信息,移動對應的位置。

首先是獲取手機的位移信息就可以根據(jù)需求不同分為兩種

  • 拖拽view本身,view實現(xiàn)移動。則設置view的setOnTouchListener。
  • 在activity中隨意滑動,view都會反應出動作。則重寫activity onTouchEvent方法。

而移動的方法嘛,也有幾種

  • 給view設置補間動畫,動畫時間為0.(不推薦,因為移動的只是view的影子,本地還在原地)
  • 更改view 的margin。(不推薦,會影響viewgroup的布局排布)
  • 根據(jù)屬性動畫原理,更改setTranslationX和setTranslationY.(推薦此方法,不會影響原理的布局排布)

代碼

public class ViewTestActivity extends AppCompatActivity {
  private static final String TAG = "ViewTestActivity";
  private TextView mTv1,mTv2;
  private double lastx,lastY;
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_view_test);
    mTv1= (TextView) findViewById(R.id.tv01);
    mTv1.setOnTouchListener(new View.OnTouchListener() {
      @Override
      public boolean onTouch(View v, MotionEvent event) {
        double x=event.getRawX();
        double y=event.getRawY();
        Log.d(TAG, "onTouch: "+event.getAction());
        if (event.getAction()==MotionEvent.ACTION_DOWN){
          lastx=x;
          lastY=y;
        }else if (event.getAction()==MotionEvent.ACTION_MOVE){
          double dx=x-lastx;
          double dy=y-lastY;
          Log.d(TAG, "onTouch: dx=="+dx+",dy=="+dy);
//      startAnimation(dx,dy);

          // moveMethod1(dx, dy);
          moveMethod2(dx, dy);

          lastx=x;
          lastY=y;
        }
        return true;
      }
    });
  }

//  @Override
//  public boolean onTouchEvent(MotionEvent event) {
//    double x=event.getRawX();
//    double y=event.getRawY();
//    Log.d(TAG, "onTouch: "+event.getAction());
//    if (event.getAction()==MotionEvent.ACTION_DOWN){
//      lastx=x;
//      lastY=y;
//    }else if (event.getAction()==MotionEvent.ACTION_MOVE){
//      double dx=x-lastx;
//      double dy=y-lastY;
//      Log.d(TAG, "onTouch: dx=="+dx+",dy=="+dy);
////      startAnimation(dx,dy);
//
//     // moveMethod1(dx, dy);
//      moveMethod2(dx, dy);
//
//      lastx=x;
//      lastY=y;
//    }
//    return true;
//  }

  //根據(jù)屬性動畫的原理
  private void moveMethod2(double dx, double dy) {
    
    mTv1.setTranslationX((float) (mTv1.getTranslationX()+dx));
    mTv1.setTranslationY((float) (mTv1.getTranslationY()+dy));
  }
  
  //根據(jù)margin 原理
  private void moveMethod1(double dx, double dy) {
    ViewGroup.MarginLayoutParams marginLayoutParams= (ViewGroup.MarginLayoutParams) mTv1.getLayoutParams();
    marginLayoutParams.leftMargin+=dx;
    marginLayoutParams.topMargin+=dy;
    mTv1.setLayoutParams(marginLayoutParams);
  }

  private void startAnimation(double dx, double dy) {
    ObjectAnimator objectAnimator=ObjectAnimator.ofFloat(mTv1,"translationX", (float) (mTv1.getTranslationX()+dx)).setDuration(3000);
    objectAnimator.start();

    ObjectAnimator objectAnimator2=ObjectAnimator.ofFloat(mTv1,"translationY", (float) (mTv1.getTranslationY()+dy)).setDuration(3000);
    objectAnimator2.start();
  }
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論