画圆拖动0630

本文介绍了一个自定义的Android视图组件CircleView,该组件能够绘制一个红色圆圈,并支持触摸移动操作来改变圆的位置。文章详细展示了CircleView的实现代码,包括如何通过Canvas绘制圆、设置触摸事件监听等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Rect;
import android.support.annotation.Nullable;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;
 
/**
* Created by muhanxi on 17/6/6.
*/
 
public class CircleView extends View {
 
 
Paint paint;
private float x = 100;
private float y = 100;
 
 
 
Rect rect = new Rect();
 
public CircleView(Context context) {
super(context);
}
 
public CircleView(Context context, @Nullable AttributeSet attrs) {
super(context, attrs);
 
paint = new Paint();
paint.setColor(Color.RED);
paint.setAntiAlias(true);
 
}
 
public CircleView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
 
public CircleView(Context context, @Nullable AttributeSet attrs, int defStyleAttr, int defStyleRes) {
super(context, attrs, defStyleAttr, defStyleRes);
}
 
 
 
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
 
 
 
canvas.drawCircle(x,y,100,paint);
rect.set((int)(x-100),(int) (y-100),(int)( x+100),(int)(y+100));
 
 
 
}
 
 
@Override
public boolean onTouchEvent(MotionEvent event) {
 
switch (event.getAction()){
 
case MotionEvent.ACTION_DOWN:
 
break;
 
case MotionEvent.ACTION_MOVE:
 
float x1 = event.getX() ;
float y1 = event.getY();
if (x1 > rect.left && x1 < rect.right && y1 > rect.top && y1 < rect.bottom) {
//主线程调用刷新
x = event.getX();
y = event.getY();
invalidate();
 
//子线程 调用刷新
// postInvalidate();
}
 
 
 
 
 
 
 
 
 
 
 
break;
case MotionEvent.ACTION_UP:
 
break;
case MotionEvent.ACTION_POINTER_DOWN:
 
System.out.println("event = ACTION_POINTER_DOWN " + event);
break;
 
 
 
}
 
return true;
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值