注: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中,图像旋转主要通过`getRotationMatrix2D`和`warpAffine`或`warpPerspective`这两个函数来完成。`...
例如,在MATLAB中,我们可以使用imread函数来读取图像,imshow用于显示图像,imresize进行图像的大小调整,imrotate实现图像的旋转,imwrite将处理后的图像保存。对于颜色空间转换,imrgb2gray可以将RGB图像转换为...
5. 旋转与翻转:改变图像方向,如rotate函数和flip函数。 6. 图像直方图:统计图像像素值的分布,用于分析图像亮度特性,如histogram函数。 7. Canny边缘检测:一种自适应的边缘检测算法,用于找到图像中的显著边缘...
3. 图像基本操作:包括缩放、旋转、裁剪、平移等,可以利用`resize()`, `rotate()`, `crop()`, `translate()`等函数实现。 四、颜色空间转换 OpenCV支持多种颜色空间之间的转换,例如BGR到灰度、HSV等。常用函数如`...
3. **丰富的库支持**:Python社区提供了大量的第三方库,如PIL(Python Imaging Library)、OpenCV等,这些库极大地简化了图像处理的复杂度。 4. **跨平台**:Python程序可以在多种操作系统上运行,具有很好的可移植性...
- **旋转图像**:使用`rotate()`方法,如`rotated_img = img.rotate(angle)`,可以指定旋转角度。 - **格式转换**:`save()`方法可以将图像保存为不同格式,例如`img.save("new_format.png")`。 2. **其他模块*...