Android實現View的拖拽
阿新 • • 發佈:2020-05-30
本文例項為大家分享了Android實現View拖拽的具體程式碼,供大家參考,具體內容如下
前言
實現View的拖拽,其實原理很簡單。無非就是獲取手指的位移資訊,然後view根據手指的位移資訊,移動對應的位置。
首先是獲取手機的位移資訊就可以根據需求不同分為兩種
- 拖拽view本身,view實現移動。則設定view的setOnTouchListener。
- 在activity中隨意滑動,view都會反應出動作。則重寫activity onTouchEvent方法。
而移動的方法嘛,也有幾種
- 給view設定補間動畫,動畫時間為0.(不推薦,因為移動的只是view的影子,本地還在原地)
- 更改view 的margin。(不推薦,會影響viewgroup的佈局排布)
- 根據屬性動畫原理,更改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,dy=="+dy); //// startAnimation(dx,dy); // // // moveMethod1(dx,dy); // moveMethod2(dx,dy); // // lastx=x; // lastY=y; // } // return true; // } //根據屬性動畫的原理 private void moveMethod2(double dx,double dy) { mTv1.setTranslationX((float) (mTv1.getTranslationX()+dx)); mTv1.setTranslationY((float) (mTv1.getTranslationY()+dy)); } //根據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(); } }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。