改进版
矩阵中的循环操作非常耗时,so 用矩阵逻辑与操作替代for循环
one = ones(s_img(1), s_img(2));
segM = segM & uint8(one);
% for i=1:s_img(1)
% for j=1:s_img(2)
% if segM(i,j)==255
% segM(i,j)=1;
% end
% end
% end
****************这是一道分割线*******************
matlab的掩膜操作实现扣图
需要原图以及mask
im=imread([origin image path])
segM=imread([mask path])
s_img=size(im);
%%change the interested area to 1
for i=1:s_img(1)
for j=1:s_img(2)
if segM(i,j)==255
segM(i,j)=1;
end
end
end
%%deal with the R, G, B channels
R=im(:,:,1);
G=im(:,:,2);
B=im(:,:,3);
result(:,:,1)=R.*uint8(segM);
result(:,:,2)=G.*uint8(segM);
result(:,:,3)=B.*uint8(segM);
%%output the result
imwrite([output path]);
figure;
imshow(result);
下图是BSDS300数据集中的图片的运行结果
原图-mask-生成目标图像