求一个可以用OpenCV求线段距离的代码!可以有偿,用C++, 最好也可以用javaCV
我本来打算用霍夫变化求线段长度,奈何时间不够了下午就要出结果
这种白底黑线的简单的图片可以识别就可以,可以识别出线段长度,以及线段的端点坐标
![](https://profile-avatar.csdnimg.cn/220099be2c7446ae8d671adb0b0311d9_apple_50669589.jpg!4)
求写一个opencv很简单的小代码
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- 爱晚乏客游 2022-06-29 16:21关注
简单写一个,里面内凹的角起始点差一个像素,我懒得处理,你自己要是觉得不行自己处理下
#include<iostream> #include<opencv2/opencv.hpp> using namespace std; using namespace cv; struct Line { Point A, B; double distance; }; double getDistance(Point A,Point B) { return sqrt((A.x - B.x)* (A.x - B.x) + (A.y - B.y)*(A.y - B.y)); } int main() { string path = "./3/1.jpg"; Mat img = imread(path); Mat gray,binary; cvtColor(img, gray, COLOR_BGR2GRAY); threshold(gray, binary, 180,255, THRESH_BINARY_INV); vector<vector<Point>> contours; findContours(binary, contours, RETR_EXTERNAL, CHAIN_APPROX_SIMPLE); vector<Line> Lines; //存放找到结果Lines for (int i = 0; i < contours.size(); ++i) { for (int j = 0; j < contours[i].size(); ++j) { int k = (j +1)%contours[i].size(); Point A = contours[i][j]; Point B = contours[i][k]; double distance = getDistance(A, B); if (distance > 2) { Line temp_line; temp_line.A = A; temp_line.B = B; temp_line.distance = distance; Lines.push_back(temp_line); } } } //绘制每条线: Mat drawImg = img.clone(); for (int i = 0; i < Lines.size(); ++i) { Scalar color(rand() % 255, rand() % 255, rand() % 255 ); line(drawImg, Lines[i].A, Lines[i].B, color, 1, 8); } imshow("src", img); imshow("res", drawImg); waitKey(); return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 3无用
悬赏问题
- ¥15 Stata链式中介效应代码修改
- ¥15 latex投稿显示click download
- ¥15 请问读取环境变量文件失败是什么原因?
- ¥15 在若依框架下实现人脸识别
- ¥15 添加组件无法加载页面,某块加载卡住
- ¥15 网络科学导论,网络控制
- ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
- ¥15 metadata提取的PDF元数据,如何转换为一个Excel
- ¥15 关于arduino编程toCharArray()函数的使用
- ¥100 vc++混合CEF采用CLR方式编译报错