opencv 拉伸、扭曲、旋转图像-透视变换

 <span style="font-family: Arial, Helvetica, sans-serif;">/* Warps image with perspective (projective) transform */</span>
CVAPI(void)  cvWarpPerspective( const CvArr* src, CvArr* dst, const CvMat* map_matrix,
                                int flags CV_DEFAULT(CV_INTER_LINEAR+CV_WARP_FILL_OUTLIERS),
                                CvScalar fillval CV_DEFAULT(cvScalarAll(0)) );

参数与cvWarpAffine()相同,有一个小的但很重要的区别是所采用的映射矩阵必须是3x3的


CvMat* cvGetPerspectiveTransform(
	const CvPoint2D32f* pts_src,
	const CvPoint2D32f* pts_dst,
	CvMat* map_matrix
	);
这里的pts_src和pts_dst是四个点的数组


void imageRotationP(void)
{
	CvPoint2D32f srcQuad[4], dstQuad[4];
	CvMat* warp_matrix = cvCreateMat(3, 3, CV_32FC1);
	IplImage *src, *dst;

	src=cvLoadImage("lena.jpg");
	dst=cvCloneImage(src);
	dst->origin = src->origin;
	cvZero(dst);

	srcQuad[0].x=0;//src Top left
	srcQuad[0].y=0;
	srcQuad[1].x=src->width-1;//src Top right
	srcQuad[1].y=0;
	srcQuad[2].x=0;//src Bottom left
	srcQuad[2].y=src->height-1;
	srcQuad[3].x=src->width-1;//src Bottom right
	srcQuad[3].y=src->height-1;

	dstQuad[0].x=src->width*0.05;//dst Top left
	dstQuad[0].y=src->height*0.33;
	dstQuad[1].x=src->width*0.9;//dst Top right
	dstQuad[1].y=src->height*0.25;
	dstQuad[2].x=src->width*0.2;//dst Bottom left
	dstQuad[2].y=src->height*0.7;
	dstQuad[3].x=src->width*0.9;//dst Bottom right
	dstQuad[3].y=src->height*0.9;

	cvGetPerspectiveTransform(
		srcQuad, dstQuad, warp_matrix
		);

	cvWarpPerspective(src, dst, warp_matrix);
	cvNamedWindow("Perspective_Warp", 1);
	cvShowImage("Perspective_Warp", dst);
	cvWaitKey(0);
	cvReleaseImage(&src);
	cvReleaseImage(&dst);
	cvReleaseMat(&warp_matrix);
}



opencv 拉伸、扭曲、旋转图像-仿射变换

http://blog.csdn.net/u012005313/article/details/46714637


  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
图像配准是指将两幅或多幅图像进行对齐,使它们在几何形状和外观上尽可能的相似。而透视变换是一种仿射变换的扩展,可以将一个平面上的任意四边形转换为另一个平面上的任意四边形。 基于OpenCV图像配准之后,可以使用透视变换来实现图像的矫正、纠偏等操作。具体步骤如下: 1. 首先,通过图像配准的方法将待处理的图像对齐,得到对应的变换矩阵; 2. 然后,利用该变换矩阵进行透视变换,将图像进行矫正、纠偏等操作; 3. 最后,可以进行进一步的图像处理,如图像增强、目标检测等。 下面是一个基于OpenCV透视变换示例代码: ``` import cv2 import numpy as np # 读取原始图像 img = cv2.imread('test.png') # 设置目标图像的四个顶点 dst_points = np.float32([[100, 100], [500, 100], [500, 500], [100, 500]]) # 设置原始图像的四个顶点 src_points = np.float32([[10, 10], [630, 10], [630, 470], [10, 470]]) # 计算透视变换矩阵 M = cv2.getPerspectiveTransform(src_points, dst_points) # 进行透视变换 dst_img = cv2.warpPerspective(img, M, (600, 600)) # 显示结果 cv2.imshow('src_img', img) cv2.imshow('dst_img', dst_img) cv2.waitKey(0) cv2.destroyAllWindows() ``` 其中,dst_points 和 src_points 分别表示目标图像和原始图像的四个顶点坐标,通过 cv2.getPerspectiveTransform 方法计算透视变换矩阵 M,然后通过 cv2.warpPerspective 方法进行透视变换,最终得到矫正后的图像 dst_img。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值