opencv 轮廓区域检测

直线检测

void LineDetect(const cv::Mat &binaryImage)
{
    cv::Mat xImage,yImage,binaryImage1,binaryImage2;
    // 形态学变化,闭操作  先膨胀,再腐蚀 可以填充小洞,填充小的噪点
    cv::Mat element = cv::getStructuringElement(cv::MORPH_RECT, cv::Size(15, 3)); 
    morphologyEx(binaryImage, binaryImage1, cv::MORPH_CLOSE, element);
    cv::imwrite("close1.jpg",binaryImage1);
    cv::Sobel(binaryImage1, xImage, CV_8U, 1, 0);

    element = cv::getStructuringElement(cv::MORPH_RECT, cv::Size(3, 15)); 
    morphologyEx(binaryImage1, binaryImage2, cv::MORPH_CLOSE, element);
    cv::imwrite("close2.jpg",binaryImage2);
    cv::Sobel(binaryImage2, yImage, CV_8U, 0, 1);

    vector<cv::Vec4i> lines;
    cv::HoughLinesP(xImage,lines, 1, CV_PI / 180, 10,100,50);
    for (size_t i = 0; i < lines.size(); i++)
    {
        cv::Vec4i l = lines[i];
        line(xImage, cv::Point(l[0], l[1]), cv::Point(l[2], l[3]), cv::Scalar(255), 3, cv::LINE_AA);
    }
    // drawLine(xImage, lines, xImage.rows, xImage.cols, cv::Scalar(255),1);

    cv::imwrite("xImage.jpg",xImage);
    cv::imwrite("yImage.jpg",yImage);
}

轮廓检测

void ContourDetect(const cv::Mat &binaryImage,vector<vector<cv::Point>> &contours)
{
    int closeSize = 25;
    float areaRatio = 0.005;
    int imgArea = binaryImage.cols * binaryImage.rows;
    cv::Mat closeImg;
    // 形态学变化,闭操作  先膨胀,再腐蚀 可以填充小洞,填充小的噪点
    cv::Mat element = cv::getStructuringElement(cv::MORPH_RECT, cv::Size(closeSize, closeSize));
    morphologyEx(binaryImage, closeImg, cv::MORPH_CLOSE, element);
    cv::imwrite("closeImg.jpg",closeImg);

    cv::Mat edges_image;
    // 应用Canny边缘检测算法
    Canny(closeImg, edges_image, 100, 200);
    cv::imwrite("edges_image.jpg",edges_image);

    // 寻找轮廓
    vector<vector<cv::Point>> allContours;
    cv::findContours(edges_image, allContours, cv::RETR_EXTERNAL, cv::CHAIN_APPROX_SIMPLE);
    cout << "allContours size is: " <<allContours.size()<< endl;
    // 轮廓过滤
    for (auto contour:allContours)
    {
        cv::Rect rect = cv::boundingRect(contour);
        // cout << rect.area()  <<" "<< imgArea * areaRatio <<endl;
        if (rect.area() > imgArea * areaRatio)
        {
            contours.push_back(contour);
        }
    }

    // 绘制轮廓
    cv::Mat contourImg = cv::Mat::zeros(binaryImage.size(), binaryImage.type());
    cout << "contours size is: " <<contours.size()<< endl;
    for (int i = 0; i < contours.size(); i++)
    {
        cv::drawContours(contourImg, contours, i, cv::Scalar(255), 2);
    }
    cv::imwrite("contours.jpg", contourImg);
}

连通区域检测

void ConnectedComponentRect(const cv::Mat &binaryImage,vector<cv::Rect> &rects)
{
    int closeSize = 25;
    float areaRatio = 0.001;
    int imgArea = binaryImage.cols * binaryImage.rows;
    cv::Mat closeImg;
    // 形态学变化,闭操作  先膨胀,再腐蚀 可以填充小洞,填充小的噪点
    cv::Mat element = cv::getStructuringElement(cv::MORPH_RECT, cv::Size(closeSize, closeSize));
    morphologyEx(binaryImage, closeImg, cv::MORPH_CLOSE, element);
    cv::imwrite("closeImg.jpg",closeImg);

    cv::Mat labels, stats, centroids;
    int num_objects = cv::connectedComponentsWithStats(closeImg, labels, stats, centroids);

    for (int i = 1; i < num_objects; i++) {
        // 获取连通组件的统计信息
        int* stat = stats.ptr<int>(i);
        int left = stat[cv::CC_STAT_LEFT];
        int top = stat[cv::CC_STAT_TOP];
        int width = stat[cv::CC_STAT_WIDTH];
        int height = stat[cv::CC_STAT_HEIGHT];
        int area = stat[cv::CC_STAT_AREA];
        if (area > imgArea * areaRatio)
        {
            rects.push_back(cv::Rect(left, top, width, height));
        }
    }
    cout << num_objects << " rect size is:"<< rects.size() <<endl;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/602313.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

idea配置hive

idea配置hive 今天才知道&#xff0c;idea居然可以配置hive&#xff0c;步骤如下: view -> Tool Windows -> Database Database出来了之后&#xff0c;直接配置即可

STM32快速入门(定时器之输入捕获)

STM32快速入门&#xff08;定时器之输入捕获&#xff09; 前言 本节主要讲解STM32利用通用定时器&#xff0c;在输入引脚出现指定电平跳变时&#xff0c;将CNT的值锁存到CCR寄存器当中&#xff0c;从而计算PWM波形的频率、占空比、脉冲间隔、电平持续时间等。其功能的应用有&…

[C++基础编程]----预处理指令简介、typedef关键字和#define预处理指令之间的区别

目录 引言 正文 01-预处理指令简介 02-typedef关键字简介 03-#define预处理指令简介 04-#define预处理指令和typedef关键字的区别 &#xff08;1&#xff09;原理不同 &#xff08;2&#xff09;功能不同 &#xf…

【YOLOv8改进[Backbone]】使用SCINet改进YOLOv8在黑暗环境的目标检测效果

目录 一 SCINet 1 本文方法 ① 权重共享的照明学习 ② 自校准模块 ③ 无监督训练损失 二 使用SCINet助力YOLOv8在黑暗环境的目标检测效果 1 整体修改 2 配置文件 3 训练 其他 一 SCINet 官方论文地址&#xff1a;https://arxiv.org/pdf/2204.10137 官方代码地址&…

26_Scala集合常用API汇总

文章目录 1.mkString2.size&#xff0c;length&#xff0c;isEmpty,contains3.reverse ,length,distinct4.获取数据相关4.1数据准备4.2准确获取尾部last4.3 除了最后一个元素不要其他都要4.4从集合获取部分数据 5.删除数据5.1删除3个从左边5.2删除3个右边 6.切分数据splitAt(n:…

解决“您的连接不是私密连接”

目录 那么为什么会出现这样提示呢 https访问有什么不同 将http访问更改为https访问 当您在浏览网页时&#xff0c;遇到“您的连接不是私密连接”的提示&#xff0c;这通常表示浏览器认为您的连接不够安全。这是因为浏览器无法信任网站使用的SSL证书&#xff0c;或者网站没有…

【系统架构师】-UML-用例图(Use Case)

1、概述 用于表示系统功能需求&#xff0c;以及应用程序与用户或者与其他应用程序之间的交互关系。 2、组成 参与者&#xff08;Actors&#xff09;&#xff1a;与系统交互的用户或其他系统。用一个人形图标表示。用例&#xff08;Use Cases&#xff09;&#xff1a;系统需要…

平滑矢量图形综述:表示、创建、光栅化和图像矢量化的最新进展

摘要 平滑矢量图形领域探索了轻量级图像表示的表示、创建、光栅化和自动生成&#xff0c;常用于可缩放图像内容。过去几十年中&#xff0c;出现了多种概念性方法来表示具有平滑渐变的图像&#xff0c;每种方法都引发了独立的研究线索&#xff0c;包括流行的梯度网格和扩散曲线…

工程技术SCI期刊,中科院三区,一投就中,国人友刊!

一、期刊名称 Industrial Management & Data Systems 二、期刊简介概况 期刊类型&#xff1a;SCI 学科领域&#xff1a;工程技术 影响因子&#xff1a;5.5 中科院分区&#xff1a;3区 出版方式&#xff1a;订阅模式/开放出版 版面费&#xff1a;$4120 三、期刊征稿范…

QT功能 实现静态内容国际化实验

文章目录 第一步&#xff1a;新建一个QT工程第二步&#xff1a;添加控件第三步&#xff1a;在pro文件中添加内容第四步&#xff1a;更新文件第五步&#xff1a;打开QT的Linguist第六步&#xff1a;添加翻译内容第七步&#xff1a;回到QT Creator中添加文件第八步&#xff1a;给…

Colibri for Mac v2.2.0激活版:专业级无损音乐播放器

Colibri for Mac是一款专为Mac用户设计的高分辨率无损音乐播放器。它基于BASS技术构建&#xff0c;为用户带来极致的音频体验。Colibri支持所有流行的无损和有损音频格式&#xff0c;如FLAC、MP3、AAC等&#xff0c;确保音乐播放的清晰度和完美度。其独特的清晰比特完美播放技术…

月均互动超50万!“仪式感”何以盛行?小红书数据分析揭示消费动力

现代年轻人&#xff1a;“赚不到钱&#xff0c;却爱花钱买仪式感”。审慎消费的当下&#xff0c;“仪式感消费”不减反增&#xff0c;小红书平台相关内容更是持续火爆&#xff0c;成为品牌圈粉消费者的关键词。 这届小红书用户&#xff0c;热衷为“仪式感”氪金 “XX的第一杯奶…

【mysql】mysql单表查询、多表查询、分组查询、子查询等案例详细解析

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…

常用的外贸软件有哪些

常用的外贸软件涵盖了多个方面&#xff0c;包括客户开发、订单管理、库存控制、客户关系管理(CRM)、财务管理以及跨境电商平台等。以下是一些代表性的外贸软件和平台&#xff1a; 客户开发与营销软件: 大镜山谷歌搜索大师易谷歌地图数据采集大师米贸搜 外贸管理软件 (ERP): 神卓…

【Kali Linux工具篇】使用Aircrack-ng破解wifi密码

前期准备 1、一个无线网卡 2、密钥爆破字典 实站过程 1、设置wlan为监听模式 airmon-ng start wlan0 #开启网卡wlan0监听模式 iwconfig #查看网卡状态&#xff0c;发现wlan0mon&#xff0c;表示已开启成功2、探测附近WiFi airdump-ng wlan0monBSSID 代表…

零售全渠道营销业务链分析,让企业管控能力大幅加强!

对于传统的、规模化的零售快消企业来讲&#xff0c;面临着很大的渠道管理和建设问题&#xff0c;如何尽快实现整个营销体系的全渠道数字化转型是当务之急、重中之重。 面对错综分散的经销商&#xff0c;零售快消企业订货流程会越复杂&#xff0c;加之对门店管理较为粗放&#…

技术速递|Java on VS Code 3月更新 - 大量 Spring 新功能!测试覆盖率功能正式发布!​

作者&#xff1a;Nick Zhu 排版&#xff1a;Alan Wang 大家好&#xff0c;欢迎来到2024年3月的 Visual Studio Code Java 更新&#xff01;在本篇博客中&#xff0c;我们将分享大量 Spring 有关的新功能以及测试覆盖率的更新&#xff0c;让我们开始吧&#xff01; Spring Boot…

【网络】网络层ICMP协议

&#x1f984; 个人主页——&#x1f390;开着拖拉机回家_Linux,大数据运维-CSDN博客 &#x1f390;✨&#x1f341; &#x1fa81;&#x1f341;&#x1fa81;&#x1f341;&#x1fa81;&#x1f341;&#x1fa81;&#x1f341; &#x1fa81;&#x1f341;&#x1fa81;&am…

新建的springBoot WEB项目无法自动返回html模版(gradle+kotlin版本)

最近研究了springBoot创建web项目&#xff0c; 第一步服务端返回字符串没有问题&#xff0c;第二步返回html时&#xff0c;还是返回的字符串。 文章目录 一、参考方案二、新建springBoot web项目三、启动项目的三种方式 一、参考方案 将控制器类的 RestController 改为 Contro…

【JavaWeb】网上蛋糕商城后台-订单管理

概念 前面通过多篇文章以完全实现了用户在网上蛋糕商城平台上的所有功能和操作&#xff0c;从本文开始&#xff0c;实现网站的后台管理功能的介绍和操作。 订单列表 想要进入后台管理系统&#xff0c;则登入的用户一定是管理员账号&#xff0c;这个账号和密码只有管理员才知…
最新文章