Ответ 1
Учитывая точки p1
, p2
на окружности с центром center
,
вы сначала вычислите векторы разностей:
let v1 = CGVector(dx: p1.x - center.x, dy: p1.y - center.y)
let v2 = CGVector(dx: p2.x - center.x, dy: p2.y - center.y)
Тогда
let angle = atan2(v2.dy, v2.dx) - atan2(v1.dy, v1.dx)
- (направленный) угол между этими векторами в радианах и
var deg = angle * CGFloat(180.0 / M_PI)
угол в градусах. Вычисленное значение может быть в диапазоне -360.. 360, так что вы может хотеть нормализовать его до диапазона 0 <= deg < 360 с
if deg < 0 { deg += 360.0 }