点关于点旋转计算新坐标

        假设对图片上任意点(x,y),绕一个坐标点(rx0,ry0)逆时针旋转a角度后的新的坐标设为(x0, y0),有公式:

x0 = (x-rx0)*cos(a) - (y-ry0)*sin(a) + rx0; 
y0 = (x-rx0)*sin(a) + (y-ry0)*cos(a) + ry0;

测试逻辑:

        设置大小为512*512的画布,绿色点(100, 100)沿着红色中心点(200, 300)顺时针旋转30度。旋转结果为黄色点。

import cv2
import math
import numpy as np

def test():
    img = np.ones((512, 512, 3), dtype=np.uint8) * 255  # h,w,c
    center = (200, 300)  # x, y
    rx0, ry0 = center
    cv2.circle(img, (rx0, ry0), 5, (0, 0, 255), thickness=10)

    x, y = (100, 100)
    angle = math.radians(30)  # 角度转弧度
    cv2.circle(img, (x, y), 5, (0, 255, 0), thickness=10)
    cv2.line(img, center, (x, y), (0, 0, 0), thickness=2)

    x0 = int((x - rx0) * math.cos(angle) - (y - ry0) * math.sin(angle) + rx0)
    y0 = int((x - rx0) * math.sin(angle) + (y - ry0) * math.cos(angle) + ry0)
    cv2.circle(img, (x0, y0), 5, (0, 255, 255), thickness=10)
    cv2.line(img, center, (x0, y0), (0, 0, 0), thickness=2)

    cv2.imwrite("ret.jpg", img)

结果:

 推理过程:https://jingyan.baidu.com/article/2c8c281dfbf3dd0009252a7b.html

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jingbo1801

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值