% 确定目标(篮球)的横纵坐标,以及球的半径
function [cc,cr,radius,flag]=extractball(Imwork,Imback,fig1,fig2,fig3,fig5,index)
cc = 0;
cr = 0;
radius=0;
flag=0;
[MR,MC,Dim] = size(Imback);
% 与背景相减得到相素不同的点
fore = zeros(MR,MC);
fore = (abs(Imwork(:,:,1)-Imback(:,:,1)) > 10) ...
| (abs(Imwork(:,:,2) - Imback(:,:,2)) > 10) ...
| (abs(Imwork(:,:,3) - Imback(:,:,3)) > 10);
if fig5 > 0
figure(fig5)
clf
imshow(fore)
end
% 腐蚀除去噪声
foremm = bwmorph(fore,'erode',2);
if fig2 > 0
figure(fig2)
clf
imshow(foremm)
end
% 确定目标外框,得到面积
labeled = bwlabel(foremm,4);
stats = regionprops(labeled,['basic']);
[N,W] = size(stats);
if N < 1
return
end
% 用冒泡法(从大到小)排序
id = zeros(N);
for i = 1 : N
id(i) = i;
end
for i = 1 : N-1
for j = i+1 : N
if stats(i).Area < stats(j).Area
tmp = stats(i);
stats(i) = stats(j);
stats(j) = tmp;
tmp = id(i);
id(i) = id(j);
id(j) = tmp;
end
end
end
% 确定一个最大区域,即面积
if stats(1).Area < 100
return
end
selected = (labeled==id(1));
if fig3 > 0
figure(fig3)
clf
imshow(selected)
end
% 确定目标的质心和半径
centroid = stats(1).Centroid;
radius = sqrt(stats(1).Area/pi);
cc = centroid(1);
cr = centroid(2);
flag = 1;
return
薰衣草之夏龙
- 粉丝: 913
- 资源: 68
最新资源
- 微信自动抢红包APP.zip毕业设计参考学习资料
- 为 Wireshark 能使用纯真网络 IP 数据库(QQwry)而提供的格式转换工具.zip
- 音频格式转换工具.zip学习资料程序资源
- 自用固件,合并openwrt和immortalwrt编译AX6(刷机有风险).zip
- 最新GeoLite2-City.mmdb,GeoLite2-Country.mmdb打包下载
- 基于BootStrap + Springboot + FISCO-BCOS的二手物品交易市场系统.zip
- 使用Java语言编写的九格拼游戏,找寻下曾经小时候的记忆.zip
- gakataka课堂管理系统
- 一个简单ssh(spring springMVC hibernate)游戏网站,在网上找的html模板,没有自己写UI,重点放在java后端上.zip
- 一个采用MVC架构设计、Java实现的泡泡堂游戏.zip
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈