opencv|LineIterator获取图片中两点之间连线上所有点坐标

#include "opencv2/opencv.hpp"
int main(int argc, char** argv)
{
   
    cv::Mat image = cv::Mat(100, 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要实现获取图片两点之间的真实距离,需要进行以下步骤: 1. 读取图片并显示 使用Python的OpenCV库可以读取图片并显示,代码如下: ```python import cv2 img = cv2.imread('image.jpg') cv2.imshow('image', img) cv2.waitKey(0) cv2.destroyAllWindows() ``` 其,'image.jpg'为图片的路径。 2. 使用鼠标点击获取两个点的坐标 使用OpenCV的鼠标事件可以获取鼠标点击的坐标,代码如下: ```python import cv2 def get_coordinate(event, x, y, flags, param): if event == cv2.EVENT_LBUTTONDOWN: print('x: {}, y: {}'.format(x, y)) img = cv2.imread('image.jpg') cv2.imshow('image', img) cv2.setMouseCallback('image', get_coordinate) cv2.waitKey(0) cv2.destroyAllWindows() ``` 该代码会在鼠标左键点击时输出坐标。 3. 计算两点之间的距离 使用获取到的两个点的坐标,可以使用勾股定理计算两点之间的距离,代码如下: ```python import cv2 import math def get_distance(x1, y1, x2, y2): return math.sqrt((x1 - x2) ** 2 + (y1 - y2) ** 2) def get_coordinate(event, x, y, flags, param): if event == cv2.EVENT_LBUTTONDOWN: print('x: {}, y: {}'.format(x, y)) if len(param) == 2: x1, y1 = param[0] print('distance: {:.2f}'.format(get_distance(x1, y1, x, y))) param.append((x, y)) img = cv2.imread('image.jpg') cv2.imshow('image', img) cv2.setMouseCallback('image', get_coordinate, []) cv2.waitKey(0) cv2.destroyAllWindows() ``` 该代码会在点击两个点时输出两点之间的距离。 注意:需要在点击第二个点时计算距离,因此用一个列表来存储已经点击的点,当列表长度为2时,表示已经点击了两个点,此时计算距离。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

3D视觉工坊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值