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;
}

运行结果

相关推荐
Tiansan66661 天前
郑州AI问答服务商崛起:专业团队如何重塑企业客服
人工智能·郑州ai问答服务商崛
DeniuHe1 天前
sklearn 中所有交叉验证数据集划分方式完整总结
人工智能·python·sklearn
DeniuHe1 天前
sklearn中不同交叉验证方法的场景适配
人工智能·python·sklearn
小新同学^O^1 天前
简单学习 --> 指令微调
人工智能·学习·llm·指令微调
知识浅谈1 天前
Transformer 中的 Q、K、V 到底是什么?怎么理解 Query、Key、Value?
人工智能·深度学习·transformer
名不经传的养虾人1 天前
从0到1:企业级AI项目迭代日记 Vol.36|临时方案下线,网关区分负载,用量穿透链路——这一周全是“归位”
人工智能·ai编程·ai工作流·企业ai·多agent协作
小程故事多_801 天前
拆解Hermes Agent技术架构,会自我迭代的开源智能体如何突破AI传统局限
人工智能·架构·开源
黎阳之光1 天前
数智透明·安全兜底|黎阳之光透明矿山,AI+数字孪生守护矿山生命线
人工智能·物联网·算法·安全·数字孪生
Bigger1 天前
mini-cc 的 MCP 协议:给 AI 装个 USB-C 接口
人工智能·ai编程·claude
yubo05091 天前
计算机视觉第三课:在图像上画框、画文字、画圆点
opencv·计算机视觉·目标跟踪