OpenCV中数据类型cv::Vec3f

cv::Vec3f 是 OpenCV 提供的一个模板类,用于表示具有三个元素的向量,每个元素都是 float 类型。在图像处理和计算机视觉中,这种类型的向量通常用于表示颜色值(如 BGR 颜色空间中的一个像素点)、坐标点(例如圆的中心),或其他需要三个浮点数的数据。

cv::Vec3f 的使用

1. 表示圆的参数

在使用 cv::HoughCircles 函数检测圆时,cv::Vec3f 通常用来表示检测到的圆的参数:

  • cv::Vec3f 的第一个元素是圆心的 x 坐标。
  • 第二个元素是圆心的 y 坐标。
  • 第三个元素是圆的半径。
cpp 复制代码
std::vector<cv::Vec3f> circles;
cv::HoughCircles(edges, circles, cv::HOUGH_GRADIENT, 1, 20, 50, 30, 10, 100);

for (const auto& circle : circles) {
    cv::Point center(cvRound(circle[0]), cvRound(circle[1]));
    int radius = cvRound(circle[2]);
    // 处理检测到的圆
}
2. 表示颜色值

cv::Vec3f 也可以用来表示图像中的颜色值,尤其是当你需要浮点精度时。例如:

cpp 复制代码
cv::Vec3f color(0.0f, 255.0f, 0.0f); // 绿色(BGR格式)
3. 表示三维坐标

在一些计算机视觉应用中,cv::Vec3f 也可以用来表示三维坐标点:

cpp 复制代码
cv::Vec3f point3D(1.0f, 2.0f, 3.0f);

代码示例

以下是一个完整的 C++ 示例,展示了如何使用 cv::Vec3f 来检测圆并处理相关参数:

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

void detectCircles(const cv::Mat& edges) {
    std::vector<cv::Vec3f> circles;
    cv::HoughCircles(edges, circles, cv::HOUGH_GRADIENT, 1, 20, 50, 30, 10, 100);

    for (const auto& circle : circles) {
        // 圆的中心坐标
        cv::Point center(cvRound(circle[0]), cvRound(circle[1]));
        // 圆的半径
        int radius = cvRound(circle[2]);

        std::cout << "Circle detected at (" << center.x << ", " << center.y << ") with radius " << radius << std::endl;

        // 在图像上绘制圆
        cv::Mat img = cv::imread("clock.jpg");
        cv::circle(img, center, radius, cv::Scalar(0, 255, 0), 2); // 绘制圆
        cv::circle(img, center, 3, cv::Scalar(0, 0, 255), -1); // 绘制圆心

        // 显示图像
        cv::imshow("Detected Circles", img);
        cv::waitKey(0);
    }
}

int main() {
    cv::Mat img = cv::imread("clock.jpg");
    if (img.empty()) {
        std::cerr << "Error: Image not found!" << std::endl;
        return -1;
    }

    cv::Mat gray;
    cv::cvtColor(img, gray, cv::COLOR_BGR2GRAY);
    cv::Mat edges;
    cv::GaussianBlur(gray, gray, cv::Size(5, 5), 0);
    cv::Canny(gray, edges, 50, 150);

    detectCircles(edges);

    return 0;
}

代码解释

  1. 读取图像并转换为灰度图像:

    • cv::imread 读取图像文件。
    • cv::cvtColor 将图像转换为灰度图。
  2. 应用高斯滤波和边缘检测:

    • cv::GaussianBlur 去噪。
    • cv::Canny 边缘检测。
  3. 检测圆并绘制:

    • cv::HoughCircles 检测图像中的圆,返回圆的参数作为 cv::Vec3f 向量。
    • 遍历检测到的圆,使用 cv::circle 在图像上绘制圆和圆心。
  4. 显示图像:

    • 使用 cv::imshow 显示图像,cv::waitKey 等待用户按键。

通过理解和正确使用 cv::Vec3f,您可以在 OpenCV 中高效地处理和管理三维数据或颜色数据。

相关推荐
星越华夏6 小时前
计算机视觉:YOLOv12安装环境
人工智能·yolo·计算机视觉
Terrence Shen12 小时前
大模型部署工具对比
人工智能·深度学习·计算机视觉
AI算法沐枫14 小时前
大模型 | 大模型之机器学习基本理论
人工智能·python·神经网络·学习·算法·机器学习·计算机视觉
埃菲尔铁塔_CV算法15 小时前
YOLO11 与传统纹理特征融合目标检测 完整实现教程
人工智能·神经网络·yolo·计算机视觉
松☆16 小时前
ops-transformer:FlashAttention算子深度实践
人工智能·计算机视觉·目标跟踪
普密斯科技17 小时前
在线图像测量仪实战案例:医疗西林瓶尺寸检测的精准解决方案
大数据·人工智能·计算机视觉·健康医疗·测量
AI人工智能+17 小时前
不动产权证书识别技术:融合了计算机视觉、自然语言处理(NLP)和人工智能的深度技术栈
人工智能·计算机视觉·语言模型·ocr·不动产权证书识别
Hua-Jay19 小时前
OpenCV联合C++/Qt 学习笔记(二十二)----相机模型与投影及单目相机标定
c++·笔记·qt·opencv·学习·计算机视觉
凌峰的博客19 小时前
T2SMark:在扩散模型噪声水印中寻找鲁棒性与多样性的平衡
人工智能·深度学习·计算机视觉
小白|20 小时前
CANN目标检测实战:自定义检测算子开发(插件机制)
人工智能·目标检测·计算机视觉