OpenCV iOS 中的漫水填充(12)

2021-09-11 14:28:49 字數 2991 閱讀 8759

漫水填充的定義

漫水填充是一種用特定的顏色填充連通區域,通過設定可連通畫素的上下限以及連通方式達到不同的填充效果的方法。漫水填充經常用來標記或者是分離影象的一部分,以便對其進行進一步處理貨分析,也可以用來從輸入影象獲取掩碼區域,掩碼會加速處理過程,或者只處理指定的畫素點,操作的結果總是某個連續的區域。

實現漫水填充演算法:floodfill函式

foodfill函式有兩個版本,乙個不帶掩碼的mask的版本,乙個是帶有mask的版本

第乙個版本

floodfill( inputoutputarray image,

point seedpoint, 

scalar newval, 

cv_out rect* rect = 0,

scalar lodiff = scalar(), 

scalar updiff = scalar(),

int flags = 4 

第二個版本

floodfill( inputoutputarray image, 

inputoutputarray mask,

point seedpoint,

scalar newval,

cv_out rect* rect=0,

scalar lodiff = scalar(),

scalar updiff = scalar(),

int flags = 4 

第乙個引數,inputoutputarray型別的image, 輸入/輸出1通道或3通道,8位或浮點影象,具體引數由之後的引數具體指明。

第二個引數, inputoutputarray型別的mask,這是第二個版本的floodfill獨享的引數,表示操作掩模,。它應該為單通道、8位、長和寬上都比輸入影象 image 大兩個畫素點的影象。第二個版本的floodfill需要使用以及更新掩膜,所以這個mask引數我們一定要將其準備好並填在此處。需要注意的是,漫水填充不會填充掩膜mask的非零畫素區域。例如,乙個邊緣檢測運算元的輸出可以用來作為掩膜,以防止填充到邊緣。同樣的,也可以在多次的函式呼叫中使用同乙個掩膜,以保證填充的區域不會重疊。另外需要注意的是,掩膜mask會比需填充的影象大,所以 mask 中與輸入影象(x,y)畫素點相對應的點的座標為(x+1,y+1)。

第三個引數,point型別的seedpoint,漫水填充演算法的起始點。

第四個引數,scalar型別的newval,畫素點被染色的值,即在重繪區域畫素的新值。

第五個引數,rect*型別的rect,有預設值0,乙個可選的引數,用於設定floodfill函式將要重繪區域的最小邊界矩形區域。

第六個引數,scalar型別的lodiff,有預設值scalar( ),表示當前觀察畫素值與其部件鄰域畫素值或者待加入該部件的種子畫素之間的亮度或顏色之負差(lower brightness/color difference)的最大值。

第七個引數,scalar型別的updiff,有預設值scalar( ),表示當前觀察畫素值與其部件鄰域畫素值或者待加入該部件的種子畫素之間的亮度或顏色之正差(lower brightness/color difference)的最大值。

第八個引數,int型別的flags,操作標誌符,此引數包含三個部分,比較複雜,我們一起詳細看看。

低八位(第0~7位)用於控制演算法的連通性,可取4 (4為預設值) 或者 8。如果設為4,表示填充演算法只考慮當前畫素水平方向和垂直方向的相鄰點;如果設為 8,除上述相鄰點外,還會包含對角線方向的相鄰點。

高八位部分(16~23位)可以為0 或者如下兩種選項識別符號的組合:

floodfill_fixed_range- 如果設定為這個識別符號的話,就會考慮當前畫素與種子畫素之間的差,否則就考慮當前畫素與其相鄰畫素的差。也就是說,這個範圍是浮動的。

floodfill_mask_only- 如果設定為這個識別符號的話,函式不會去填充改變原始影象 (也就是忽略第三個引數newval), 而是去填充掩模影象(mask)。這個識別符號只對第二個版本的floodfill有用,因第乙個版本裡面壓根就沒有mask引數。

中間八位部分,上面關於高八位floodfill_mask_only識別符號中已經說的很明顯,需要輸入符合要求的掩碼。floodfill的flags引數的中間八位的值就是用於指定填充掩碼影象的值的。但如果flags中間八位的值為0,則掩碼會用1來填充。

而所有flags可以用or操作符連線起來,即「|」。例如,如果想用8鄰域填充,並填充固定畫素值範圍,填充掩碼而不是填充源影象,以及設填充值為38,那麼輸入的引數是這樣:

flags=8 | floodfill_mask_only | floodfill_fixed_range | (38<<8)

**實現:

cvtcolor(im, dst, cv_bgra2bgr,3);// 將拿到的轉換為我們能夠使用的,使用floodfill必須是1通道或者是三通道的,這個函式的使用方法參照opencv中顏色空間轉換cvtcolor()

cv::rect ccomp;

cv::floodfill(dst, cv::point(100,100), scalar(50,0,150),&ccomp,scalar(20,20,20),scalar(20,20,20));

self.secondimageview.image = mattouiimage(dst);

實現效果

漫水填充演算法

所謂漫水填充演算法,是給定乙個聯通域內的乙個點,以此為起點找到這個聯通域的其餘所有點並將其填充為指定顏色的一種演算法。之所以稱之為漫水填充,是因為這種演算法就是模擬了漲水的過程,從一點開始,水流慢慢加大,直到漫過了全部區域。這個演算法的詳細介紹可以參考下面的鏈結。這個演算法在我們尋找一片指定區域時非...

漫水填充演算法

漫水填充演算法是填充演算法中最通用的演算法。所謂漫水填充 演算法,是給定乙個聯通域內的乙個點,以此為起點找到這個聯通域的其餘所有點並將其填充為指定顏色的一種演算法。之所以稱之為漫水填充,是因為這種演算法就是模擬了漲水的過程,從一點開始,水流慢慢加大,直到漫過了全部區域。該填充演算法的原型如下所示 v...

opencv 漫水填充

一 話說漫水填充 漫水填充是一種用特定的顏色填充連通區域,通過設定可連通畫素的上下限以及連通方式達到不同的填充效果的方法。漫水填充經常用來標記或者是分離影象的一部分,以便對其進行進一步處理貨分析,也可以用來從輸入影象獲取掩碼區域,掩碼會加速處理過程,或者只處理指定的畫素點,操作的結果總是某個連續的區...