问题描述:
详见我的博文: 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('提取后的图');