极客工坊

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 7041|回复: 1

[OpenCV2.4]图像变换之三点变换指定矩阵变换

[复制链接]
发表于 2012-8-8 17:29:31 | 显示全部楼层 |阅读模式
我的博客:http://zwmin.com

#include <iostream>
#include <opencv2/core/core.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include <opencv2/highgui/highgui.hpp>
int
main(int argc, char *argv[])
{
  cv::Mat src_img = cv::imread("../../image/lenna.png", 1);
  if(src_img.empty()) return -1;
  // 变换前三点
  const cv::Point2f src_pt[] = { cv::Point2f(200, 200), cv::Point2f(250, 200), cv::Point2f(200, 100) };
  // 变换后三点
  const cv::Point2f dst_pt[] = { cv::Point2f(300, 100), cv::Point2f(300, 50), cv::Point2f(200, 100) };
  // 通过三点的变换计算矩阵的变换
  const cv::Mat affine_matrix = cv::getAffineTransform(src_pt, dst_pt);
  std::cout << "affine_matrix=\n" << affine_matrix << std::endl;
  cv::Mat dst_img;
  cv::warpAffine(src_img, dst_img, affine_matrix, src_img.size());
  // 画出变换前后的三点连线
  cv::line(src_img, src_pt[0], src_pt[1], cv::Scalar(255,255,0), 2);
  cv::line(src_img, src_pt[1], src_pt[2], cv::Scalar(255,255,0), 2);
  cv::line(src_img, src_pt[2], src_pt[0], cv::Scalar(255,255,0), 2);
  cv::line(src_img, dst_pt[0], dst_pt[1], cv::Scalar(255,0,255), 2);
  cv::line(src_img, dst_pt[1], dst_pt[2], cv::Scalar(255,0,255), 2);
  cv::line(src_img, dst_pt[2], dst_pt[0], cv::Scalar(255,0,255), 2);
  cv::namedWindow("src", CV_WINDOW_AUTOSIZE|CV_WINDOW_FREERATIO);
  cv::namedWindow("dst", CV_WINDOW_AUTOSIZE|CV_WINDOW_FREERATIO);
  cv::imshow("src", src_img);
  cv::imshow("dst", dst_img);
  cv::waitKey(0);
}

输入画像:

输出结果:

affine_matrix=
[0, 1, 100;
  -1, -3.255497723249808e-17, 300.0000000000001]



回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|联系我们|极客工坊 ( 浙ICP备09023225号 )

GMT+8, 2020-7-13 20:53 , Processed in 0.050980 second(s), 24 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表