您好,登錄后才能下訂單哦!
這篇文章主要介紹了Android如何實現(xiàn)自定義view圓并隨手指移動,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
具體內容如下
main代碼
public class MainActivity extends AppCompatActivity { private int screenW; //屏幕寬度 private int screenH; //屏幕高度 @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); Display dis = this.getWindowManager().getDefaultDisplay(); // 設置全屏 requestWindowFeature(Window.FEATURE_NO_TITLE); this.getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN); // 獲取屏幕寬度 screenW = dis.getWidth(); // 獲取屏幕高度 screenH = dis.getHeight(); setContentView(new MyView(this)); } //自定義繪圖類 class MyView extends View { private Paint paint; //定義畫筆 private float cx = 50; //圓點默認X坐標 private float cy = 50; //圓點默認Y坐標 private int radius = 20; //定義顏色數(shù)組 private int colorArray[] = {Color.BLACK,Color.BLACK,Color.GREEN,Color.YELLOW, Color.RED}; private int paintColor = colorArray[0]; //定義畫筆默認顏色 public MyView(Context context) { super(context); //初始化畫筆 initPaint(); } private void initPaint(){ paint = new Paint(); //設置消除鋸齒 paint.setAntiAlias(true); //設置畫筆顏色 paint.setColor(paintColor); } //重寫onDraw方法實現(xiàn)繪圖操作 @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); //將屏幕設置為白色 canvas.drawColor(Color.WHITE); //修正圓點坐標 revise(); //隨機設置畫筆顏色 setPaintRandomColor(); //繪制小圓作為小球 canvas.drawCircle(cx, cy, radius, paint); } //為畫筆設置隨機顏色 private void setPaintRandomColor(){ Random rand = new Random(); int randomIndex = rand.nextInt(colorArray.length); paint.setColor(colorArray[randomIndex]); } //修正圓點坐標 private void revise(){ if(cx <= radius){ cx = radius; }else if(cx >= (screenW-radius)){ cx = screenW-radius; } if(cy <= radius){ cy = radius; }else if(cy >= (screenH-radius)){ cy = screenH-radius; } } @Override public boolean onTouchEvent(MotionEvent event) { switch (event.getAction()) { case MotionEvent.ACTION_DOWN: // 按下 cx = (int) event.getX(); cy = (int) event.getY(); // 通知重繪 postInvalidate(); //該方法會調用onDraw方法,重新繪圖 break; case MotionEvent.ACTION_MOVE: // 移動 cx = (int) event.getX(); cy = (int) event.getY(); // 通知重繪 postInvalidate(); break; case MotionEvent.ACTION_UP: // 抬起 cx = (int) event.getX(); cy = (int) event.getY(); // 通知重繪 postInvalidate(); break; } /* * 備注1:此處一定要將return super.onTouchEvent(event)修改為return true,原因是: * 1)父類的onTouchEvent(event)方法可能沒有做任何處理,但是返回了false。 * 2)一旦返回false,在該方法中再也不會收到MotionEvent.ACTION_MOVE及MotionEvent.ACTION_UP事件。 */ //return super.onTouchEvent(event); return true; } } }
布局
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/activity_main" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.example.sn.MainActivity"> <com.example.sn.MainActivity.MyView android:id="@+id/myview" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerInParent="true" /> </RelativeLayout>
感謝你能夠認真閱讀完這篇文章,希望小編分享的“Android如何實現(xiàn)自定義view圓并隨手指移動”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業(yè)資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。