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中进行模拟,得到的如下结果:

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

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

(0)

相关推荐

  • 使用opencv识别图像红色区域,并输出红色区域中心点坐标

    适用小白,大佬勿喷 个人配置:vs2013 ; opencv 3.0 ; 直接上效果图 注意:右下角的水印把中心点挡住了,要仔细看才能看到 下面是代码: #include <iostream> #include<opencv2\opencv.hpp> #include <opencv2/imgproc/imgproc.hpp> #include <opencv2/highgui/highgui.hpp> #define PI 3.1415926 using

  • OpenCV识别图像上的线条轨迹

    如果图片上有线条,图形什么的,人的眼睛可以直接看出来,这是人的直接反应.那么如何让电脑识别呢? 图片在内存中是以二维矩阵的形式存储的,如果是彩图,则是GBR三通道,灰度图则是单通道.本教程用OpenCV去识别图形上的线条,曲线等轨迹. 软件环境:Win7-32, VS2010, OpenCV2.4.9 (1)以灰度图的方式导入图片 Mat src = imread("1.jpg", 0); (2)我的思路:根据图形中的每个像素点的差异去判断,对原图的灰度图做二值化处理,不是线条的区域像

  • Python Opencv实现图像轮廓识别功能

    本文实例为大家分享了python opencv识别图像轮廓的具体代码,供大家参考,具体内容如下 要求:用矩形或者圆形框住图片中的云朵(不要求全部框出) 轮廓检测 Opencv-Python接口中使用cv2.findContours()函数来查找检测物体的轮廓. import cv2 img = cv2.imread('cloud.jpg') # 灰度图像 gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 二值化 ret, binary = cv2.th

  • opencv如何识别图片上带颜色的圆

    本文实例为大家分享了opencv识别图片上带颜色的圆的具体代码,供大家参考,具体内容如下 识别带颜色的圆,首先需要先查询该颜色的HSV值,下图部分紫色归为红色了: 比如红色: //红色的HSV值 int low_H = 0,low_S = 123,low_V = 100; int High_H = 5,High_S = 255,High_V = 255; 然后将图片从BGR转化成HSV,接着二值化: cvtColor(image,src,COLOR_BGR2HSV); //从BGR-> HSV

  • 使用OpenCV circle函数图像上画圆的示例代码

    OpenCV中circle与rectangle函数显示,只不过rectangle在图像中画矩形,circle在图像中画圆. void circle(Mat img, Point center, int radius, Scalar color, int thickness=1, int lineType=8, int shift=0) img为源图像 center为画圆的圆心坐标 radius为圆的半径 color为设定圆的颜色,规则根据B(蓝)G(绿)R(红) thickness 如果是正数,

  • OpenCV识别提取图像中的水平线与垂直线

    本文实例为大家分享了OpenCV识别提取图像中的水平线与垂直线,供大家参考,具体内容如下 1).原理 图像形态学操作时候,可以通过自定义的结构元素实现结构元素 对输入图像一些对象敏感.另外一些对象不敏感,这样就会让敏感的对象改变而不敏感的对象保留输出.通过使用两个最基本的形态学操作 – 膨胀与腐蚀,使用不同的结构元素实现对输入图像的操作.得到想要的结果. -膨胀,输出的像素值是结构元素覆盖下输入图像的最大像素值 -腐蚀,输出的像素值是结构元素覆盖下输入图像的最小像素值 常见的形状:矩形.园.直线

  • OpenCV提取图像中圆线上的数据具体流程

    目录 需求说明 具体流程 功能函数 C++测试代码 测试效果 总结 需求说明 在对图像进行处理时,经常会有这类需求:客户想要提取出图像中某条直线.圆线或者ROI区域内的感兴趣数据,进行重点关注.该需求在图像检测领域尤其常见.ROI区域一般搭配Rect即可完成提取,直线和圆线数据的提取没有现成的函数,需要自行实现. 直线的提取见: OpenCV获取图像中直线上的数据具体流程 而圆线的提取则是本文要将的内容,对圆线而言,将线上某点作为起点,沿顺时针或逆时针方向依次提取感兴趣数据,可放置在容器中.那么

  • Python+OpenCV实现在图像上绘制矩形

    话不多说,直接上代码 import copy import cv2 import numpy as np WIN_NAME = 'draw_rect' class Rect(object): def __init__(self): self.tl = (0, 0) self.br = (0, 0) def regularize(self): """ make sure tl = TopLeft point, br = BottomRight point ""

  • 使用Python和OpenCV检测图像中的物体并将物体裁剪下来

    介绍 硕士阶段的毕设是关于昆虫图像分类的,代码写到一半,上周五导师又给我新的昆虫图片数据集了,新图片中很多图片很大,但是图片中的昆虫却很小,所以我就想着先处理一下图片,把图片中的昆虫裁剪下来,这样除去大部分无关背景,应该可以提高识别率. 原图片举例(将红色矩形框部分裁剪出来)): step1:加载图片,转成灰度图 image = cv2.imread("353.jpg") gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY) step2:用Sob

  • OpenCV在Android上的应用示例

    一. OpenCV 介绍 OpenCV是一个基于BSD许可(开源)发行的跨平台计算机视觉库,可以运行在Linux.Windows.Android和Mac OS操作系统上.它轻量级而且高效--由一系列 C 函数和少量 C++ 类构成,同时提供了Python.Ruby.MATLAB等语言的接口,实现了图像处理和计算机视觉方面的很多通用算法. 在移动端上使用 OpenCV 可以完成一系列图像处理的工作. 二. OpenCV 在 Android 上的配置 我在项目中使用的 OpenCV 版本是 4.x.

随机推荐