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;
}
相关推荐
开开心心就好1 小时前
仅168KB的桌面图标自动隐藏工具
windows·计算机视觉·计算机外设·excel·启发式算法·宽度优先·csdn开发云
山居秋暝LS6 小时前
安装C++版opencv和opencv_contrib
开发语言·c++·opencv
xrgs_shz7 小时前
MATLAB 纹理特征提取:一文读懂 graycomatrix 与 graycoprops
人工智能·计算机视觉·matlab
格林威9 小时前
3D相机视觉检测:环境光太强,结构光点云全是噪点怎么办?
开发语言·人工智能·数码相机·计算机视觉·3d·视觉检测·工业相机
格林威9 小时前
线阵工业相机:线阵图像出现“波浪纹”,是机械振动还是编码器问题?
开发语言·人工智能·数码相机·计算机视觉·视觉检测·工业相机·线阵相机
β添砖java10 小时前
深度学习(15)卷积层
人工智能·深度学习·计算机视觉
sali-tec10 小时前
C# 基于OpenCv的视觉工作流-章59-九点标定
图像处理·人工智能·opencv·计算机视觉
格林威11 小时前
工业视觉检测:单样本学习 vs 传统监督学习
人工智能·深度学习·数码相机·学习·计算机视觉·视觉检测·工业相机
格林威11 小时前
工业视觉检测:两大主流异常检测开源框架深度对比(PatchCore vs SPADE)
开发语言·人工智能·深度学习·数码相机·计算机视觉·视觉检测·工业相机
嵌入式老牛12 小时前
液晶段码(米/日字格)识别—预处理
人工智能·opencv·计算机视觉