在opencv-rust中使用Canny边缘检测与轮廓绘制
2025-07-04 07:01:09作者:董宙帆
概述
本文将介绍如何在Rust中使用opencv-rust库实现Canny边缘检测算法,并将检测到的边缘轮廓绘制到原始图像上。Canny边缘检测是计算机视觉中常用的技术,能够有效地识别图像中的边缘信息。
实现步骤
1. 图像读取与预处理
首先需要读取原始彩色图像,然后将其转换为灰度图像。这是因为Canny边缘检测通常在单通道灰度图像上执行效果最佳。
let mut img: Mat = imgcodecs::imread(origin_path, imgcodecs::IMREAD_COLOR)?;
let mut gray: Mat = Mat::default();
cvt_color(&img, &mut gray, COLOR_BGR2GRAY, 0)?;
2. 应用Canny边缘检测
Canny算法需要设置两个阈值参数:
- 低阈值:用于边缘连接
- 高阈值:用于强边缘检测
- 孔径大小:Sobel算子的大小
let mut edges: Mat = Mat::default();
canny(&gray, &mut edges, 100.0, 200.0, 3, false)?;
3. 查找轮廓
检测到边缘后,使用find_contours函数查找图像中的轮廓。这里需要注意函数参数:
- RETR_EXTERNAL表示只检测最外层轮廓
- CHAIN_APPROX_SIMPLE压缩水平、垂直和对角线段,只保留端点
let mut contours = Vector::<Vector<Point>>::new();
find_contours(
&edges,
&mut contours,
RETR_EXTERNAL,
CHAIN_APPROX_SIMPLE,
Point::default(),
)?;
4. 绘制轮廓到原始图像
将检测到的轮廓绘制到原始彩色图像上,使用绿色线条表示边缘:
draw_contours(
&mut img,
&contours,
-1, // 绘制所有轮廓
Scalar::new(0.0, 255.0, 0.0, 0.0), // 绿色
1, // 线宽
LINE_8.into(),
&Mat::default(),
i32::MAX,
Point::default(),
)?;
5. 保存结果
最后将处理后的图像保存到指定路径:
imgcodecs::imwrite(destination_path, &img, &Vector::new())?;
参数调优建议
-
Canny阈值:100和200是常用起始值,可根据具体图像调整
- 高阈值太低会导致过多噪声
- 高阈值太高会丢失重要边缘
-
轮廓检测模式:
- RETR_EXTERNAL:仅最外层轮廓
- RETR_LIST:所有轮廓无层次结构
- RETR_TREE:完整层次结构
-
轮廓近似方法:
- CHAIN_APPROX_NONE:存储所有轮廓点
- CHAIN_APPROX_SIMPLE:压缩冗余点
性能优化
- 使用并行处理批量处理图像
- 对于大图像,可考虑降采样后再处理
- 合理设置Canny阈值减少后续处理数据量
应用场景
这种技术可用于:
- 图像特征提取
- 物体识别预处理
- 图像分割
- 工业检测中的缺陷识别
通过调整参数和后续处理,可以适应不同场景的需求。
登录后查看全文
热门项目推荐
相关项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
MiniMax-M2.7MiniMax-M2.7 是我们首个深度参与自身进化过程的模型。M2.7 具备构建复杂智能体应用框架的能力,能够借助智能体团队、复杂技能以及动态工具搜索,完成高度精细的生产力任务。Python00- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
HY-Embodied-0.5这是一套专为现实世界具身智能打造的基础模型。该系列模型采用创新的混合Transformer(Mixture-of-Transformers, MoT) 架构,通过潜在令牌实现模态特异性计算,显著提升了细粒度感知能力。Jinja00
LongCat-AudioDiT-1BLongCat-AudioDiT 是一款基于扩散模型的文本转语音(TTS)模型,代表了当前该领域的最高水平(SOTA),它直接在波形潜空间中进行操作。00
项目优选
收起
deepin linux kernel
C
28
15
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
660
4.26 K
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.54 K
894
Ascend Extension for PyTorch
Python
505
610
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
392
289
暂无简介
Dart
909
219
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21
昇腾LLM分布式训练框架
Python
142
168
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
940
867
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
1.33 K
108