opencv技巧:投影变换代替旋转

普通旋转

cv::warpAffine 函数用来旋转图片

c 复制代码
static cv::Mat RotateMatWithTransparency(const cv::Mat& src, double angle) {
	//double angle = 45.0; // 旋转角度
	cv::Point2f center(src.cols / 2.0f, src.rows / 2.0f);
	cv::Mat rotMat = cv::getRotationMatrix2D(center, angle, 1.0);
	cv::Mat dst;
	cv::warpAffine(src, dst, rotMat, src.size(), cv::INTER_LINEAR, cv::BORDER_TRANSPARENT);
	return dst;
}

投影变换来做旋转

使用投影变换来代替旋转函数,使用warpPerspective 函数

c 复制代码
static cv::Mat rotateImageWithProjection(const cv::Mat& image, double angle, cv::Point2f center = cv::Point2f()) {
	if (center.x == 0 && center.y == 0) {
		center = cv::Point2f(image.cols / 2.0, image.rows / 2.0);
	}

	// 计算旋转矩阵(投影变换形式)
	double rad = angle * CV_PI / 180.0;
	double sinVal = sin(rad);
	double cosVal = cos(rad);

	// 构建3x3投影矩阵
	cv::Mat M = (cv::Mat_<double>(3, 3) <<
		cosVal, -sinVal, center.x * (1 - cosVal) + center.y * sinVal,
		sinVal, cosVal, center.y * (1 - cosVal) - center.x * sinVal,
		0, 0, 1
		);

	// 计算旋转后的图像尺寸,避免裁剪
	int newWidth = static_cast<int>(image.cols * fabs(cosVal) + image.rows * fabs(sinVal));
	int newHeight = static_cast<int>(image.cols * fabs(sinVal) + image.rows * fabs(cosVal));

	// 调整平移量,使图像居中
	M.at<double>(0, 2) += (newWidth / 2.0) - center.x;
	M.at<double>(1, 2) += (newHeight / 2.0) - center.y;

	// 应用投影变换
	cv::Mat rotated;
	warpPerspective(image, rotated, M, cv::Size(newWidth, newHeight),
		cv::INTER_LINEAR, cv::BORDER_CONSTANT, cv::Scalar(0, 0, 0));
	return rotated;
}
相关推荐
春日见14 小时前
5分钟入门强化学习之动态规划算法与实现
大数据·人工智能·python·算法·机器学习·计算机视觉
yubo050915 小时前
计算机视觉第三课:在图像上画框、画文字、画圆点
opencv·计算机视觉·目标跟踪
yubo050921 小时前
计算机视觉第五课:给每个物体画 bounding box
人工智能·opencv·计算机视觉
AI人工智能+21 小时前
赋能智慧监管:基于深度学习的特种行业许可证全要素精准识别系统
计算机视觉·自然语言处理·ocr·特种行业许可证识别
AGV算法笔记1 天前
OpenCV 二维码三维定位 普通摄像头也能测空间坐标
人工智能·数码相机·opencv·工业视觉· 机器人视觉
weixin_468466851 天前
机器学习与深度学习新手区分指南
人工智能·python·深度学习·机器学习·计算机视觉·ai·机器视觉
yubo05091 天前
计算机视觉第四课:寻找轮廓(自动框出所有物体)
人工智能·opencv·计算机视觉
fie88891 天前
近红外与可见光图像融合的ICA变换:原理、实现与应用
图像处理·人工智能·计算机视觉
sali-tec1 天前
C# 基于OpenCv的视觉工作流-章79-单位转换
图像处理·人工智能·opencv·算法·计算机视觉
彭祥.1 天前
无人考评利用旋转目标检测识别验电器
人工智能·目标检测·计算机视觉