android canvas rotate 速度,Android中的Canvas.rotate()问题。它是如何工作的?

博客探讨了在Android中使用Canvas绘制圆弧时,旋转操作对绘制效果的影响。作者发现,旋转调用的位置不同,会导致圆弧的起始角度变化。当旋转调用置于绘制圆弧之前时,圆弧的起始位置会按预期移动25度。然而,如果旋转调用放在绘制之后,圆弧的起始角度并未改变。文章旨在理解Canvas.rotate()函数的工作原理。

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

请在下面找到我的onDraw方法的代码(。我试图在绘制圆弧后旋转画布(//旋转调用-b)25度,但是我发现圆弧仍然是从0到50 degrees.I期待它被另一个25度移动。Android中的Canvas.rotate()问题。它是如何工作的?

public class CustomView extends View {

public CustomView(Context context) {

super(context);

}

public CustomView(Context context, AttributeSet attrs) {

super(context, attrs);

}

protected void onDraw(Canvas canvas) {

super.onDraw(canvas);

Paint paint = new Paint();

paint.setColor(Color.RED);

int px = getMeasuredWidth()/2;

int py = getMeasuredHeight()/2;

// radius - min

int radius = 130;

// Defining bounds for the oval for the arc to be drawn

int left = px - radius;

int top = py - radius;

int right = left + (radius * 2);

int bottom = top + (radius * 2);

RectF rectF = new RectF(left, top, right, bottom);

paint.setColor(Color.RED);

paint.setStyle(Style.FILL);

//canvas.rotate(25,px,py);//Rotate call -a

canvas.drawArc(rectF, 0, 50, true, paint);

canvas.rotate(25,px,py);//Rotate call -b

}

}

但是,如果我画弧前放置旋转呼叫(//调用旋转-a)我看到,所描绘的圆弧由25度移更准确。什么这里发生了什么?有人能解释一下吗?

感谢

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值