Matlab图像处理-RGB色彩提取原理方法

时间:2024-10-12 02:02:40

1、打开图像[FileName, FilePath]=uigetfile('*.jpg;*.png;*.tif;*.img;*.gif;','请选择图像数据');str=[FilePath FileName];Image=imread(str);% 以对话框的形式选择打开一幅图像

2、设置参数Gray=rgb2gray(Image);R=Image(:,:,1); G=Image(:,:,2); B=Image(:,:,3);diff_R=0; diff_G=0; diff_B=0; % 设置红、绿、蓝三种颜色提取阈值(越大越严格)

3、红色提取Image_R=Image;RP_R=Image(:,:,1); RP_G=Image(:,:,2); RP_B=Image(:,:,3);XYR=~((伊怕锱鳏R-G)>diff_R&(R-B)>diff_R); % 提取红色条件是R分量与G、B分量差值大于设定Mask=Gray(XYR); % 灰照片掩膜RP_R(XYR)=Mask; RP_G(XYR)=Mask; RP_B(XYR)=Mask; % 使得非红色区域变为灰色Image_R(:,:,1)=RP_R; Image_R(:,:,2)=RP_G; Image_R(:,:,3)=RP_B;

4、绿色提取Image_G=Image;GP_R=Image(:,:,1); GP_G=Image(:,:,2)稆糨孝汶; GP_B=Image(:,:,3);XYG=~((G-R)>diff_G&(G-B)>diff_G); % 提取绿色条件是G分量与R、B分量差值大于设定Mask=Gray(XYG);% 灰照片掩膜GP_R(XYG)=Mask; GP_G(XYG)=Mask; GP_B(XYG)=Mask;% 使得非绿色区域变为灰色Image_G(:,:,1)=GP_R; Image_G(:,:,2)=GP_G; Image_G(:,:,3)=GP_B;

5、蓝色提取Image_B=Image;BP_R=Image(:巳呀屋饔,:,1);BP_G=Image(:,:,2);BP_B=Image(:,:,3);XYB=~((B-R)>diff_B媪青怍牙&(B-G)>diff_B); % 提取绿色条件是G分量与R、B分量差值大于设定Mask_B=Gray(XYB); % 灰照片掩膜BP_R(XYB)=Mask_B; BP_G(XYB)=Mask_B; BP_B(XYB)=Mask_B; % 使得非蓝色区域变为灰色Image_B(:,:,1)=BP_R; Image_B(:,:,2)=BP_G; Image_B(:,:,3)=BP_B;

6、显示结果subplot(2,2,1),imshow(Image); title('Image');subplot(2,2,2),imshow(Image_R); title('Red Pass');subplot(2,2,3),imshow(Image_G); title('Green Pass');subplot(2,2,4),imshow(Image_B); title('Blue Pass');% 显示原图与R/G/B三色提取结果对比图并显示标签

Matlab图像处理-RGB色彩提取原理方法

7、保存结果imwrite(Image_R,'Image_R.jpg','jpeg');imwrite(Image_G,'Image_G.jpg','jpeg');imwrite(Image_B,'Image_B.jpg','jpeg');% 将R/G/B三色提取结果写成jpg文件保存到当前目录

© 手抄报圈