SetImageROI
基于給定的矩形設置感興趣區域
void cvSetImageROI( IplImage* image,CvRect rect );
image
圖像頭.
rect
ROI 矩形.
函數 cvSetImageROI 基于給定的矩形設置圖像的 ROI(感興趣區域) .如果ROI是NULL 并且參數RECT的值不等于整個(gè)圖像,ROI被分配.不像 COI,大多數的 OpenCV 函數支持 ROI 并且處理它就像它是一個(gè)分離的圖像 (例如,所有的像素坐標從ROI的左上角或左下角(基于圖像的結構)計算.
只要將想分割的部分rect的位置和大小訂好就可以了.經(jīng)過(guò)上述函數處理之后image除rect之外的其他部分相當于沒(méi)有
SetImageROI基于給定的矩形設置感興趣區域 void cvSetImageROI( IplImage* image,CvRect rect );image 圖像頭.rect ROI 矩形.函數 cvSetImageROI 基于給定的矩形設置圖像的 ROI(感興趣區域) .如果ROI是NULL 并且參數RECT的值不等于整個(gè)圖像,ROI被分配.不像 COI,大多數的 OpenCV 函數支持 ROI 并且處理它就像它是一個(gè)分離的圖像 (例如,所有的像素坐標從ROI的左上角或左下角(基于圖像的結構)計算.只要將想分割的部分rect的位置和大小訂好就可以了.經(jīng)過(guò)上述函數處理之后image除rect之外的其他部分相當于沒(méi)有。
采用金字塔方法進(jìn)行圖像分割#include "cv.h"#include "highgui.h"#include IplImage* image[2] = { 0, 0 }, *image0 = 0, *image1 = 0;CvSize size;int w0, h0,i;int threshold1, threshold2;int l,level = 4;int sthreshold1, sthreshold2;int l_comp;int block_size = 1000;float parameter;double threshold;double rezult, min_rezult;CvFilter filter = CV_GAUSSIAN_5x5;CvConnectedComp *cur_comp, min_comp;CvSeq *comp;CvMemStorage *storage;CvPoint pt1, pt2;void ON_SEGMENT(int a){ cvPyrSegmentation(image0, image1, storage, &comp, level, threshold1+1, threshold2+1); /*l_comp = comp->total; i = 0; min_comp.value = cvScalarAll(0); while(i fabs(255- cur_comp->value.val[0]) && fabs(min_comp.value.val[1])> fabs(cur_comp->value.val[1]) && fabs(min_comp.value.val[2])> fabs(cur_comp->value.val[2]) ) min_comp = *cur_comp; i++; }*/ cvShowImage("Segmentation", image1);}int main( int argc, char** argv ){ char* filename = argc == 2 ? argv[1] : (char*)"fruits.jpg"; if( (image[0] = cvLoadImage( filename, 1)) == 0 ) return -1; cvNamedWindow("Source", 0); cvShowImage("Source", image[0]); cvNamedWindow("Segmentation", 0); storage = cvCreateMemStorage ( block_size ); image[0]->width &= -(1height &= -(1 評論0 0 0。
定點(diǎn)做分割?我知道的有定區域做分割。比如用構造函數:
Mat image = read(path, 0);
Mat roi(image, Rect(x, y, width, height));
這表示Rect(x, y, width, height)內的圖片被“分割”到了roi中,注意,Mat格式中,一般除了明顯的copy,其他都只是改變指針,所以image沒(méi)有變化。這點(diǎn)要注意,之所以這樣是為了省空間和時(shí)間,畢竟圖片處理很耗時(shí)。
SetImageROI基于給定的矩形設置感興趣區域 void cvSetImageROI( IplImage* image, CvRect rect );image 圖像頭. rect ROI 矩形. 函數 cvSetImageROI 基于給定的矩形設置圖像的 ROI(感興趣區域) . 如果ROI是NULL 并且參數RECT的值不等于整個(gè)圖像, ROI被分配. 不像 COI, 大多數的 OpenCV 函數支持 ROI 并且處理它就像它是一個(gè)分離的圖像 (例如, 所有的像素坐標從ROI的左上角或左下角(基于圖像的結構)計算。
只要將想分割的部分rect的位置和大小訂好就可以了。經(jīng)過(guò)上述函數處理之后image除rect之外的其他部分相當于沒(méi)有。
顏色直方圖是在許多圖像檢索系統中被廣泛采用的顏色特征。
它所描述的是不同色彩在整幅圖像中所占的比例,而并不關(guān)心每種色彩所處的空間位置,即無(wú)法描述圖像中的對象或物體。顏色直方圖特別適于描述那些難以進(jìn)行自動(dòng)分割的圖像。
OpenCV對顏色直方圖進(jìn)行統計的代碼如下所示,在圖像檢索,鏡頭分割等領(lǐng)域使用的還是比較多的。#include #include #include using namespace std; int main( int argc, char** argv ) { IplImage * src= cvLoadImage("F:\\test3.jpg"); IplImage* hsv = cvCreateImage( cvGetSize(src), 8, 3 ); IplImage* h_plane = cvCreateImage( cvGetSize(src), 8, 1 ); IplImage* s_plane = cvCreateImage( cvGetSize(src), 8, 1 ); IplImage* v_plane = cvCreateImage( cvGetSize(src), 8, 1 ); IplImage* planes[] = { h_plane, s_plane }; /** H 分量劃分為16個(gè)等級,S分量劃分為8個(gè)等級 */ int h_bins = 16, s_bins = 8; int hist_size[] = {h_bins, s_bins}; /** H 分量的變化范圍 */ float h_ranges[] = { 0, 180 }; /** S 分量的變化范圍*/ float s_ranges[] = { 0, 255 }; float* ranges[] = { h_ranges, s_ranges }; /** 輸入圖像轉換到HSV顏色空間 */ cvCvtColor( src, hsv, CV_BGR2HSV ); cvCvtPixToPlane( hsv, h_plane, s_plane, v_plane, 0 ); /** 創(chuàng )建直方圖,二維, 每個(gè)維度上均分 */ CvHistogram * hist = cvCreateHist( 2, hist_size, CV_HIST_ARRAY, ranges, 1 ); /** 根據H,S兩個(gè)平面數據統計直方圖 */ cvCalcHist( planes, hist, 0, 0 ); /** 獲取直方圖統計的最大值,用于動(dòng)態(tài)顯示直方圖 */ float max_value; cvGetMinMaxHistValue( hist, 0, &max_value, 0, 0 ); /** 設置直方圖顯示圖像 */ int height = 240; int width = (h_bins*s_bins*6); IplImage* hist_img = cvCreateImage( cvSize(width,height), 8, 3 ); cvZero( hist_img ); /** 用來(lái)進(jìn)行HSV到RGB顏色轉換的臨時(shí)單位圖像 */ IplImage * hsv_color = cvCreateImage(cvSize(1,1),8,3); IplImage * rgb_color = cvCreateImage(cvSize(1,1),8,3); int bin_w = width / (h_bins * s_bins); for(int h = 0; h < h_bins; h++) { for(int s = 0; s < s_bins; s++) { int i = h*s_bins + s; /** 獲得直方圖中的統計次數,計算顯示在圖像中的高度 */ float bin_val = cvQueryHistValue_2D( hist, h, s ); int intensity = cvRound(bin_val*height/max_value); /** 獲得當前直方圖代表的顏色,轉換成RGB用于繪制 */ cvSet2D(hsv_color,0,0,cvScalar(h*180.f / h_bins,s*255.f/s_bins,255,0)); cvCvtColor(hsv_color,rgb_color,CV_HSV2BGR); CvScalar color = cvGet2D(rgb_color,0,0); cvRectangle( hist_img, cvPoint(i*bin_w,height), cvPoint((i+1)*bin_w,height - intensity), color, -1, 8, 0 ); } } cvNamedWindow( "Source", 1 ); cvShowImage( "Source", src ); cvNamedWindow( "H-S Histogram", 1 ); cvShowImage( "H-S Histogram", hist_img ); cvWaitKey(0); }。
聲明:本網(wǎng)站尊重并保護知識產(chǎn)權,根據《信息網(wǎng)絡(luò )傳播權保護條例》,如果我們轉載的作品侵犯了您的權利,請在一個(gè)月內通知我們,我們會(huì )及時(shí)刪除。
蜀ICP備2020033479號-4 Copyright ? 2016 學(xué)習?shū)B(niǎo). 頁(yè)面生成時(shí)間:3.665秒