SwiftUI简明概念(3):Path.addArc的clockwise方向问题

一、画个下半圆

SwiftUI中绘制下半圆的一个方法是使用Path.addArc,示例代码如下:

var body: some View {
    Path { path in
        path.addArc(center: CGPoint(x: 200, y: 370), radius: 50, startAngle: Angle(degrees: 0), endAngle: Angle(degrees: 180.0), clockwise: true)
        path.closeSubpath()
    }
}

Path.addArc的参数分别表示圆弧的中心点位置,圆弧半径,开始角度,结束角度以及圆弧方向(顺时针还是逆时针)。我们来看看最终的效果:

如果我们把时钟放在屏幕上,顺时针从0到180度,应该是从3点到9点的下半圆区域,跟我们实际绘制方向刚好相反。为什么呢?

二、原因

绘制系统默认使用的是笛卡尔坐标系,这个没有问题,就像下图所示:

但是这里有个问题,绘制的实际效果还要考虑当前图形上下文的变换矩阵。在一个翻转坐标系统,例如UIKit和SwiftUI中,顺时针方向在应用翻转后就会变成逆时针方向:

所以最终我们得到了一个和直觉相反的上半圆。

三、参考

Is clockwise of Path.addArc in SwiftUI wrong? - Stack Overflow

Apple文档:Core Graphics/CGContext/addArc

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值