视图 view
package shidongliang.bwei.com.mycircle01.view;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;
/**
* 此类的作用:
*
* @author: forever
* @date: 2017/11/1 19:56
*/
public class CustomCircleView extends View {
private int cx = 200;
private int cy = 200;
private Paint paint;
public CustomCircleView(Context context) {
super(context);
}
public CustomCircleView(Context context, AttributeSet attrs) {
super(context, attrs);
paint = new Paint();
paint.setColor(Color.RED);
paint.setStyle(Paint.Style.STROKE);
paint.setAntiAlias(true);
paint.setStrokeWidth(5);
}
public CustomCircleView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
@Override
public boolean onTouchEvent(MotionEvent event) {
switch (event.getAction()){
case MotionEvent.ACTION_DOWN:
System.out.println("event ACTION_DOWN = " + event.getRawX() + " " + event.getRawY());
break;
case MotionEvent.ACTION_MOVE:
System.out.println("event ACTION_MOVE = " + event.getRawX() + " " + event.getRawY());
cx = (int) event.getX() ;
cy =(int) event.getY();
//刷新
invalidate();
// postInvalidate();
break;
case MotionEvent.ACTION_UP:
System.out.println("event ACTION_UP = " + event.getRawX() + " " + event.getRawY());
break;
}
return true;
}
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
canvas.drawCircle(cx,cy,200,paint);
}
}
布局--------------------------
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="shidongliang.bwei.com.mycircle01.MainActivity">
<shidongliang.bwei.com.mycircle01.view.CustomCircleView
android:layout_width="match_parent"
android:layout_height="match_parent" />
</RelativeLayout>
文章标题 鼠标拖动圆形移动
最新推荐文章于 2021-03-19 11:59:19 发布