图像旋转

绕原点旋转
newx=x*cosa-y*sina
newy=x*sina+y*cosa
绕某一定点A(x0,y0)旋转
1.平移变换,将坐标原点移动到A点
newx=x-x0
newy=y-y0
2.旋转
newx=newx*cosa-newy*sina
newy=newx*sina+newx*cosa
3.平移变换,将坐标原点变回原来的O(0,0)点
newx=newx+x0
newy=newy+y0

PS:
在C#中,Math.Cos,Math.Sin等操作采用的angle度量为弧度!

在Emgu中,Rotation采用的angle度量为角度!

code:

 private Point translation(Point pt,Point pteye,double angle)
        {
            //pt:原始坐标 pteye:参考点原始坐标 
            Point newpt = new Point();          
            pt.X -= pteye.X;
            pt.Y -= pteye.Y;
            newpt.X = Convert.ToInt16(pt.X * Math.Cos(angle) - pt.Y * Math.Sin(angle)+pteye.X);
            newpt.Y = Convert.ToInt16(pt.X * Math.Sin(angle) + pt.Y * Math.Cos(angle) + pteye.Y);    
            return newpt;
        }

result:

以左眼中心为旋转中心,旋转后左眼中心坐标不变,其余标记点均有变换


对所有点进行坐标变换后


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
图像数据增强是一种广泛应用于计算机视觉任务中的技术,它可以通过对原始图像进行一系列变换来增加训练数据的多样性。图片旋转是其中一种常见的数据增强方式之一。 在图像旋转过程中,可以使用旋转矩阵来对图像进行变换。旋转矩阵定义了一个旋转角度和旋转中心点,通过将每个像素点围绕中心点按照指定的角度进行旋转,从而实现图像的旋转操作。 在进行图像旋转时,可以选择不同的角度来生成不同方向的旋转图像。常见的角度包括90度、180度和270度等,也可以使用任意角度进行旋转。 以下是一个使用Python和OpenCV库进行图像旋转的示例代码: ```python import cv2 def rotate_image(image, angle): # 获取图像尺寸 height, width = image.shape[:2] # 计算旋转中心点 center = (width / 2, height / 2) # 定义旋转矩阵 rotation_matrix = cv2.getRotationMatrix2D(center, angle, 1.0) # 执行旋转操作 rotated_image = cv2.warpAffine(image, rotation_matrix, (width, height)) return rotated_image # 读取图像 image = cv2.imread('image.jpg') # 旋转图像 rotated_image = rotate_image(image, 90) # 显示旋转后的图像 cv2.imshow('Rotated Image', rotated_image) cv2.waitKey(0) cv2.destroyAllWindows() ``` 以上代码中,`rotate_image` 函数用于对图像进行旋转操作。首先获取图像的尺寸,然后通过 `cv2.getRotationMatrix2D` 函数计算旋转矩阵。最后使用 `cv2.warpAffine` 函数执行旋转操作,生成旋转后的图像。 请注意,以上代码仅为示例,实际使用时可能需要根据具体需求进行调整。另外,OpenCV还提供了其他图像旋转的函数和参数选项,可以根据需要进行更灵活的处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值