2024-01-24 06:19:34 +01:00
|
|
|
function point_rotate(px, py, ox, oy, a, p = undefined) {
|
|
|
|
p ??= [ px, py ];
|
|
|
|
|
2024-11-10 05:17:30 +01:00
|
|
|
if(a == 0) { p[0] = px; p[1] = py; return p; }
|
|
|
|
else if(a == 180) { p[0] = ox + (ox - px); p[1] = oy + (oy - py); return p; }
|
2023-02-23 07:02:19 +01:00
|
|
|
|
2022-01-13 05:24:03 +01:00
|
|
|
var cx = px - ox;
|
|
|
|
var cy = py - oy;
|
|
|
|
|
2024-11-10 05:17:30 +01:00
|
|
|
var dc = dcos(-a);
|
|
|
|
var ds = dsin(-a);
|
|
|
|
|
|
|
|
p[0] = ox + cx * dc - cy * ds;
|
|
|
|
p[1] = oy + cx * ds + cy * dc;
|
|
|
|
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
function point_rotate_origin(px, py, a, p) {
|
|
|
|
INLINE
|
|
|
|
|
|
|
|
a = angle_difference(a, 0);
|
2024-12-22 09:01:16 +01:00
|
|
|
if(a == 0) { p[0] = px; p[1] = py; return p; }
|
|
|
|
if(a == 180) { p[0] = -px; p[1] = -py; return p; }
|
2024-11-10 05:17:30 +01:00
|
|
|
|
|
|
|
var dc = dcos(-a);
|
|
|
|
var ds = dsin(-a);
|
|
|
|
|
|
|
|
p[0] = px * dc - py * ds;
|
|
|
|
p[1] = px * ds + py * dc;
|
2024-01-24 06:19:34 +01:00
|
|
|
|
2024-12-22 09:01:16 +01:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
function point_vec2_rotate(p, ox, oy, a) {
|
|
|
|
var px = p.x;
|
|
|
|
var py = p.y;
|
|
|
|
|
|
|
|
if(a == 0) return p;
|
|
|
|
if(a == 180) { p.x = ox + (ox - px); p.y = oy + (oy - py); return p; }
|
|
|
|
|
|
|
|
var cx = px - ox;
|
|
|
|
var cy = py - oy;
|
|
|
|
|
|
|
|
var dc = dcos(-a);
|
|
|
|
var ds = dsin(-a);
|
|
|
|
|
|
|
|
p.x = ox + cx * dc - cy * ds;
|
|
|
|
p.y = oy + cx * ds + cy * dc;
|
|
|
|
|
2024-01-24 06:19:34 +01:00
|
|
|
return p;
|
2022-01-13 05:24:03 +01:00
|
|
|
}
|