問題描述:
詳見我的博文: https://blog.csdn.net/wuli_dear_wang/article/details/88370186
方法二:
代碼如下:
clear,clc,close all;
a=imread('a.jpg');
b=imread('b.jpg');
a1=~a; %a圖取反
a2=a1.*255; %取反後與255相乘,背景變成白色(255),蝴蝶變成黑色(0)
a3=uint8(a2); %a2爲double,強制轉化爲uint8類型
R=b(:,:,1); %提取三個通道
G=b(:,:,2);
B=b(:,:,3);
R1=imsubtract(R,a3); %與a3相減。小於0的歸爲0,大於255的歸爲255。中間蝴蝶部分因爲減去的是0,所以不變
G1=imsubtract(G,a3);
B1=imsubtract(B,a3);
b1(:,:,1)=R1; %三個通道疊加,組成一個三維的RGB圖
b1(:,:,2)=G1;
b1(:,:,3)=B1;
subplot(221),imshow(a),title('灰度圖');
subplot(222),imshow(b),title('彩色原圖');
subplot(223),imshow(b1),title('提取後的圖');