clear;
Hi=100;%定义杯子高度
I=imread('cup.bmp');
I=im2bw(I,0.5);
I(1:20,:)=[]; %去除边缘效应
I((end-20):end,:)=[];
I(:,1:20)=[];
I(:,(end-20):end)=[];
I(:,~sum(abs(~I),1))=[];%删除图像中全1的列
I(~sum(abs(~I),2),:)=[];%删除图像中全1的行
H=size(I);
J=I;
a=find(mean(I,2)>0.5);
J(a,:)=1;
J(~sum(abs(~J),2),:)=[];%删除图像中全1的行
H1=size(J);
result=fix(Hi*H1(1)/H(1));
sprintf('杯子里水的高度为:\n%u',result)
subplot(121),imshow(I),title('杯子');
subplot(122),imshow(J),title('水');
ans =
杯子里水的高度为:
48
这个程序主要针对你的附图,如果图没有黑边,去边缘的4行可以不要。
在边缘小的情况下,可能会产生误差。要根据实际情况稍作修改。
[ 本帖最后由 花如月 于 2007-7-24 14:46 编辑 ] |