opencv 画延长线
hough变换可以让我们检测到直线,这在前面已有详解,对于车道检测,我们需要其到图像边界的延长线一遍之后数据帧分析。
以下代码帮助我们在opencv中画延长线,本来想用虚线表示延长线的,无奈参数调不好了……只好把bug的虚线贴上去注释掉了,希望牛人能给点帮助帮我调下吧
其他的代码部分可供参考
- void CCVMFCView::OnDottedLine(CvPoint p1,CvPoint p2,IplImage *workimg)
- {
- double k=(p2.y-p1.y)/(p2.x-p1.x+0.000001);
- double DOT_STEP;
- CvPoint pa=p1,pb=p1;
- cvLine(workimg,p1,p2,CV_RGB(255,255,0),3, CV_AA, 0 );
- //dotted line , has bug ╮(╯_╰)╭
- //while(pb.x>0&&pb.x<workimg->width&&pb.y<p2.y)
- //{
- // pb.x+=DOT_STEP;
- // pb.y+=DOT_STEP*k;
- // cvLine(workimg,pa,pb,CV_RGB(255,255,0),3, CV_AA, 0 );
- // pb.x+=DOT_STEP;
- // pb.y+=DOT_STEP*k;
- // pa=pb;
- // pb.x+=DOT_STEP;
- // pb.y+=DOT_STEP*k;
- //}
- }
- // find two endpoint of the faint line
- void CCVMFCView::OnDrawDotline(CvPoint s, CvPoint e,IplImage *workimg)
- {
- CvPoint pa,pb;
- if(s.y>e.y)//swap
- {
- pa=s;
- s=e;
- e=pa;
- }
- double k=(e.y-s.y)/(e.x-s.x+0.000001);
- double h=workimg->height,w=workimg->width;
- pb=s;
- pa.y=0,pa.x=s.x-s.y/k; //start point on the low line
- if(pa.x<0) //start point on the left line
- pa.x=0, pa.y=k*s.x;
- else if(pa.x>=w)
- pa.x=w, pa.y=s.y+k*(w-s.x);
- OnDottedLine(pb,pa,workimg);
- pa=pb=e;
- pb.y=h; pb.x+=(h-e.y)/k;
- if(pb.x>w)
- pb.y=e.y+k*(w-e.x), pb.x=w;
- else if(pb.x<0)
- pb.y=e.y-k*e.x, pb.x=0;
- OnDottedLine(pa,pb,workimg);
- }
实验结果:
原图:

车道检测结果:

hough变换检测+延长线(绿:检测结果。黄:延长线)

from: http://blog.csdn.net/abcjennifer/article/details/7440887
opencv 画延长线的更多相关文章
- 学习OpenCV——用OpenCv画漫画
闲的时候用OpenCV画漫画也挺有意思,虽然效果不好(达不到上面所实现的效果), 参数需要调整,还是大头贴而且噪声小的图像比较合适 而且可以熟悉一下关于各种滤波的操作比如:双边滤波: #include ...
- 使用OpenCV画折线图
使用OpenCV画直方图是一件轻松的事情,画折线图就没有那么Easy了,还是使用一个库吧: GraphUtils 源代码添加入工程 原文链接:http://www.360doc.com/content ...
- python3 使用opencv 画基本图形
在Python3 环境下安装opencv-python 后练习画基本图形: import numpy as np import cv2 # BGR format GREEN = (0, 255, 0) ...
- opencv画出轮廓外接矩形
Mat cannyImage; /// Detect edges using canny Canny(src, cannyImage, , , ); vector<vector<Point ...
- opencv 震撼你的视觉-------基础篇
opencv 最近在做一个钓鱼网站的项目中用到了一个叫opencv的玩意儿,以前没接触过.感觉挺新鲜的,而且项目中要用,所以就问了一下度娘(是想Google一下的,显得高大上and专业一点,但是英语水 ...
- Python OpenCV —— geometric
用OpenCV画几何图形. import numpy as np import cv2 # Create a black image img = np.zeros((521,512,3), np.ui ...
- opencv实现坐标旋转(教你框住小姐姐)
一.项目背景 最近在做一个人脸检测项目,需要接入百度AI的系统进行识别和检测.主要流程就是往指定的URL上post图片上去,之后接收检测结果就好了. 百度的检测结果包含这样的信息: left - 人脸 ...
- Python+OpenCV图像处理(十五)—— 圆检测
简介: 1.霍夫圆变换的基本原理和霍夫线变换原理类似,只是点对应的二维极径.极角空间被三维的圆心和半径空间取代.在标准霍夫圆变换中,原图像的边缘图像的任意点对应的经过这个点的所有可能圆在三维空间用圆心 ...
- 【python+opencv】直线检测+圆检测
Python+OpenCV图像处理—— 直线检测 直线检测理论知识: 1.霍夫变换(Hough Transform) 霍夫变换是图像处理中从图像中识别几何形状的基本方法之一,应用很广泛,也有很多改进 ...
随机推荐
- 新手自学ABAP(1)--数据类型
一.DATA语句 1.TYPE type ex: 可以利用冒号声明多个变量. DATA : gv_num1 TYPE I, gv_num2 TYPE I. 2.LIKE num (num可以 ...
- SQL Server 数据库身份认证以及包含数据库
首先分为SQL Server 认证与Windows 身份认证. SQL Server 认证可以运行以下语句来查询 select * from sys.sql_logins 管理员可以直接修改密码,但无 ...
- cadence PCB绘制步骤
1 创建一个PCB文件 file -> new 2 创建一个板框 add -> line ,在 options 选型中选择好,板框为 长 4400mil 宽 3200 3 给PCB板框 ...
- JAVA读取TXT文本中的数据
现在在Demo.txt中存在数据: ABC 需要将ABC从文本文件中读取出来 代码片: import java.io.*; class FileReaderDemo { public static v ...
- C语言基础:数组和字符串
数组:数组的定义注意点 数组初始化正确写法: int args[5] = {1,23,32,4,5}; int args[5] = {12,23}; int args[5] = {[3]=23, [4 ...
- C#中类型分析中的常见问题 Type - 转
http://www.cnblogs.com/yuanyuan/archive/2012/08/16/2642281.html 写代码的时候经常需要分析已有类型的信息例如:分析现有类型自动生成类, 或 ...
- 1068: [SCOI2007]压缩 - BZOJ
Description 给一个由小写字母组成的字符串,我们可以用一种简单的方法来压缩其中的重复信息.压缩后的字符串除了小写字母外还可以(但不必)包含大写字母R与M,其中M标记重复串的开始,R重复从上一 ...
- 在Eclipse中使用Propertites Editor插件来解决property文件中文显示乱码
在一般情况下,propertites文件在eclipse中的显示中文一直显示乱码,想要解决这个问题,需要通过在eclipse中安装一个Propertites Editor插件来进行解决. 在Eclip ...
- SQL Server性能常用语句
查看各表的数据行数 SELECT o.name, i. ROWS FROM sysobjects o, sysindexes i WHERE o.id = i.id AND o.Xtype = ORD ...
- 【转】成为it精英,我奋斗7年
转载地址:http://liangwang985.blog.163.com/blog/static/119549233201191394259491/ 这些日子 我一直在写一个实时操作系统内核,已有小 ...