提取骨架连接点
Extracting Junction point in skeleton
我目前在学校的项目中使用opencv和c++。我的问题是如何提取骨架图像中的连接点。我试着开发这个代码,但它不起作用,我没有发现错误。提前谢谢。
int main( int argc, char** argv )
{
cv::Mat im = cv::imread("IMG.jpg",0);
if (im.empty())
return -1;
cv::Mat img_rgb(im.size(), CV_8UC3);
cv::threshold(img_rgb, img_rgb, 155, 255, CV_THRESH_BINARY);
cv::cvtColor(im, img_rgb, CV_GRAY2RGB);
int s=0;
for (int i = 1; i < img_rgb.rows-1; i++)
{
for (int j = 1; j < img_rgb.cols-1; j++)
{
if(255 == img_rgb.at<uchar>(i,j))
{
uchar p1 = img_rgb.at<uchar>(i, j);
uchar p2 = img_rgb.at<uchar>(i-1, j);
uchar p3 = img_rgb.at<uchar>(i-1, j+1);
uchar p4 = img_rgb.at<uchar>(i, j+1);
uchar p5 = img_rgb.at<uchar>(i+1, j+1);
uchar p6 = img_rgb.at<uchar>(i+1, j);
uchar p7 = img_rgb.at<uchar>(i+1, j-1);
uchar p8 = img_rgb.at<uchar>(i, j-1);
uchar p9 = img_rgb.at<uchar>(i-1, j-1);
// s = abs(p9-p8)+abs(p8-p7)+abs(p7-p6)+abs(p6-p5)+abs(p5-p4)+abs(p4-p3)+abs(p3-p2)+abs(p2-p9);
// if (s == 1530)
int same=(p9==p1);
same+=(p8==p1);
same+=(p7==p1);
same+=(p6==p1);
same+=(p5==p1);
same+=(p4==p1);
same+=(p3==p1);
same+=(p2==p1);
if (same==2)
{
// cout<<i<<" "<<j<<" " <<same<<endl;
circle(img_rgb,Point(i,j),1,Scalar(0, 255, 0),1);
}
}
}
}
cv::imshow("a",img_rgb);
cv::waitKey();
return 0 ;
}
您设置的阈值为img_rgb,此时该值为空。
也,为什么转换从灰色到rgb,再次?(顺便说一句,如果你循环rgb图像,mat.at<uchar>(y,x)
是错误的,应该是mat.at<Vec3b>(y,x)
)
我会说,跳过gray2rgb转换,而不是阈值灰度图像加载:
cv::Mat im = cv::imread("IMG.jpg",0);
if (im.empty())
return -1;
cv::Mat thresh;
cv::threshold(im, thresh, 155, 255, CV_THRESH_BINARY);
,然后使用该垫子进行进一步处理:
for (int i = 1; i < thresh.rows-1; i++)
{
for (int j = 1; j < thresh.cols-1; j++)
{
uchar p1 = thresh.at<uchar>(i, j);
if(255 == p1)
{
uchar p2 = thresh.at<uchar>(i-1, j);
uchar p3 = thresh.at<uchar>(i-1, j+1);
// ...
相关文章:
- 从包含m行的文件中提取n行,必要时(惰性地)重复该文件
- 如何从 std::atomic 中提取指针 T<T>?
- 为什么istream不支持右值提取
- 如何设置一个范围来提取我想要获得的信息
- 有没有办法知道Tracer是否成功地完全连接到了jaegerclientcpp中的jaeger后端服务器
- 视觉工作室项目.提取源文件夹名称
- C++17 - 使用自定义分配器的节点提取/重新插入 - 适用于 clang++/libc++,但不适用于 libstd
- 从字符串中提取整数并形成一个数组
- C ++中的StringStream有助于使用向量从字符串中提取逗号分隔的整数,而不是空格分隔的整数,为什么?
- asn1c 不会从 asn.1 模块中提取八位字节字符串的默认值
- 从 std::vector<无符号字符>切片中提取 int?
- 在C++中使用重载提取运算符时出现问题
- 在 Qt(C++) 中使用 QProcess 解压缩 - 提取目录问题
- C++(.cpp文件和.h文件)拆分代码并添加一个函数,提取 - 这很容易吗?
- 无法从 std::string 中提取C++ Unicode 符号
- 如何从也包含C++字母的文本文件中提取某些数字?
- 对于每个连接点集合,通过所有连接点一次的算法
- 提取骨架连接点
- 二维数组,计算并存储6个随机连接点
- Microsoft Word连接点接收器示例/MFC出现问题