霍夫变换 检测直线

来源:互联网 发布:雷雨田软件 编辑:程序博客网 时间:2024/05/16 05:07
#include "opencv2/core/core.hpp"  
#include "opencv2/highgui/highgui.hpp"  
#include "opencv2/imgproc/imgproc.hpp"  
  
#include <iostream>  
using namespace cv;  
using namespace std;  
  
int main( int argc, char** argv )  
{  
    Mat src, edge,color_edge;  
    src=imread("1.jpg");  
    if( !src.data )    
        return -1;    
  
    Canny(src,edge,50,200,3);  
    cvtColor( edge, color_edge, CV_GRAY2BGR );  
    vector<Vec4i> lines;  
    HoughLinesP(edge, lines, 1, CV_PI/180, 80, 30, 10 );  
    for( size_t i = 0; i < lines.size(); i++ )  
    {  
        Vec4i l = lines[i];  
        line( color_edge, Point(l[0], l[1]), Point(l[2], l[3]), Scalar(0,0,255), 2);  
    }  
  
    namedWindow( "lines", CV_WINDOW_NORMAL );  
    imshow( "lines", color_edge );  
    waitKey(0);  
  
    return 0;  
}  
原创粉丝点击