失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > 【笔记】Opencv 实现拼图板小游戏

【笔记】Opencv 实现拼图板小游戏

时间:2020-10-18 12:26:08

相关推荐

【笔记】Opencv 实现拼图板小游戏

for(int i=0;i<rows;i++){for(int j=0;j<cols;j++){Mat SourceRoi=Sourceimage(Rect(j*Roicols,i*Roirows,Roicols-1,Roirows-1));arraryimage.push_back(SourceRoi);}}

//*******************************************************************////随机调换所有的子图像序列的位置,用于在 Splite image中显示//*******************************************************************//void Randarrary( vector<Mat>& vectorMat){for(int i=0;i<vectorMat.size();i++){srand(int(time(0)));int a=rand()%(vectorMat.size()-i)+i;swap(vectorMat[i],vectorMat[a]);}}

//*******************************************************************////鼠标回调函数,用于获取需要查找的子图像在原图像中的位置,并在叠加显示在目标图像中//*******************************************************************//void OnMouseAction(int event,int x,int y,int flags,void *ustc){if(event==CV_EVENT_LBUTTONDOWN){Mat RoiSpilte,RoiSource;int rows=(y/Roirows)*Roirows;int clos=(x/Roicols)*Roicols;RoiSpilte=Spilteimage(Rect(clos,rows,Roicols,Roirows));imshow("Slice",RoiSpilte);Mat image=Mat::zeros(Sourceimage.rows-Roirows,Sourceimage.cols-Roicols,CV_32FC1);matchTemplate(Sourceimage,RoiSpilte,image,1);normalize(image,image,0,1,NORM_MINMAX);double minV=0;double maxV=0;Point minP,maxP;minMaxLoc(image,&minV,&maxV,&minP,&maxP);//Mat ROIS=Sourceimage(Rect(maxP.x,maxP.y,Roicols,Roirows));Mat ROIDst=Dstimage(Rect(minP.x,minP.y,Roicols,Roirows));addWeighted(ROIDst,0,RoiSpilte,1,0,ROIDst,-1);imshow("Jigsaw image",Dstimage);}

#include "core/core.hpp"#include "highgui/highgui.hpp"#include "imgproc/imgproc.hpp"#include <time.h>using namespace cv;Mat Sourceimage,Spilteimage,Rebuildimage,Dstimage;int rows,cols;int Roirows,Roicols;vector<Mat>arraryimage;void Randarrary( vector<Mat> &vectorMat); //随机排列子图像序列函数static int vectornumber=0;void OnMouseAction(int event,int x,int y,int flags,void *ustc); //鼠标回调事件函数int main(int argc,char*argv[]){Sourceimage=imread(argv[1]);imshow("Source image",Sourceimage);rows=atoi(argv[2]);cols=atoi(argv[3]);Roirows=Sourceimage.rows/rows;Roicols=Sourceimage.cols/cols;Spilteimage=Mat::zeros(Sourceimage.rows,Sourceimage.cols,Sourceimage.type());Dstimage=Mat::zeros(Sourceimage.rows,Sourceimage.cols,Sourceimage.type());for(int i=0;i<rows;i++){for(int j=0;j<cols;j++){Mat SourceRoi=Sourceimage(Rect(j*Roicols,i*Roirows,Roicols-1,Roirows-1));arraryimage.push_back(SourceRoi);}}// 随机函数Randarrary( arraryimage);for(int i=0;i<rows;i++){for(int j=0;j<cols;j++){Mat SpilterRoi=Spilteimage(Rect(j*Roicols,i*Roirows,Roicols-1,Roirows-1));addWeighted(SpilterRoi,0,arraryimage[vectornumber],1,0,SpilterRoi);vectornumber++;imshow("Splite image",Spilteimage);waitKey(150);}}setMouseCallback("Splite image",OnMouseAction);waitKey();}//*******************************************************************////随机调换所有的子图像序列的位置,用于在 Splite image中显示//*******************************************************************//void Randarrary( vector<Mat>& vectorMat){for(int i=0;i<vectorMat.size();i++){srand(int(time(0)));int a=rand()%(vectorMat.size()-i)+i;swap(vectorMat[i],vectorMat[a]);}}//*******************************************************************////鼠标回调函数,用于获取需要查找的子图像在原图像中的位置,并在叠加显示在目标图像中//*******************************************************************//void OnMouseAction(int event,int x,int y,int flags,void *ustc){if(event==CV_EVENT_LBUTTONDOWN){Mat RoiSpilte,RoiSource;int rows=(y/Roirows)*Roirows;int clos=(x/Roicols)*Roicols;RoiSpilte=Spilteimage(Rect(clos,rows,Roicols,Roirows));imshow("Slice",RoiSpilte);Mat image=Mat::zeros(Sourceimage.rows-Roirows,Sourceimage.cols-Roicols,CV_32FC1);matchTemplate(Sourceimage,RoiSpilte,image,1);normalize(image,image,0,1,NORM_MINMAX);double minV=0;double maxV=0;Point minP,maxP;minMaxLoc(image,&minV,&maxV,&minP,&maxP);Mat ROIDst=Dstimage(Rect(minP.x,minP.y,Roicols,Roirows));addWeighted(ROIDst,0,RoiSpilte,1,0,ROIDst,-1);imshow("Jigsaw image",Dstimage);}}

如果觉得《【笔记】Opencv 实现拼图板小游戏》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。