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;
}
相关推荐
小小杨树2 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
H__Rick4 天前
自动对焦学习-3
人工智能·学习·计算机视觉
计算机科研狗@OUC4 天前
(cvpr26) AIMDepth: Asymmetric Image-Event Mamba for Monocular Depth Estimation
人工智能·深度学习·计算机视觉
qq_366566504 天前
2026最新:5款AI视频口型同步工具实测横评,视频翻译后嘴型对不上的终极解决方案
人工智能·计算机视觉·新媒体运营
梦想三三4 天前
OpenCV银行卡数字识别项目(图像预处理与字符分割)
人工智能·opencv·计算机视觉
kaikaile19954 天前
图像稀疏化分解 + 压缩感知(CS)重建 MATLAB
开发语言·计算机视觉·matlab
武子康4 天前
调查研究-180 roboflow/supervision:计算机视觉工程里的“胶水层“,为什么值得关注?
人工智能·opencv·计算机视觉·chatgpt·llm·向量化
YOLO数据集集合4 天前
无人机风电设备智能巡检 风机叶片缺陷目标检测数据集实战 | 表面腐蚀漏油识别 工业视觉质检 深度学习模型训练落地10337期
人工智能·深度学习·目标检测·计算机视觉·无人机
装不满的克莱因瓶4 天前
【工业领域】了解目标检测基本流程——从数据到部署的完整工程化思路
人工智能·python·深度学习·机器学习·计算机视觉·目标跟踪·工业领域