opencv學習之路(10)、ROI與mask掩碼


一、ROI

 1 #include<opencv2/opencv.hpp>
 2 using namespace cv;
 3 
 4 void main(){
 5     Mat img=imread("E://0.jpg");
 6     Mat logo=imread("E://opencv.jpg");
 7     Mat ROI=img(Rect(20,20,logo.cols,logo.rows));//x,y,w,h    xy坐標,寬度,高度
 8     //Mat ROI=img(Range(20,20+logo.rows),Range(20,20+logo.cols));//縱坐標范圍,行坐標范圍
 9     logo.copyTo(ROI);//logo復制到ROI上面
10     
11     imshow("img",img);
12     waitKey(0);
13 }

低級融合

二、mask掩碼

圖像高級融合

 1 #include<opencv2/opencv.hpp>
 2 using namespace cv;
 3 
 4 void main(){
 5     Mat img=imread("E://0.jpg");
 6     Mat logo=imread("E://opencv.jpg");
 7     Mat mask=imread("E://opencv.jpg",0);//以灰度圖的形式讀入
 8     bitwise_not(mask, mask);//圖像取反,白色背景變黑
 9     imshow("mask",mask);
10     threshold(mask, mask, 50, 255, THRESH_BINARY);//二值化,50這個取值是經過調試后選擇的,若取值為100則左下角的標志會消失
11     imshow("threshold", mask);
12 
13     Mat ROI=img(Rect(20,20,logo.cols,logo.rows));//x,y,w,h    xy坐標,寬度,高度
14     logo.copyTo(ROI,mask);//logo復制到ROI上面
15     
16     imshow("img",img);
17     waitKey(0);
18 }

圖像加法

 1 #include<opencv2/opencv.hpp>
 2 using namespace cv;
 3 
 4 void main(){
 5     Mat img1=imread("E://3.jpg");
 6     Mat img2=imread("E://4.jpg");
 7     Mat mask=Mat::zeros(img1.size(),CV_8SC1);//純黑
 8     circle(mask,Point(mask.cols/2,mask.rows/2),100,Scalar(100),-1,8);
 9     Mat dst;
10     add(img1,img2,dst,mask);
11     imshow("result",dst);
12     waitKey(0);
13 }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM