2016-04-07 10 views
-1
FDetect = vision.CascadeObjectDetector; 

%// Read the input image 

I = imread('face.jpg'); 

%// Returns Bounding Box values based on number of objects 
BB = step(FDetect,I); 

figure, 
imshow(I); 
hold on 
for i = 1:size(BB,1) 
    rectangle('Position',BB(i,:),'LineWidth',2.5,'LineStyle','','EdgeColor','r'); 
end 
title('Face Detection'); 
hold off; 

フィルタを与える:顔検出およびフィルタに

E = imerode(I,strel('square',5)); 

figure, imshow(E); 

私の問題は、長方形の顔領域でフィルタを与える方法です。

enter image description here

答えて

1

あなたはバウンディングボックス内にあるイメージの部分だけを抽出し、その後、ちょうどその部分にあなたのimerode操作を適用することになるでしょう。

境界ボックスの形式は[x、y、幅、高さ]です。これをピクセルに変換する必要があります。

%// Ensure that we are working with integers. 
BB(k,:) = round(BB(k,:)); 

%// Sample all rows and columns within this bounding box 
rows = BB(k,2):sum(BB(k,[2 4])) 
cols = BB(k,1):sum(BB(k,[1 3])) 

%// Apply the imerode operation on just these pixels 
I(rows,cols) = imerode(I(rows,cols), strel('square', 5));