求一个可以用OpenCV求线段距离的代码!可以有偿,用C++, 最好也可以用javaCV
我本来打算用霍夫变化求线段长度,奈何时间不够了下午就要出结果
这种白底黑线的简单的图片可以识别就可以,可以识别出线段长度,以及线段的端点坐标
求写一个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 VB.NET2022如何生成发布成exe文件
- ¥30 matlab appdesigner私有函数嵌套整合
- ¥15 给我一个openharmony跑通webrtc实现视频会议的简单demo项目,sdk为12
- ¥15 vb6.0使用jmail接收smtp邮件并另存附件到D盘
- ¥30 vb net 使用 sendMessage 如何输入鼠标坐标
- ¥15 关于freesurfer使用freeview可视化的问题
- ¥100 谁能在荣耀自带系统MagicOS版本下,隐藏手机桌面图标?
- ¥15 求SC-LIWC词典!
- ¥20 有关esp8266连接阿里云
- ¥15 C# 调用Bartender打印机打印