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;
}
相关推荐
CoovallyAIHub3 天前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub3 天前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub3 天前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub3 天前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub3 天前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉
这张生成的图像能检测吗5 天前
(论文速读)XLNet:语言理解的广义自回归预训练
人工智能·计算机视觉·nlp·注意力机制
十铭忘5 天前
自主认知-行动1——架构
人工智能·计算机视觉
yuzhuanhei5 天前
YOLO26实操记录(自用)
人工智能·计算机视觉·目标跟踪
sali-tec5 天前
C# 基于OpenCv的视觉工作流-章27-图像分割
图像处理·人工智能·opencv·算法·计算机视觉
saoys5 天前
Opencv 学习笔记:腐蚀操作 + 轮廓标记 + 分水岭分割
笔记·opencv·学习