19,468
社区成员
发帖
与我相关
我的任务
分享
void CtestOpencvDlg::OnTest()
{
//【1】载入原始图和Mat变量定义
Mat srcImage = imread("C:\\test2.jpg"); //工程目录下应该有一张名为1.jpg的素材图
Mat temp, midImage,dstImage;//临时变量和目标图的定义
//【2】进行边缘检测和转化为灰度图
cvtColor(srcImage, temp, CV_BGR2GRAY);//转化边缘检测后的图为灰度图
Canny(temp, midImage, 50, 200, 3);//进行一此canny边缘检测
cvtColor(midImage,dstImage, CV_GRAY2BGR);//转化边缘检测后的图为灰度图
//【3】进行霍夫线变换
vector<Vec4i> lines;//定义一个矢量结构lines用于存放得到的线段矢量集合
HoughLinesP(midImage, lines, 1, CV_PI/180, 80, 50, 10 );
//【4】依次在图中绘制出每条线段
for( size_t i = 0; i < lines.size(); i++ )
{
Vec4i l = lines[i];
line( srcImage, Point(l[0], l[1]), Point(l[2], l[3]), Scalar(186,88,255), 1, CV_AA);
}
//【5】显示效果图
imshow("【效果图】", srcImage);
waitKey(0);
}