OpenCV實(shí)現(xiàn)透視變換矯正
本文實(shí)例為大家分享了OpenCV實(shí)現(xiàn)透視變換矯正的具體代碼,供大家參考,具體內(nèi)容如下
演示結(jié)果參考:

功能實(shí)現(xiàn):運(yùn)行程序,會顯示圖片的尺寸,按回車鍵后,依次點(diǎn)擊需矯正的圖片的左上、右上、左下、右下角,并能顯示其坐標(biāo),結(jié)果彈出矯正后的圖片,如圖上的PIC2對話框。可以繼續(xù)選擇圖片四個(gè)點(diǎn)進(jìn)行實(shí)驗(yàn),按下字符'q'后退出。
代碼如下:(注:圖中的11.jpg圖片自己選取放到該程序目錄下。)
//使用鼠標(biāo)在原圖像上選取感興趣區(qū)域
#include <opencv2/opencv.hpp>
#include <iostream>
#include <vector>
using namespace std;
using namespace cv;
const int N = 400;
const int M = 220;
Mat img;
Point p[5];
int flag = 1;
int cnt = 0;
static void mouse_callback(int event, int x, int y, int, void *) {
? ? //當(dāng)鼠標(biāo)左鍵按下時(shí),記錄其坐標(biāo)
? ? if(event == EVENT_LBUTTONDOWN) {
? ? ? ? p[cnt].x = x*1.0; p[cnt++].y = y*1.0;
? ? ? ? cout << "p" << cnt << " is recorded at " << p[cnt-1] << endl;
? ? }
? ? if(cnt==4) {
? ? ? ? ? ? cnt=0;
? ? ? ? ? ? //變換前圖像四個(gè)點(diǎn)
? ? ? ? ? ? vector<Point2f>src(4);
? ? ? ? ? ? src[0] = p[0];
? ? ? ? ? ? src[1] = p[1];
? ? ? ? ? ? src[2] = p[2];
? ? ? ? ? ? src[3] = p[3];
? ? ? ? ? ? //變換后
? ? ? ? ? ? vector<Point2f>dst(4);
? ? ? ? ? ? dst[0] = Point2f(0, 0);//左上
? ? ? ? ? ? dst[1] = Point2f(N, 0);//右上
? ? ? ? ? ? dst[2] = Point2f(0, M);//左下
? ? ? ? ? ? dst[3] = Point2f(N, M);//右下
? ? ? ? ? ? //獲取透視變換矩陣
? ? ? ? ? ? Mat m = getPerspectiveTransform(src, dst);
? ? ? ? ? ? Mat res;
? ? ? ? ? ??
? ? ? ? ? ? warpPerspective(img, res, m, Size(N, M),INTER_LINEAR);//實(shí)現(xiàn)圖像透視變換
? ? ? ? ? ? namedWindow("PIC2",1);
? ? ? ? ? ? imshow("PIC2", res);
? ? ? ? ? ? waitKey(0);
? ? ? ? } ? ?
}
int main() {
? ? img = imread("11.jpg");
? ? if(!img.data) {cout<<"read image file wrong!"<<endl; getchar(); return 0;}
? ? cout << "height = " << img.size().height << ",width = " << img.size().width << endl;
? ? getchar();
? ? namedWindow("PIC");
? ? imshow("PIC", img);
? ??
? ? setMouseCallback("PIC", mouse_callback);//設(shè)置鼠標(biāo)事件回調(diào)函數(shù)
? ??
? ? while(char(waitKey(1)) != 'q') {}
? ? return 0;
}以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++如何計(jì)算二進(jìn)制數(shù)中1的個(gè)數(shù)
這篇文章主要介紹了C++如何計(jì)算二進(jìn)制數(shù)中1的個(gè)數(shù),具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07
詳解C語言對字符串處理函數(shù)的實(shí)現(xiàn)方法
這篇文章主要為大家介紹了C語言對字符串處理函數(shù)的實(shí)現(xiàn)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2021-12-12
C++有限狀態(tài)機(jī)實(shí)現(xiàn)計(jì)算器小程序
這篇文章主要為大家詳細(xì)介紹了C++有限狀態(tài)機(jī)實(shí)現(xiàn)計(jì)算器小程序的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06
c++ 內(nèi)聯(lián)函數(shù)和普通函數(shù)的區(qū)別
內(nèi)聯(lián)函數(shù)是c++為了提高程序的運(yùn)行速度做的改進(jìn),那么內(nèi)聯(lián)函數(shù)和普通函數(shù)的區(qū)別是什么,本文就來詳細(xì)的介紹一下,感興趣的朋友可以了解一下2021-05-05

