`
java-mans
  • 浏览: 11930830 次
文章分类
社区版块
存档分类
最新评论

opencv 旋转图像函数实现 等同于matlab里的rotate() (注:旋转后图像变大,超出部分填为黑色)

 
阅读更多

注:clockwise=true 顺时针旋转

clockwise=false 逆时针旋转


IplImage* rotateImage(IplImage* src, int angle, bool clockwise)

{
angle = abs(angle) % 180;
if (angle > 90)
{
angle = 90 - (angle % 90);
}
IplImage* dst = NULL;
int width =
(double)(src->height * sin(angle * CV_PI / 180.0)) +
(double)(src->width * cos(angle * CV_PI / 180.0 )) + 1;
int height =
(double)(src->height * cos(angle * CV_PI / 180.0)) +
(double)(src->width * sin(angle * CV_PI / 180.0 )) + 1;
int tempLength = sqrt((double)src->width * src->width + src->height * src->height) + 10;
int tempX = (tempLength + 1) / 2 - src->width / 2;
int tempY = (tempLength + 1) / 2 - src->height / 2;
int flag = -1;

dst = cvCreateImage(cvSize(width, height), src->depth, src->nChannels);
cvZero(dst);
IplImage* temp = cvCreateImage(cvSize(tempLength, tempLength), src->depth, src->nChannels);
cvZero(temp);

cvSetImageROI(temp, cvRect(tempX, tempY, src->width, src->height));
cvCopy(src, temp, NULL);
cvResetImageROI(temp);

if (clockwise)
flag = 1;

float m[6];
int w = temp->width;
int h = temp->height;
m[0] = (float) cos(flag * angle * CV_PI / 180.);
m[1] = (float) sin(flag * angle * CV_PI / 180.);
m[3] = -m[1];
m[4] = m[0];
// 将旋转中心移至图像中间
m[2] = w * 0.5f;
m[5] = h * 0.5f;
//
CvMat M = cvMat(2, 3, CV_32F, m);
cvGetQuadrangleSubPix(temp, dst, &M);
cvReleaseImage(&temp);
return dst;
}
分享到:
评论

相关推荐

    基于opencv的图像旋转,功能类似matlab的imrotate函数

    本篇将深入探讨如何利用OpenCV实现图像的旋转,以及这一功能与MATLAB中的`imrotate`函数的相似性。 在OpenCV中,图像旋转主要通过`getRotationMatrix2D`和`warpAffine`或`warpPerspective`这两个函数来完成。`...

    matlab图像处理实验和opencv cv2 图像处理.zip

    例如,在MATLAB中,我们可以使用imread函数来读取图像,imshow用于显示图像,imresize进行图像的大小调整,imrotate实现图像的旋转,imwrite将处理后的图像保存。对于颜色空间转换,imrgb2gray可以将RGB图像转换为...

    DSP图像处理函数集

    5. 旋转与翻转:改变图像方向,如rotate函数和flip函数。 6. 图像直方图:统计图像像素值的分布,用于分析图像亮度特性,如histogram函数。 7. Canny边缘检测:一种自适应的边缘检测算法,用于找到图像中的显著边缘...

    opencv英文开发入门手册

    3. 图像基本操作:包括缩放、旋转、裁剪、平移等,可以利用`resize()`, `rotate()`, `crop()`, `translate()`等函数实现。 四、颜色空间转换 OpenCV支持多种颜色空间之间的转换,例如BGR到灰度、HSV等。常用函数如`...

    使用Python进行图像处理

    3. **丰富的库支持**:Python社区提供了大量的第三方库,如PIL(Python Imaging Library)、OpenCV等,这些库极大地简化了图像处理的复杂度。 4. **跨平台**:Python程序可以在多种操作系统上运行,具有很好的可移植性...

    用Python进行图像处理

    - **旋转图像**:使用`rotate()`方法,如`rotated_img = img.rotate(angle)`,可以指定旋转角度。 - **格式转换**:`save()`方法可以将图像保存为不同格式,例如`img.save("new_format.png")`。 2. **其他模块*...

Global site tag (gtag.js) - Google Analytics