位置: 编程技术 - 正文

【Rayeager PX2分享】OpenCV入门之线段检测

编辑:rootadmin
线段检测主要运用Hough变换,Hough变换是图像处理中从图像中识别几何形状的基本方法之一,应用很广泛,也有很多改进算法。主要用来从图像中分离出具有某种相同特征的几何形状(如,直线,圆等)。最基本的霍夫变换是从黑白图像中检测直线(线段)。在OpenCV编程中,实现线段检测主要使用cvHoughLines2函数。函数原型:CvSeq* cvHoughLines2( CvArr* image, void* line_storage, int method, double rho, double theta, int threshold, double param1=0, double param2=0);参数说明:第一个参数表示输入图像,必须为二&#;图像(黑白图)。第二个参数表示存储容器,可以传入CvMemStorage类型的指针。第三个参数表示变换变量,可以取下面的&#;: CV_HOUGH_STANDARD - 传统或标准 Hough 变换. 每一个线段由两个浮点数 (ρ, θ) 表示,其中 ρ 是线段与原点 (0,0) 之间的距离,θ 线段与 x-轴之间的夹角。 CV_HOUGH_PROBABILISTIC - 概率 Hough 变换(如果图像包含一些长的线性分割,则效率更高)。它返回线段分割而不是整个线段。每个分割用起点和终点来表示。 CV_HOUGH_MULTI_SCALE - 传统 Hough 变换的多尺度变种。线段的编码方式与 CV_HOUGH_STANDARD 的一致。第四个参数表示与象素相关单位的距离精度。第五个参数表示弧度测量的角度精度。第六个参数表示检测线段的最大条数,如果已经检测这么多条线段,函数返回。第七个参数与第三个参数有关,其意义如下: 对传统 Hough 变换,不使用(0). 对概率 Hough 变换,它是最小线段长度. 对多尺度 Hough 变换,它是距离精度 rho 的分母 (大致的距离精度是 rho 而精确的应该是 rho / param1 ).第八个参数与第三个参数有关,其意义如下: 对传统 Hough 变换,不使用 (0). 对概率 Hough 变换,这个参数表示在同一条线段上进行碎线段连接的最大间隔&#;(gap), 即当同一条线段上的两条碎线段之间的间隔小于param2时,将其合二为一。 对多尺度 Hough 变换,它是角度精度 theta 的分母 (大致的角度精度是 theta 而精确的角度应该是 theta / param2)。示例程序:hough.cpp #include <opencv2/core/core.hpp>#include <opencv2/opencv.hpp>#include <opencv2/imgproc/imgproc.hpp>#include <opencv2/highgui/highgui.hpp>#include <iostream>using namespace std;int main (int argc, char **argv) { const char *pstrWindowsSrcTitle = "initial";const char *pstrWindowsLineName = "hough";IplImage *pSrcImage = cvLoadImage("hough.jpg", CV_LOAD_IMAGE_UNCHANGED);IplImage *pGrayImage = cvCreateImage(cvGetSize(pSrcImage), IPL_DEPTH_8U, 1); cvCvtColor(pSrcImage, pGrayImage, CV_BGR2GRAY);IplImage *pCannyImage = cvCreateImage(cvGetSize(pSrcImage), IPL_DEPTH_8U, 1); cvCanny(pGrayImage, pCannyImage, , );CvMemStorage *pcvMStorage = cvCreateMemStorage(); double fRho = 1; double fTheta = CV_PI / ; int nMaxLineNumber = ;//最多检测条直线double fMinLineLen = ;//最小线段长度double fMinLineGap = ;//最小线段间隔CvSeq *pcvSeqLines = cvHoughLines2(pCannyImage, pcvMStorage, CV_HOUGH_PROBABILISTIC, fRho, fTheta, nMaxLineNumber, fMinLineLen, fMinLineGap);IplImage *pColorImage = cvCreateImage(cvGetSize(pSrcImage), IPL_DEPTH_8U, 3);cvCvtColor(pCannyImage, pColorImage, CV_GRAY2BGR);int i;for(i = 0; i < pcvSeqLines->total; i&#;&#;) { CvPoint* line = (CvPoint*)cvGetSeqElem(pcvSeqLines, i); cvLine(pColorImage, line[0], line[1], CV_RGB(,0,0), 2); }cvNamedWindow(pstrWindowsSrcTitle, CV_WINDOW_AUTOSIZE); cvShowImage(pstrWindowsSrcTitle, pSrcImage); cvNamedWindow(pstrWindowsLineName, CV_WINDOW_AUTOSIZE); cvShowImage(pstrWindowsLineName, pColorImage); cvWaitKey(0); cvReleaseMemStorage(&pcvMStorage); cvDestroyWindow(pstrWindowsSrcTitle); cvDestroyWindow(pstrWindowsLineName); cvReleaseImage(&pSrcImage); cvReleaseImage(&pGrayImage); cvReleaseImage(&pCannyImage); cvReleaseImage(&pColorImage); return 0; }makefile: INCLUDE = $(shell pkg-config --cflags opencv) LIBS = $(shell pkg-config --libs opencv) SOURCES = hough.cpp # 目标文件 OBJECTS = $(SOURCES:.cpp=.o) # 可执行文件 TARGET = hough $(TARGET):$(OBJECTS) g&#;&#; -o $(TARGET) $(OBJECTS) -I $(INCLUDE) $(LIBS) $(OBJECTS):$(SOURCES) g&#;&#; -c $(SOURCES) clean: rm $(OBJECTS) $(TARGET) # 编译规则 $@代表目标文件 $< 代表第一个依赖文件 %.o:%.cpp g&#;&#; -I $(INCLUDE) -o $@ -c $<所在文件夹上已有hough.jpg图片,make后执行./hough hough.jpg 【Rayeager PX2分享】OpenCV入门之线段检测感谢fjjjnk的分享更多请参考:

推荐整理分享【Rayeager PX2分享】OpenCV入门之线段检测,希望有所帮助,仅作参考,欢迎阅读内容。

【Rayeager PX2分享】OpenCV入门之线段检测

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

Android开发资源文件用法小结 本文用来记录在Android开发中经常用到的一些用法arrays.xml定义数组例:resources!--shareitems--string-arrayname="app_share_items"item新浪微博/itemitem腾讯微博/item/string-

Android 官方文档之Activity和Task 原文地址什么知识,看官方的API是最好的了。但是鉴于很多人英语不好,便转载了这篇文章,翻译的非常好了。搞不懂Activity声明周期,和程序框架设计

Android常用代码之APK root权限静默安装

标签: 【Rayeager PX2分享】OpenCV入门之线段检测

本文链接地址:https://www.jiuchutong.com/biancheng/386021.html 转载请保留说明!

上一篇:如何使用adb查看各个文件属性详细信息(adb查看ip地址)

下一篇:Android开发资源文件用法小结(android完整开源项目)

  • 印花税征税范围是什么
  • 自产货物用于生产
  • 直线法计提折旧的公式预计净残值
  • 公司给非员工代缴社保合法吗
  • 城建税和教育费附加可以税前扣除吗
  • 应交税费未交增值税借方余额表示什么
  • 提前给货款计入什么科目
  • 销售固定资产未收到钱
  • 小微企业减免的税金怎么做账
  • 增值税预缴表填写模板
  • 可以选择用简易计算办法计税的是哪些
  • 预付账款和其他应收款可以抵消吗
  • 撤回和撤销是什么意思
  • 增值税发票开具错误重开该怎么做会计分录?
  • 应收票据背书转让以取得所需物资
  • 应收账款出售给银行
  • 房屋维修基金怎么申请使用
  • 公司聚餐费属于哪个科目
  • 无法手动设置时区
  • 个税申报的人数比工资表少了怎么办
  • 交易性金融资产的入账价值
  • 收益类账户的会计分录
  • cmdkill进程
  • 建筑工程甲级什么意思
  • 踩坑视频
  • 货币资金属于
  • 巧克力山介绍
  • 前端毕业设计项目
  • 同一控制下企业合并入账价值
  • SSD目标检测算法
  • 外出经营活动税收管理
  • 布兹洛夫
  • php 面向对象
  • 工资必须走银行卡吗
  • 【深度学习时间序列预测案例】零基础入门经典深度学习时间序列预测项目实战(附代码+数据集+原理介绍)
  • 图像修复技术
  • 用php写个简单的编程
  • 暂估入库后发票来不了
  • 资金账簿印花税怎么算
  • 管家婆实收资本显示负数什么原因
  • 员工意外伤害保险最多赔多少
  • php验证码代码怎么写
  • 管理不善的进项税额去了哪里
  • 应交税费的明细账怎么登记
  • 汇算清缴调增都有哪些项目
  • 可以采用
  • 处置使用过的固定资产,税率按多少
  • 写字楼租金
  • 移动怎么开当月发票
  • 利息收入怎么做红字
  • 享受优惠政策的通知
  • 应收账款客户少付款怎么记账
  • 认缴的注册资金怎么做账
  • 调整以前年度的费用怎么做
  • 一般纳税人购进税控设备如何抵扣
  • 租赁费计提印花税税率
  • 货款还没收到有违法所得吗
  • 银行贷款给个人用于经营属于消费贷款
  • 存储过程sql server
  • 蓝屏service
  • iphone制造成本
  • avsched32.exe是什么进程 avsched32进程有什么作用
  • linux chakan
  • 硬盘版win10
  • centos设置永不待机
  • win8开始菜单在右边
  • win8无法打开ie
  • linux系统如何禁用光驱
  • win10任务栏跳来跳去
  • win10资源管理器启动不了
  • PyCharm在win10的64位系统安装实例
  • eventlistener js
  • linux释放cache
  • javascript性能优化写法
  • listview
  • 每年个人所得税2万工资多少
  • 佛山市地税局办公室主任
  • 合并申报后老申报表还可以继续使用吗
  • 代收工会经费标准规定
  • 出口退税备案单证目录
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设