代码如下:
#include<opencv.hpp>
#include<iostream>
using namespace std;
int main()
{
int b = 0, g = 0, r = 255;
cv::Mat image = cv::imread("F:\\ebook\\opencv\\LearningOpenCV3\\test\\test\\timg.jpg");
cv::resize(image, image, cv::Size(640, 480));
int h = image.size[0];
int w = image.size[1];
cv::namedWindow("window1");
cv::imshow("window1", image);
cv::waitKey(0);
cv::Point2f src[] = { cv::Point2f(0, 0), cv::Point2f(w - 1, 0), cv::Point2f(w - 1, h - 1),cv::Point2f(0,h-1) };
cv::Point2f dst[] = { cv::Point2f(0.25*w, 0), cv::Point2f(0.75*(w-1), 0), cv::Point2f(w - 1, h - 1), cv::Point2f(0, h - 1) };
cv::Mat warp_mat = cv::getPerspectiveTransform(src, dst);
cv::Mat resultimage;
cv::warpPerspective(image, resultimage, warp_mat, cv::Size(w,h), cv::INTER_LINEAR, cv::BORDER_CONSTANT, cv::Scalar());
cv::namedWindow("window2");
cv::imshow("window2", resultimage);
cv::waitKey(0);
cv::destroyWindow("window1");
cv::destroyWindow("window2");
return 0;
}
运行结果如图: