OpenCV選擇圖像中矩形區(qū)域并保存
本文實例為大家分享了OpenCV選擇圖像中矩形區(qū)域并保存的具體代碼,供大家參考,具體內(nèi)容如下
根據(jù)《Learning OpenCV》中的example4.1改寫:
// An example program in which the // user can draw boxes on the screen. // //#include <cv.h> //#include <highgui.h> #include "opencv2/imgproc/imgproc.hpp" #include "opencv2/highgui/highgui.hpp" using namespace cv; // Define our callback which we will install for // mouse events. // void my_mouse_callback( int event, int x, int y, int flags, void* param ); CvRect box; bool drawing_box = false; bool isRectDrawn = false; // A litte subroutine to draw a box onto an image_copy void draw_box( IplImage* img, CvRect rect ) { cvRectangle ( img, cvPoint(box.x,box.y), cvPoint(box.x+box.width,box.y+box.height), cvScalar(0x00,0x00,0xff) /* blue */ ); } void draw_box_green( IplImage* img, CvRect rect ) { cvRectangle ( img, cvPoint(box.x,box.y), cvPoint(box.x+box.width,box.y+box.height), cvScalar(0x00,0xff,0x00) /* green */ ); } int main( int argc, char* argv[] ) { box = cvRect(-1,-1,0,0); IplImage* image_input = cvLoadImage(argv[1]); IplImage* image = cvCloneImage( image_input ); IplImage* image_copy = cvCloneImage( image ); IplImage* temp = cvCloneImage( image_copy ); cvNamedWindow( "Box Example" ); // Here is the crucial moment that we actually install // the callback. Note that we set the value ‘param' to // be the image_copy we are working with so that the callback // will have the image_copy to edit. // cvSetMouseCallback( "Box Example", my_mouse_callback, (void*) image_copy ); // The main program loop. Here we copy the working image_copy // to the ‘temp' image_copy, and if the user is drawing, then // put the currently contemplated box onto that temp image_copy. // display the temp image_copy, and wait 15ms for a keystroke, // then repeat… // while( 1 ) { //cvCopyImage( image_copy, temp ); cvCopy( image_copy, temp ); if( drawing_box ) draw_box( temp, box ); cvShowImage( "Box Example", temp ); //if( cvWaitKey( 15 )==27 ) break; int key = cvWaitKey( 15 ); if(key == 27) break; if(isRectDrawn){ if(key == 's' || key == 'S'){ // draw green box draw_box_green( image_copy, box ); cvCopy( image_copy, image ); // save roi image static int index = 0; char save_image_name[128]; sprintf(save_image_name, "rect_%d.jpg", index++); cvSetImageROI(image_input, box); cvSaveImage(save_image_name, image_input); cvResetImageROI(image_input); isRectDrawn = false; } if(key == 'q' || key == 'Q'){ cvCopy( image, image_copy ); isRectDrawn = false; } } } // Be tidy // cvReleaseImage( &image_copy ); cvReleaseImage( &temp ); cvDestroyWindow( "Box Example" ); } // This is our mouse callback. If the user // presses the left button, we start a box. // when the user releases that button, then we // add the box to the current image_copy. When the // mouse is dragged (with the button down) we // resize the box. // void my_mouse_callback( int event, int x, int y, int flags, void* param ) { IplImage* image_copy = (IplImage*) param; switch( event ) { case CV_EVENT_MOUSEMOVE: { if( drawing_box ) { box.width = x-box.x; box.height = y-box.y; } } break; case CV_EVENT_LBUTTONDOWN: { drawing_box = true; box = cvRect(x, y, 0, 0); } break; case CV_EVENT_LBUTTONUP: { drawing_box = false; isRectDrawn = true; if(box.width<0) { box.x+=box.width; box.width *=-1; } if(box.height<0) { box.y+=box.height; box.height*=-1; } draw_box(image_copy, box); } break; } }
使用方法:
載入圖像后,用鼠標(biāo)在圖像上點擊確定矩形起始點,拖動鼠標(biāo)畫矩形,抬起鼠標(biāo)鍵時會畫出一個紅色矩形區(qū)域。按下s或S鍵,紅色矩形變成綠色,并保存這個ROI區(qū)域。如果按下q或Q鍵,將會取消這次選擇,紅色矩形框消失??梢赃B續(xù)選取多個區(qū)域。按ESC鍵退出程序。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++產(chǎn)生隨機數(shù)的實現(xiàn)代碼
本篇文章是對C++中產(chǎn)生隨機數(shù)的實現(xiàn)代碼進行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05C++?MiniZip實現(xiàn)目錄壓縮與解壓的示例詳解
Zlib是一個開源的數(shù)據(jù)壓縮庫,提供了一種通用的數(shù)據(jù)壓縮和解壓縮算法,本文主要為大家詳細(xì)介紹了如何利用Zlib實現(xiàn)目錄壓縮與解壓,需要的小伙伴可以參考下2023-11-11Java C++ 題解leetcode857雇傭K名工人最低成本vector pair
這篇文章主要為大家介紹了Java C++ 題解leetcode857雇傭K名工人最低成本vector pair示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09華為云開發(fā)工具CodeArts IDE for C/C++開發(fā)使用指南
CodeArts IDE是一個集成開發(fā)環(huán)境(IDE),它提供了開發(fā)語言和調(diào)試服務(wù),本文主要介紹了華為云開發(fā)工具CodeArts IDE for C/C++ 開發(fā)使用指南,感興趣的可以了解一下2023-08-08