OpenCV (iOS)中的形態(tài)學(xué)變換(11)

形態(tài)學(xué)的高級形態(tài)往往是建立在腐蝕和膨脹這兩個(gè)基本操作之上,關(guān)于腐蝕和膨脹請參考OpenCV中的腐蝕和膨脹(9)

使用OpenCV中函數(shù)morphologyEx進(jìn)行形態(tài)學(xué)操作

(1)開運(yùn)算 (Opening)

(2)閉運(yùn)算 (Closing)

(3)形態(tài)梯度 (Morphological Gradient)

(4)頂帽 (Top Hat)

(5)黑帽(Black Hat)

開運(yùn)算(Opening)

開運(yùn)算是通過先對圖像腐蝕再膨脹實(shí)現(xiàn)的

能夠排除小團(tuán)塊的物體(假設(shè)物體背景明亮)

閉運(yùn)算(Closing)

閉運(yùn)算是通過先對圖像膨脹后再腐蝕實(shí)現(xiàn)的

能夠排除小型黑洞(黑色區(qū)域)

形態(tài)梯度(Morphological Gradient)

膨脹圖與腐蝕圖只差

頂帽(Top Hat)

原圖像與開運(yùn)算結(jié)果的圖只差

黑帽(Black Hat)

閉運(yùn)算結(jié)果圖與原圖像只差

函數(shù)morphologyEx參數(shù)介紹

void morphologyEx( InputArray src,// 預(yù)處理圖像

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?OutputArray dst,// 處理結(jié)果圖像

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? int op,// 需要運(yùn)行的形態(tài)學(xué)操作

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? InputArray kernel,? ? ? ? ? ? ? ? ??

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? Point anchor = Point(-1,-1),

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? int iterations =1,

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? int borderType = BORDER_CONSTANT,

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?const Scalar& borderValue = morphologyDefaultBorderValue()

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? );

op 有六種形式 (2--6)

Opening:MORPH_OPEN: 2 // 開運(yùn)算

Closing:MORPH_CLOSE: 3 // 閉運(yùn)算

Gradient:MORPH_GRADIENT: 4 // 形態(tài)梯度

Top Hat:MORPH_TOPHAT: 5 // 頂帽

Black Hat:MORPH_BLACKHAT: 6 // 黑帽

代碼

- (void)initMat {

self.img = [UIImage imageNamed:@"123.png"];

UIImageToMat(_img, m_src);

[self morphologyEx];

}

- (void)createImageView {

CGFloat h = self.view.frame.size.width * 2 / 3;

self.imgView1 = [[UIImageView alloc] initWithFrame:CGRectMake(0, 20, self.view.frame.size.width, h)];

[self.view addSubview:_imgView1];

_imgView1.backgroundColor = [UIColor lightGrayColor];

_imgView1.image = _img;

self.imgView2 = [[UIImageView alloc] initWithFrame:CGRectMake(0, CGRectGetMaxY(_imgView1.frame) + 5, self.view.frame.size.width, h)];

[self.view addSubview:_imgView2];

_imgView2.backgroundColor = [UIColor lightGrayColor];

_imgView2.image = _img;

}

- (void)createSlider {

NSArray *tempArr = @[@"Operator :", @"Element :", @"Kernel Size :"];

CGFloat w = self.view.frame.size.width - 100;

CGFloat y = self.view.frame.size.height - 50;

for (NSInteger i = 0; i < 3; i++) {

UISlider *slider = [[UISlider alloc] initWithFrame:CGRectMake(90,? y - 45 * i, w, 40)];

[self.view addSubview:slider];

[slider addTarget:self action:@selector(valueChanged:)

forControlEvents:UIControlEventValueChanged];

[self sliderMumValueWith:i slider:slider];

slider.tag = 1000 + i;

UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(10, y - 45 * i, 80, 40)];

label.textAlignment = NSTextAlignmentRight;

[self.view addSubview:label];

label.font = [UIFont systemFontOfSize:10];

label.text = tempArr[i];

}

}

- (void)sliderMumValueWith:(NSInteger)i slider:(UISlider *)slider {

switch (i) {

case 0: {

slider.continuous = YES; // NO makes it call only once you let go

slider.minimumValue = 2;

slider.maximumValue = 6;

} break;

case 1: {

slider.continuous = YES; // NO makes it call only once you let go

slider.minimumValue = 0;

slider.maximumValue = 2;

} break;

case 2: {

slider.continuous = YES; // NO makes it call only once you let go

slider.minimumValue = 0;

slider.maximumValue = 21;

} break;

}

}

- (void)morphologyEx {

// 由于 MORPH_X的取值范圍是: 2,3,4,5 和 6

Mat element = getStructuringElement(morph_elem, cv::Size(2 * morph_size + 1, 2 * morph_size + 1), cv::Point(morph_size, morph_size));

/// 運(yùn)行指定形態(tài)學(xué)操作

morphologyEx(m_src, m_dst, morph_operator, element);

_imgView2.image = MatToUIImage(m_dst);//morph_operator

}


創(chuàng)建公共變量

Mat m_src, m_dst;

int morph_elem = 0;

int morph_size = 0;

int morph_operator = 0;

調(diào)用

[self initMat];

[self createSlider];

[self createImageView];

參考資料

OpenCV for iOS 學(xué)習(xí)筆記(十)—— 形態(tài)學(xué)變換

更多形態(tài)學(xué)變換

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末厚满,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子署拟,更是在濱河造成了極大的恐慌项玛,老刑警劉巖摧玫,帶你破解...
    沈念sama閱讀 218,941評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件剩膘,死亡現(xiàn)場離奇詭異衅斩,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)怠褐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評論 3 395
  • 文/潘曉璐 我一進(jìn)店門矛渴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人惫搏,你說我怎么就攤上這事具温。” “怎么了筐赔?”我有些...
    開封第一講書人閱讀 165,345評論 0 356
  • 文/不壞的土叔 我叫張陵铣猩,是天一觀的道長。 經(jīng)常有香客問我茴丰,道長达皿,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,851評論 1 295
  • 正文 為了忘掉前任贿肩,我火速辦了婚禮峦椰,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘汰规。我一直安慰自己汤功,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,868評論 6 392
  • 文/花漫 我一把揭開白布溜哮。 她就那樣靜靜地躺著滔金,像睡著了一般。 火紅的嫁衣襯著肌膚如雪茂嗓。 梳的紋絲不亂的頭發(fā)上餐茵,一...
    開封第一講書人閱讀 51,688評論 1 305
  • 那天,我揣著相機(jī)與錄音述吸,去河邊找鬼忿族。 笑死,一個(gè)胖子當(dāng)著我的面吹牛蝌矛,可吹牛的內(nèi)容都是我干的道批。 我是一名探鬼主播,決...
    沈念sama閱讀 40,414評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼朴读,長吁一口氣:“原來是場噩夢啊……” “哼屹徘!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起衅金,我...
    開封第一講書人閱讀 39,319評論 0 276
  • 序言:老撾萬榮一對情侶失蹤噪伊,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后氮唯,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體鉴吹,經(jīng)...
    沈念sama閱讀 45,775評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年惩琉,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了豆励。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,096評論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖良蒸,靈堂內(nèi)的尸體忽然破棺而出技扼,到底是詐尸還是另有隱情,我是刑警寧澤嫩痰,帶...
    沈念sama閱讀 35,789評論 5 346
  • 正文 年R本政府宣布剿吻,位于F島的核電站,受9級特大地震影響串纺,放射性物質(zhì)發(fā)生泄漏丽旅。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,437評論 3 331
  • 文/蒙蒙 一纺棺、第九天 我趴在偏房一處隱蔽的房頂上張望榄笙。 院中可真熱鬧,春花似錦祷蝌、人聲如沸茅撞。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽乡翅。三九已至,卻和暖如春罪郊,著一層夾襖步出監(jiān)牢的瞬間蠕蚜,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評論 1 271
  • 我被黑心中介騙來泰國打工悔橄, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留靶累,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,308評論 3 372
  • 正文 我出身青樓癣疟,卻偏偏與公主長得像挣柬,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子睛挚,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,037評論 2 355

推薦閱讀更多精彩內(nèi)容