网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
2)将链码加4反向再减1,并以此链码为起点对邻域进行搜索
3)获得下一个边界点并返回下一个边界点相对当前点的链码
//寻找下一个轮廓点
int MainWindow::NextPoint(QImage* image,int x,int y,int n,unsigned char* color1)
{
int directData[8][2]={
{1,0},
{1,-1},
{0,-1},
{-1,-1},
{-1,0},
{-1,1},
{0,1},
{1,1}
};
QColor color;
int startIndex=n+3+8;
int i;
for(i=0;i<=7;i++)
{
int inde=(startIndex-i)%8;
int nx = x+directData[inde][0];
int ny = y+directData[inde][1];
if(nx>=0 && nx<image->width() && ny>=0 && ny<image->height())
{
color = QColor(image->pixel(nx,ny));
if(abs(color1[0] - color.red())<50)
{
return inde;
}
}
}
return 9;
}
单区域轮廓跟踪:如果已知图像中某区域的一个边界点,并且知道一个从区域外到达此边界点的链码,通过循环调用NextPoint方法,就可以得到区域的完整轮廓信息。主要步骤有以下:
1)以当前轮廓点位中心在邻域内搜索下一个轮廓点
2)若得下一个轮廓点的链码并保存在链码表中
3)若下一个轮廓点为起始点,则轮廓跟踪完成;否则,将当前点移动到下一个轮廓点,并重复1)和2)步骤
//单区域轮廓跟踪
int* MainWindow:: SingleTrack(QImage* image,int x,int y,int n, unsigned char* color)
{
int directData[8][2]={
{1,0},
{1,-1},
{0,-1},
{-1,-1},
{-1,0},
{-1,1},
{0,1},
{1,1}
};
int* track = new int[9999];
int k=0;
int nx=x,ny=y;
int inde=n;
track[0]=x;
track[1]=y;
do
{
inde=NextPoint(image,nx,ny,inde, color);
if(inde==9) break;
track[k+3]=inde;
k++;
nx+=directData[inde][0];
ny+=directData[inde][1];
}
while(nx!=x||ny!=y);
track[2]=k;
return track;
}
多区域轮廓跟踪的步骤有以下几个:
1)搜索起点并确定起始方向链表
2)单区域轮廓跟踪
3)绘制区域轮廓
4)区域填充
//多区域轮廓跟踪
![img](https://img-blog.csdnimg.cn/img_convert/c986f11bbc8bc8cabc78f2fc6b7043db.png)
![img](https://img-blog.csdnimg.cn/img_convert/a026b73cbda345e0f4f63b357c9b2877.png)
**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!**
**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**
**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618668825)**
比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**
**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618668825)**