opencv實(shí)現(xiàn)圖像平移
本文實(shí)例為大家分享了opencv實(shí)現(xiàn)圖像平移的具體代碼,供大家參考,具體內(nèi)容如下
圖像平移指的是沿水平方向或垂直方向進(jìn)行圖像的移動(dòng)。
平移變換公式:

對(duì)于原始圖像而言,正變換矩陣:

對(duì)于目標(biāo)圖像而言,逆變換矩陣:

代碼:
#include<opencv2/imgproc.hpp>
#include<opencv2/highgui.hpp>
#include<opencv2/core.hpp>
#include<iostream>
#include<stdlib.h>
using namespace std;
using namespace cv;
?
Mat imgTranslation1(Mat& src, int xOffset, int yOffset);
Mat imgTranslation2(Mat& src, int xOffset, int yOffset);
int main()
{
?? ?Mat src = imread("C:\\Users\\H\\Desktop\\niao.bmp");
?? ?if (src.empty())
?? ?{
?? ??? ?cout << "請(qǐng)檢查圖像是否存在..." << endl;
?? ??? ?return -1;
?? ?}
?? ?pyrDown(src, src);
?? ?cout << "原圖尺寸\trows:" << src.rows << "\tcols: " << src.cols << endl;
?
?? ?int xOffset = 50, yOffset = 80;
?? ?
?? ?Mat dst1 = imgTranslation1(src, xOffset, yOffset);
?? ?imshow("dst1", dst1);
?? ?cout << "平移不改變尺寸\trows: " << dst1.rows << "\tcols: " << dst1.cols << endl;
?? ?
?? ?Mat dst2 = imgTranslation2(src, xOffset, yOffset);
?? ?imshow("dst2", dst2);
?? ?cout << "平移改變尺寸\trows: " << dst2.rows << "\tcols: " << dst2.cols << endl;
?? ?waitKey(0);
?? ?system("pause");
?? ?return 0;
}
?
圖像的平移 ,大小不變
Mat imgTranslation1(Mat& src, int xOffset, int yOffset)
{
?? ?int nrows = src.rows;
?? ?int ncols = src.cols;
?? ?Mat dst(src.size(), src.type());
?? ?for (int i = 0; i < nrows; i++)
?? ?{
?? ??? ?for (int j = 0; j < ncols; j++)
?? ??? ?{
?? ??? ??? ?映射變換
?? ??? ??? ?int x = j - xOffset;
?? ??? ??? ?int y = i - yOffset;
?? ??? ??? ?邊界判斷
?? ??? ??? ?if (x >= 0 && y >= 0 && x < ncols && y < nrows)
?? ??? ??? ?{
?? ??? ??? ??? ?dst.at<Vec3b>(i, j) = src.ptr<Vec3b>(y)[x];
?? ??? ??? ?}
?? ??? ?}
?? ?}
?? ?return dst;
}
//圖像平移大小改變
Mat imgTranslation2(Mat& src, int xOffset, int yOffset)
{
?? ?int nrows = src.rows + abs(yOffset);
?? ?int ncols = src.cols + abs(xOffset);
?? ?Mat dst(nrows, ncols, src.type());
?? ?for (int i = 0; i < nrows; i++)
?? ?{
?? ??? ?for (int j = 0; j < ncols; j++)
?? ??? ?{
?? ??? ??? ?int x = j - xOffset;
?? ??? ??? ?int y = i - yOffset;
?? ??? ??? ?if (x >= 0 && y >= 0 && x < ncols && y < nrows)
?? ??? ??? ?{
?? ??? ??? ??? ?dst.at<Vec3b>(i, j) = src.ptr<Vec3b>(y)[x];
?? ??? ??? ?}
?? ??? ?}
?? ?}
?? ?return dst;
}結(jié)果展示:

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
利用C++ R3層斷鏈實(shí)現(xiàn)模塊隱藏功能
在R3層的模塊隱藏,我們需要做的就是將其該鏈表斷鏈,將某一模塊從這個(gè)雙向鏈表中摘除,這樣再調(diào)用傳統(tǒng)的API時(shí)就會(huì)搜索不到。本文重點(diǎn)給大家介紹利用C++ R3層斷鏈實(shí)現(xiàn)模塊隱藏功能,感興趣的朋友一起看看吧2019-10-10
C++使用一棵紅黑樹(shù)同時(shí)封裝出map和set實(shí)例代碼
紅黑樹(shù)(Red?Black?Tre)是一種自平衡二叉查找樹(shù),是在計(jì)算機(jī)科學(xué)中用到的一種數(shù)據(jù)結(jié)構(gòu),典型的用途是實(shí)現(xiàn)關(guān)聯(lián)數(shù)組,下面這篇文章主要給大家介紹了關(guān)于C++使用一棵紅黑樹(shù)同時(shí)封裝出map和set的相關(guān)資料,需要的朋友可以參考下2023-04-04
關(guān)于C++使用std::chrono獲取當(dāng)前秒級(jí)/毫秒級(jí)/微秒級(jí)/納秒級(jí)時(shí)間戳問(wèn)題
這篇文章主要介紹了C++使用std::chrono獲取當(dāng)前秒級(jí)/毫秒級(jí)/微秒級(jí)/納秒級(jí)時(shí)間戳,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07
C++數(shù)據(jù)結(jié)構(gòu)鏈表基本操作示例過(guò)程
這篇文章主要為大家介紹了C++數(shù)據(jù)結(jié)構(gòu)鏈表基本操作的示例過(guò)程有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2021-11-11
C語(yǔ)言實(shí)現(xiàn)BMP圖像閉運(yùn)算處理
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)BMP圖像閉運(yùn)算處理,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10
vscode?采用C++17版本進(jìn)行編譯的實(shí)現(xiàn)
本文主要介紹了vscode?采用C++17版本進(jìn)行編譯,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01
C++機(jī)房預(yù)約系統(tǒng)實(shí)現(xiàn)流程實(shí)例
這篇文章主要介紹了C++機(jī)房預(yù)約系統(tǒng)實(shí)現(xiàn)流程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2022-10-10
C語(yǔ)言實(shí)現(xiàn)圖的鄰接矩陣存儲(chǔ)操作
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)圖的鄰接矩陣存儲(chǔ)操作,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-08-08

