各位朋友,我想在一张图片里对不同部分进行分割,然后对不同部分上不同的颜色。
目前我找到一个颜色分割的算法,通过这个算法会有一个可以选取颜色的弹窗,如下图:
但在选取完后我关闭弹窗又会报错,出现下图:
之后就运行不下去了,麻烦大家帮我看看。
我用的代码如下:
%%B.彩色图像分割
f=imread('target_diee.jpg');
mask=roipoly(f);%手工选定图中红色区域
R=immultiply(mask,f(:,:,1));%取得选定区域图像的红色分量
G=immultiply(mask,f(:,:,2));%取得选定区域图像的绿色分量
B=immultiply(mask,f(:,:,3));%取得选定区域图像的蓝色分量
g=cat(3,R,G,B);%取得选定区域的RGB图像
figure,imshow(g);%显示取得选定区域
[M,N,K]=size(g);%选定区域的大小
I=reshape(g,M*N,3);%对g中的像素进行重排,按列序拉成一行
idx=find(mask);%找到mask中的像素在重排后的图像g中位置
I=double(I(idx,1:3));%转换到double类型
[C,m]=covmatrix(I);%计算协方差矩阵C主对角线上的元素,即方差
%>>sd=sqrt(d)%求得这些元素的平方根,即均方差
%%%用欧式距离对图像进行彩色分割,阈值为25
E25=colorseg('euclidean' ,f,25,m);
E251=f;
E251(E25==0)=0
figure,imshow(E251,[]);
%用马氏距离对图像进行彩色分割,阈值为25
M25=colorseg('mahalanobis' ,f,25,m,C);
figure,imshow(M25,[ ]);