ROS OpenCV 图像基本处理函数

这篇具有很好参考价值的文章主要介绍了ROS OpenCV 图像基本处理函数。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

在ROS中结合OpenCV使用时,cv::imread() 函数并非ROS本身的API,而是来自OpenCV库的函数,用于读取本地磁盘上的图像文件。

其用法如下:

cv::Mat cv::imread(const string& filename, int flags = IMREAD_COLOR);

参数说明:

    filename:字符串类型,表示要读取的图像文件的完整路径和名称。

    flags:整型变量,定义了读取图像的方式,可选值包括:

        IMREAD_UNCHANGED 或 -1:加载图像,包括alpha通道(如果存在)。

        IMREAD_GRAYSCALE 或 0:以灰度模式加载图像。

        IMREAD_COLOR 或 1:默认选项,以彩色模式加载图像(如果是彩色图像)。

        IMREAD_ANYDEPTH:加载任意深度图像作为单通道图像。

        IMREAD_ANYCOLOR:加载任何颜色空间的图像。

可以将上述标志进行组合,例如 IMREAD_GRAYSCALE | IMREAD_ANYDEPTH 将加载一个可能包含高动态范围数据的灰度图像。

返回值:

cv::Mat 类型的对象,代表所读取的图像数据。如果没有成功读取图像,则返回一个空矩阵(即 .empty() 返回 true)。

彩色图像使用 OpenCV 加载时是 BGR 模式。

示例代码:

#include <opencv2/opencv.hpp>

#include <ros/ros.h>

int main(int argc, char** argv)

{

    ros::init(argc, argv, "image_reader");

    ros::NodeHandle nh;

    // 读取图像文件

    cv::Mat image = cv::imread("/home/user/path/to/image.jpg", cv::IMREAD_COLOR);

    if (image.empty())

    {

        ROS_ERROR("Could not read the image file.");

        return -1;

    }

    // 显示图像

    cv::imshow("Image Window", image);

    cv::waitKey(0); // 等待用户按键,窗口才会关闭

    return 0;

}

在ROS环境下,通常会结合cv_bridge来处理ROS Image消息OpenCV Mat之间的转换,而不仅仅是读取本地文件。如果是在ROS节点内部操作摄像头获取的图像,那么需要从ROS话题订阅图像数据,并通过cv_bridge的imgmsg_to_cv2()函数将其转换为OpenCV可以处理的cv::Mat格式。

cv::imwrite() 函数同样是来自OpenCV库的函数,用于将图像数据保存到本地磁盘上的文件。可以使用这个函数来保存摄像头捕获的图像或者处理后的图像。使用函数 cv2.imwrite() 来保存一个图像。(首先需要一个文件名,之后才是要保存的图像。)

其用法如下:

cv::imwrite(const string& filename, InputArray img, const std::vector<int>& params = std::vector<int>());

参数说明:

    filename:字符串类型,表示要写入图像文件的完整路径和名称,包括扩展名,根据扩展名来确定输出图像的格式。

    img:cv::Mat 类型的对象或其他符合 InputArray 类型要求的图像数据结构,这是要保存的图像内容。

    params:可选参数,一个整数类型的向量,用于指定编码器特定的参数或选项。可选参数,用于指定图像压缩编码格式和压缩级别。

例如,在写入JPEG格式图像时可以设置压缩质量等。如果不需要特殊设置,则可以不提供此参数,此时默认为一个空的整数向量。

示例代码:

#include <iostream>

#include <opencv2/opencv.hpp>

int main()

{

    // 读取图像

    cv::Mat img = cv::imread("input.jpg");

    if (img.empty())

    {

        std::cout << "无法读取图像" << std::endl;

        return -1;

    }

    // 保存图像

    bool result = cv::imwrite("output.jpg", img);

    if (result)

    {

        std::cout << "图像保存成功" << std::endl;

    }

    else

    {

        std::cout << "图像保存失败" << std::endl;

    }

    return 0;

}

imshow()函数用于在窗口中显示图像。(窗口会自动调整为图像大小。第一个参数是窗口的名字,其次才是需要的图像。)

其用法如下:

void imshow(const String& winname, const Mat& image);  

参数说明:

winname:字符串类型,表示要显示图像的窗口名称。如果该窗口尚不存在,则会创建一个新的窗口。    

image:要显示的图像,通常是一个Mat对象。

示例代码:

#include <opencv2/opencv.hpp>

#include <iostream>

using namespace cv;

using namespace std;

int main()

{

    // 读取图像

    Mat image = imread("example.jpg");

    // 检查图像是否正确读取

    if (image.empty())

    {

        cout << "无法读取图像" << endl;

        return -1;

    }

    // 创建一个名为"Example Image"的窗口

    namedWindow("Example Image", WINDOW_AUTOSIZE);

    // 在窗口中显示图像

    imshow("Example Image", image);

    // 等待按键,然后关闭窗口

    waitKey(0);

    destroyAllWindows();

    return 0;

}

在这个示例中,首先包含了必要的头文件,然后定义了一个名为main的函数。在main函数中,使用imread函数读取了一张名为example.jpg的图像,并将其存储在Mat对象image中。

然后,使用namedWindow函数创建一个名为"Example Image"的窗口,并设置窗口大小自动调整。最后,使用imshow函数在窗口中显示图像,并使用waitKey(0)等待用户按下任意键,然后使用destroyAllWindows()关闭所有打开的窗口。

补充:cv2.waitKey() 是一个键盘绑定函数。需要指出的是它的时间尺度是毫秒级。函数等待特定的几毫秒,看是否有键盘输入。特定的几毫秒之内,如果按下任意键,这个函数会返回按键的 ASCII 码值,程序将会继续运行。如果没有键盘输入,返回值为 -1,如果我们设置这个函数的参数为 0,那它将会无限期的等待键盘输入。

cv2.destroyAllWindows() 可以轻易删除任何建立的窗口。如果想删除特定的窗口可以使用 cv2.destroyWindow(),在括号内输入想删除的窗口名。文章来源地址https://www.toymoban.com/news/detail-785530.html

到了这里,关于ROS OpenCV 图像基本处理函数的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • OpenCV(二)——图像基本处理(三)

    目录  3.图像滤波与增强 3.1线性滤波 3.2 非线性滤波 3.3 图像锐化 3.4 直方图均衡化

    2024年02月12日
    浏览(26)
  • OpenCV基本图像处理操作(十)——图像特征harris角点

    角点 角点是图像中的一个特征点,指的是两条边缘交叉的点,这样的点在图像中通常表示一个显著的几角。在计算机视觉和图像处理中,角点是重要的特征,因为它们通常是图像中信息丰富的区域,可以用于图像分析、对象识别、3D建模等多种应用。 角点的识别可以帮助在进

    2024年04月23日
    浏览(35)
  • OpenCV基本图像处理操作(一)——图像基本操作与形态学操作

    图像显示 转hsv图像 颜色表示为三个组成部分:色调(Hue)、饱和度(Saturation)和亮度(Value)。常用于图像处理中,因为它允许调整颜色的感知特性,如色彩和亮度,这些在RGB颜色模型中不那么直观。 HSV模型特别适用于任务如图像分割和对象追踪,因为它可以更好地处理光

    2024年04月22日
    浏览(37)
  • Python|OpenCV-基本使用和图像处理(1)

    前言 本文是该专栏的第1篇,后面将持续分享OpenCV计算机视觉的干货知识,记得关注。 OpenCV是基于开源许可的跨平台计算机 视觉库 ,起初OpenCV是由Intel公司开发的,直到后面由非营利组织进行维护。提到OpenCV,就不得不说它提供了大量的图像和视频处理函数,使得计算机视觉

    2024年02月12日
    浏览(37)
  • 【opencv+图像处理】Image Processing in OpenCV 1-2基本图形绘制

    🍉 博主微信 cvxiayixiao 🍓 【Segment Anything Model】计算机视觉检测分割任务专栏。 链接 🍑 【公开数据集预处理】特别是医疗公开数据集的接受和预处理,提供代码讲解。链接 🍈 【opencv+图像处理】opencv代码库讲解,结合图像处理知识,不仅仅是调库。链接 本专栏代码地址

    2024年02月08日
    浏览(32)
  • opencv 图像和视频处理的基本操作(python)

    原图:   1 图片的获取 主要通过cv2.imread(src)函数进行获取 2 图片的显示 3 ROI区域(图片截取) 4 图片的RGB通道划分 注意cv2.imread()获取的图片通过顺序为BGR,而非RGB,即B为0,G为1,R为2  保留R通道  保留G通道   保留B通道   5 RGB通道合成   6 边界填充 主要是通过cv2.copyMakeBo

    2023年04月21日
    浏览(39)
  • OpenCV图像预处理常用函数及流程

    在PyCharm终端中,运行如下命令 由于默认使用的为外网资源,下载速度和稳定性较差,具体看网络状态。如下命令为使用清华镜像下载安装相应的包 在终端中运行命令时,Windows10系统可能会存在如下报错:无法加载激活文件,因此在此系统上禁止运行脚本。此情况是因为win

    2024年02月05日
    浏览(41)
  • OpenCV(图像处理)-基于Python-图像的基本变换-平移-翻转-仿射变换-透视变换

    为了方便开发人员的操作,OpenCV还提供了一些图像变换的API,本篇文章讲简单介绍各种API的使用,并附上一些样例。 图像缩放函数,用于把图像按指定的尺寸放大或缩小。 dst = cv2.resize(src, dsize, fx, fy, interpolation) dst = 生成的目的图像 src:需要变换的原图像 disize:(x, y)需要

    2024年02月08日
    浏览(42)
  • Python 基于 OpenCV 视觉图像处理实战 之 图像相关的基本概念,以及图像的基础操作 一

    目录 Python 基于 OpenCV 视觉图像处理实战 之 图像相关的基本概念,以及图像的基础操作 一 一、简单介绍 二、图像相关的一些基本概念 1、像素 2、图像的构成 3、图像的格式 4、图像的位深和通道 三、OpenCV 的一些基本图像处理函数介绍 1、读取一幅画图像 2、显示图像 3、输出

    2024年04月11日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包