opencv去除8邻域被标记的点的个数小于6的小连通区域

这段代码展示了如何使用OpenCV去除8邻域内被标记点数少于6的连通区域。通过遍历图像并使用深度优先搜索,标记每个连通区域,然后检查其大小。如果区域像素数量不足6,则将这些区域设为0。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

void remove_six_four(int height, int width, int shuiping[H][W], int **temp_shuiping, int **temp_shuiping_2)
{
int i, j,l,m;
vector<Point> savepoint;
vector<Point> boolpoint;
Point pi,pj;
bool visit[W][H] = { 0 };
for (i = 1; i < width-1; i++)
{
for (j = 1; j < height-1; j++)
{
if (temp_shuiping[i][j] == 1&&visit[i][j]==false)
{
pi.x = i;
pi.y = j;
savepoint.push_back(pi);
boolpoint.push_back(pi);
visit[i][j] = true;
while (!boolpoint.empty())
{
pj = boolpoint[0];
boolpoint.erase(boolpoint.begin());
cout << boolpoint.size() << endl;
for (l = -1; l < 2; l++)
{
for (m = -1; m < 2; m++)
{
if (l == 0 && m == 0)
continue;
if (temp_shuiping[pj.x + l][pj.y + m] == 1 && visit[pj.x + l][pj.y + m] == false)
{
pi.x = pj.x + l;
pi.y = pj.y + m;
visit[pj.x + l][pj.y + m] = true;
savepoint.push_back(pi);
boolpoint.push_back(pi);
}
}
}
}
cout <<"sss"<< savepoint.size() << endl;
if (savepoint.size() < 6)
{
for (l = 0; l < savepoint.size(); l++)
{
temp_shuiping[savepoint[l].x][savepoint[l].y] = 0;
}
}
savepoint.clear();
}
}
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值