OpenCV直线段检测算法类cv::line_descriptor::LSDDetector

  • 操作系统:ubuntu22.04
  • OpenCV版本:OpenCV4.9
  • IDE:Visual Studio Code
  • 编程语言:C++11

算法描述

该类用于实现 LSD (Line Segment Detector) 直线段检测算法。LSD 是一种快速、准确的直线检测方法,能够在不依赖边缘检测的前提下直接从图像中提取出直线段。

它是 OpenCV 的 line_descriptor 模块的一部分,常用于计算机视觉任务如图像拼接、SLAM、特征匹配等。

主要功能:

  • 从灰度图像中检测直线段;
  • 支持多尺度和多金字塔层处理;
  • 输出结构化信息:线段起点、终点、长度、响应值等;
  • 可与 BinaryDescriptor 配合使用,进行线段描述符提取和匹配;

公共成员函数

  1. 创建 LSDDetector 实例
cpp 复制代码
Ptr<LSDDetector> lsd = LSDDetector::createLSDDetector();

说明:

  • 静态工厂方法,用于创建一个默认配置的 LSD 检测器;
  • 返回智能指针 Ptr。
  1. detect() 方法:检测线段
cpp 复制代码
void detect( const Mat& image, CV_OUT std::vector<KeyLine>& keylines,
             int scale, int numOctaves, const Mat& mask = Mat() );

参数说明:

参数 类型 含义
image const Mat& 输入图像(通常为单通道灰度图)
keylines std::vector& 输出的线段列表
scale int 图像缩放比例(尺度空间参数)
numOctaves int 构建的金字塔层数(尺度空间层级数)
mask const Mat&(可选) 感兴趣区域掩码

代码示例

cpp 复制代码
#include <opencv2/line_descriptor.hpp>
#include <opencv2/opencv.hpp>

using namespace cv;
using namespace cv::line_descriptor;

int main()
{
    // 加载图像
    Mat image = imread( "/media/dingxin/data/study/OpenCV/sources/images/Lenna.png", IMREAD_GRAYSCALE );
    if ( image.empty() )
    {
        std::cerr << "无法加载图像!" << std::endl;
        return -1;
    }

    // 创建 LSDDetector
    Ptr< LSDDetector > lsd = LSDDetector::createLSDDetector();

    // 存储线段
    std::vector< KeyLine > keylines;

    // 设置参数
    int scale       = 2;  // 尺度
    int num_octaves = 1;  // 金字塔层数

    // 检测线段
    lsd->detect( image, keylines, scale, num_octaves );

    std::cout << "检测到线段数量: " << keylines.size() << std::endl;

    // 可视化线段
    Mat colorImage;
    cvtColor( image, colorImage, COLOR_GRAY2BGR );

    for ( const auto& kl : keylines )
    {
        Point pt1( kl.startPointX, kl.startPointY );
        Point pt2( kl.endPointX, kl.endPointY );
        line( colorImage, pt1, pt2, Scalar( 0, 0, 255 ), 1 );  // 红色线段
    }

    imshow( "Detected Lines", colorImage );
    waitKey( 0 );

    return 0;
}

运行结果

相关推荐
balmtv1 小时前
2026年多模态AI文件处理与联网搜索完全教程:国内镜像方案实测
人工智能
2501_926978331 小时前
AI的三次起落发展分析,及未来预测----理论5.0的应用
人工智能·经验分享·笔记·ai写作·agi
前网易架构师-高司机1 小时前
带标注的瓶盖识别数据集,识别率99.5%,可识别瓶盖,支持yolo,coco json,pascal voc xml格式
人工智能·yolo·数据集·瓶盖
软件供应链安全指南1 小时前
以AI治理AI|问境AIST首家通过信通院大模型安全扫描产品能力评估!
人工智能·安全·ai安全·问境aist·aist·智能体安全
_爱明1 小时前
CUDA索引越界问题(Compile with `TORCH_USE_CUDA_DSA` to enable device-side assertions)
人工智能·深度学习
这张生成的图像能检测吗2 小时前
(论文速读)TCN:序列建模不一定需要 RNN
人工智能·深度学习·transformer·卷积·时序预测
大师影视解说2 小时前
基于Web端的AI电影解说自动化生产工具实测:4步完成从文案到成片的全流程
运维·人工智能·自动化·影视解说·电影解说工具·网页版电影解说·ai电影解说
是大强2 小时前
GaN器件
人工智能·神经网络·生成对抗网络
美狐美颜sdk2 小时前
从人脸关键点到动态贴图:面具特效在美颜SDK中的实现原理
前端·图像处理·人工智能·直播美颜sdk·美颜api
威联通网络存储2 小时前
告别掉帧与素材损毁:威联通 QuTS hero 如何重塑影视后期协同工作流
前端·网络·人工智能·python