c++ opencv将彩色图像按连通域区分

要将彩色图像按连通域区分,您可以使用 OpenCV 中的 cv::connectedComponents 函数。

下面是一个简单的示例代码,说明如何使用 cv::connectedComponents 函数来检测并标记图像中的连通域:

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

int main()
{
    // 读取彩色图像
    cv::Mat image = cv::imread("image.jpg");

    // 将图像转换为灰度
    cv::Mat grayImage;
    cv::cvtColor(image, grayImage, cv::COLOR_BGR2GRAY);

    // 使用二值化将图像转换为二进制图像
    cv::Mat binaryImage;
    cv::threshold(grayImage, binaryImage, 0, 255, cv::THRESH_BINARY_INV | cv::THRESH_OTSU);

    // 定义连通域标记图像
    cv::Mat labels;

    // 应用连通域检测算法
    int numLabels = cv::connectedComponents(binaryImage, labels);

    // 创建随机颜色向量,用于绘制每个连通域
    std::vector<cv::Vec3b> colors(numLabels);
    colors[0] = cv::Vec3b(0, 0, 0); // 背景设置为黑色

    for (int i = 1; i < numLabels; i++)
    {
        colors[i] = cv::Vec3b(rand() % 256, rand() % 256, rand() % 256);
    }

    // 将每个连通域根据其标签值着色
    cv::Mat connectedComponentsImage(image.size(), CV_8UC3);
    for (int y = 0; y < image.rows; y++)
    {
        for (int x = 0; x < image.cols; x++)
        {
            int label = labels.at<int>(y, x);
            cv::Vec3b &color = connectedComponentsImage.at<cv::Vec3b>(y, x);

            color = colors[label];
        }
    }

    // 显示原始图像和标记的连通域图像
    cv::imshow("Original Image", image);
    cv::imshow("Connected Components", connectedComponentsImage);
    cv::waitKey(0);

    return 0;
}

这段代码首先读取彩色图像,然后将其转换为灰度图像。接下来,使用 cv::threshold 函数将灰度图像二值化,生成二进制图像。然后,使用 cv::connectedComponents 函数应用连通域检测算法。最后,根据每个连通域的标签值,使用随机颜色向量对每个连通域进行着色。最后,将原始图像和标记的连通域图像显示出来。

您可以根据您的需求修改此示例代码。

8/29/2023, 2:06:42 PM

相关推荐
AI视觉网奇6 小时前
Fatal signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr
开发语言·c++·算法
智者知已应修善业6 小时前
【输入两个数字,判断两数相乘是否等于各自逆序数相乘】2023-10-24
c语言·c++·经验分享·笔记·算法·1024程序员节
oioihoii6 小时前
C++11到C++23语法糖万字详解
java·c++·c++23
比昨天多敲两行6 小时前
C++入门基础
开发语言·c++
集3046 小时前
C++多线程学习笔记
c++·笔记·学习
ComputerInBook6 小时前
C++编程语言:标准库:第39章——本地化(语言环境)( Locales)(Bjarne Stroustrup)
c++·c++语言环境·c++ 本地化设置·c++ locale·c++ facet·语言特征
懷淰メ7 小时前
【AI加持】基于PyQt5+YOLOv8+DeepSeek的水体污染检测系统(详细介绍)
yolo·目标检测·计算机视觉·pyqt·检测系统·deepseek·水体污染
繁华似锦respect8 小时前
C++ 智能指针底层实现深度解析
linux·开发语言·c++·设计模式·代理模式
AI即插即用8 小时前
即插即用系列 | CVPR SwiftFormer:移动端推理新王者!0.8ms 延迟下 ImageNet 78.5% 准确率,吊打 MobileViT
图像处理·人工智能·深度学习·目标检测·计算机视觉·cnn·视觉检测
Bona Sun9 小时前
单片机手搓掌上游戏机(二十三)—esp32运行简单街机模拟器软硬件准备
c语言·c++·单片机