-4
%%skin detection
[hue,s,v]=rgb2hsv(I);
cb = 0.148* I(:,:,1) - 0.291* I(:,:,2) + 0.439 * I(:,:,3) + 128;
cr = 0.439 * I(:,:,1) - 0.368 * I(:,:,2) -0.071 * I(:,:,3) + 128;
[w h]=size(I(:,:,1));
for i=1:w
for j=1:h
if 128<=cr(i,j) && cr(i,j)<=165 && 140<=cb(i,j) && cb(i,j)<=195 && 0.01<=hue(i,j) && hue(i,j)<=0.1
segment(i,j)=1;
else
segment(i,j)=0;
end
end
end
im(:,:,1)=I(:,:,1).*segment;
im(:,:,2)=I(:,:,2).*segment;
im(:,:,3)=I(:,:,3).*segment;
%imshow(uint8(im));
title('My Edge Detection')
im1 = imclearborder(im2bw(im));
figure
imshow(im1)
im_fill = imfill(im1, 'holes');
figure
imshow(im_fill)
s = regionprops(im_fill, 'Area', 'PixelList');
[~,ind] = max([s.Area]);
pix = sub2ind(size(im), s(ind).PixelList(:,2), s(ind).PixelList(:,1));
out = zeros(size(im));
out(pix) = im(pix);
imshow(out);
這裏減去臉部後,找出最大的連接區域。 我想從原始圖像裁剪該區域。使用Matlab手部檢測
請擴大您的問題的更多信息和/或在您的代碼中添加評論,以便我們能夠更好地爲您提供幫助。 –
@BrianLynch 在通過中提琴瓊斯減去臉部之後的第一部分中,然後我轉換爲Hue以找出膚色,然後找出二值圖像(手)中最大的連接區域。 現在我怎樣才能從原始輸入圖像裁剪連接區域區域。 –
您是否問如何拍攝原始圖像並將連接區域中的所有_not_像素都變成黑色? –