OpenCV识别图像上的线条轨迹

 更新时间:2020年07月21日 08:58:44   作者:令狐掌门  
这篇文章主要为大家详细介绍了OpenCV识别图像上的线条轨迹,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

如果图片上有线条,图形什么的,人的眼睛可以直接看出来,这是人的直接反应。那么如何让电脑识别呢?

图片在内存中是以二维矩阵的形式存储的,如果是彩图,则是GBR三通道,灰度图则是单通道。本教程用OpenCV去识别图形上的线条,曲线等轨迹。

软件环境:Win7-32, VS2010, OpenCV2.4.9

(1)以灰度图的方式导入图片

Mat src = imread("1.jpg", 0);

(2)我的思路:根据图形中的每个像素点的差异去判断,对原图的灰度图做二值化处理,不是线条的区域像素置0,有线条的区域置为255,然后逐列进行像素求和,如果列的和大于0则是检测到了线条,此时结束该列的扫描,继续扫描下一列。这样就可以得到线条的轨迹了。

二值处理:

threshold(src, dst, 100, 255, CV_THRESH_BINARY_INV); //二值化

按列扫描求和:

//按列扫描,求像素和,由于是二值后的图片,没有线条时,该列的像素和为0;扫描到线条时像素大于0
 for(int w = 0; w < nCols; w++)
 {
 int sum = 0;
 
 for(int h = 0; h < nRows; h++)
 {
  uchar *pRow = dst.ptr<uchar>(h, w); //该列中每个像素的地址
  sum += (int)(*pRow);
 
  if(sum > 0) //到达了线条的上侧,像素和大于0
  {
  cout << "找到了线条点,";  //从上往下找,由于线条很细,目前只判断上边界。
  cout << "坐标如下: X = " << w << ", Y = " << h << endl; 
  fout << "坐标如下: X = " << w << ", Y = " << h << endl; //控制台会丢失数据,存到文本不会丢失
  sum = 0;
  break;
  }
 }
 }

整体代码如下:

#include <iostream>
#include <opencv2/opencv.hpp>
#include <fstream>
using namespace std;
using namespace cv;
 
int main()
{
 Mat src = imread("1.jpg", 0);
 //imshow("src", src);
 
 Mat dst;
 threshold(src, dst, 100, 255, CV_THRESH_BINARY_INV); //二值化
 //imshow("dst", dst);
 
 int nRows = dst.rows;
 int nCols = dst.cols;
 
 ofstream fout("data.txt");
 
 //按列扫描,求像素和,由于是二值后的图片,没有线条时,该列的像素和为0;扫描到线条时像素大于0
 for(int w = 0; w < nCols; w++)
 {
 int sum = 0;
 
 for(int h = 0; h < nRows; h++)
 {
  uchar *pRow = dst.ptr<uchar>(h, w); //该列中每个像素的地址
  sum += (int)(*pRow);
 
  if(sum > 0) //到达了线条的上侧,像素和大于0
  {
  cout << "找到了线条点,";  //从上往下找,由于线条很细,目前只判断上边界。
  cout << "坐标如下: X = " << w << ", Y = " << h << endl; 
  fout << "坐标如下: X = " << w << ", Y = " << h << endl; //控制台会丢失数据,存到文本不会丢失
  sum = 0;
  break;
  }
 }
 }
 
 waitKey();
 cout << endl;
 system("pause");
 return 0;
}

在Qt中进行模拟,得到的如下结果:

目前的识别如上所示,后续会继续更新,如有好的处理方法,请各位博友斧正。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 基于C++实现柏林噪声算法(Perlin Noise)

    基于C++实现柏林噪声算法(Perlin Noise)

    Perlin噪声(Perlin noise,又称为柏林噪声)指由Ken Perlin发明的自然噪声生成算法,具有在函数上的连续性,并可在多次调用时给出一致的数值。本文将用C++实现柏林噪声算法,感兴趣的可以了解一下
    2023-03-03
  • C语言数据结构实现链表去重的实例

    C语言数据结构实现链表去重的实例

    这篇文章主要介绍了C语言数据结构实现链表去重的实例的相关资料,这里提供了题目及实例代码,需要的朋友可以参考下
    2017-07-07
  • C++11模板元编程-std::enable_if示例详解

    C++11模板元编程-std::enable_if示例详解

    这篇文章主要给大家介绍了关于C++11模板元编程-std::enable_if的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • C语言用easyx实现消砖块游戏

    C语言用easyx实现消砖块游戏

    这篇文章主要为大家详细介绍了C语言消砖块游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-05-05
  • GCC编译过程(预处理,编译,汇编,链接)及GCC命令详解

    GCC编译过程(预处理,编译,汇编,链接)及GCC命令详解

    文章详细介绍了GCC编译器的工作原理,包括预处理、编译、汇编和链接四个主要阶段,每个阶段都有其特定的任务和输出文件,文章还解释了如何使用GCC命令选项来查看每个阶段的输出,以及如何通过调整编译选项来优化程序性能或调试问题,感兴趣的朋友跟随小编一起看看吧
    2024-11-11
  • 详细聊聊c语言中的缓冲区问题

    详细聊聊c语言中的缓冲区问题

    缓冲区又称为缓存,它是内存空间的一部分,也就是说在内存空间中预留了一定的存储空间,这些存储空间用来缓冲输入或输出的数据,这部分预留的空间就叫做缓冲区,这篇文章主要给大家介绍了关于c语言中缓冲区问题的相关资料,需要的朋友可以参考下
    2021-11-11
  • C++ OpenCV实现白平衡之灰度世界算法

    C++ OpenCV实现白平衡之灰度世界算法

    灰度世界算法是白平衡各种算法中最基本的一种。本文将利用C++和OpenCV实现白平衡中的灰度世界算法,文中示例代码讲解详细,感兴趣的可以了解一下
    2022-05-05
  • typedef和#define用法区别总结

    typedef和#define用法区别总结

    在C还是C++代码中,typedef都使用的很多,在C代码中尤其多,typedef与#define有些相似,其实是不同的,特别是在一些复杂的用法上,下面这篇文章主要给大家介绍了关于typedef和#define用法区别总结的相关资料,需要的朋友可以参考下
    2023-06-06
  • C++实现LeetCode(97.交织相错的字符串)

    C++实现LeetCode(97.交织相错的字符串)

    这篇文章主要介绍了C++实现LeetCode(97.交织相错的字符串),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • C++实现团购订单管理系统

    C++实现团购订单管理系统

    这篇文章主要为大家详细介绍了如何利用C++实现团购订单管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-12-12

最新评论