% 确定目标(篮球)的横纵坐标,以及球的半径
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
MATLAB管家matlab674
- 粉丝: 1834
- 资源: 282
最新资源
- 法律援助工作站岗位职责.docx
- 法律援助工作站工作制度(值班登记、受理审查指派、重大、疑难案件讨论、案件质量检查、档案管理、例会制度).docx
- 返岗证明模板.docx
- 格力空调--通用网关可控型号列表.docx
- 公共生活秩序调查表.docx
- 公历农历年份对照表.docx
- 广告监管领域行风突出问题排查报告.docx
- 急救医学试卷.docx
- 教导处工作计划2024.docx
- 教学督导检查情况表.docx
- 教育实习评分细则.docx
- 考试工作人员选聘制度.docx
- 课件制作规范.docx
- 人文积淀与素质拓展测评标准表.docx
- 十二时辰当令对照表.docx
- 食堂日管控周排查月调度记录表.docx
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈