ssdqsse 发表于 2007-7-23 22:49

怎样计算这水的高度?

这幅图是一个水缸的照片二值化后的结果,黑色部分是水,请问用什么matlab程序来计算水的高度???

[ 本帖最后由 ssdqsse 于 2007-7-23 22:57 编辑 ]

花如月 发表于 2007-7-24 14:30

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 编辑 ]

ssdqsse 发表于 2007-7-24 17:58

可以啦,谢谢你了....
页: [1]
查看完整版本: 怎样计算这水的高度?