ROS机械臂——ROS结合OpenCV案例(含资源)

纲要

摄像头驱动

图像属性

图像压缩

### Realsense摄像头

点云展示

### 点云图像属性
## 摄像头标定

摄像头标定流程

如何使用标定文件

OpenCV

ROS与OpenCV的集成框架

!在这里插入图片描述(https://i-blog.csdnimg.cn/direct/b0ff143b710543839325d19c7a3c04c5.png

ROS+OpenCV 图像绘制(cpp)

cpp 复制代码
#include <ros/ros.h>
#include <image_transport/image_transport.h>
#include <sensor_msgs/image_encodings.h>
#include <cv_bridge/cv_bridge.h>
#include <opencv2/imgproc/imgproc.hpp>
#include <opencv2/highgui/highgui.hpp>

static const std::string OPENCV_WINDOW = "image_window";
 
class ImageConverter{
     ros::NodeHandle nh;
     image_transport::ImageTransport it;
     image_transport::Subscriber image_sub;
     image_transport::Publisher image_pub;

     public:
       ImageConverter()
       :it(nh){
             //订阅图像输入流 、发布图像输出流(话题名称,处理队列的大小为1,回调函数的名称,回调函数所处的类)
             image_sub = it.subscribe("/usb_cam/image_raw",1,&ImageConverter::imageCb,this);
             image_pub = it.advertise("cv_bridge_image",1);

             cv::namedWindow(OPENCV_WINDOW);
       }

    ~ImageConverter(){
           cv::destroyWindow(OPENCV_WINDOW);
    }

      void imageCb(const sensor_msgs::ImageConstPtr& msg){
          //msg为图像信息在ROS中的地址
           cv_bridge::CvImagePtr cv_ptr;

           try{
            //创建一个图像数据的拷贝
            //toCvCopy复制数据并返回复制数据地址指针cv_bridge::CvImagePtr
            //将ROS图像消息转换为了CvImage以在OpenCV中使用
            //sensor_msgs::image_encodings::BGR8是"bgr8"字符串常量。
               cv_ptr = cv_bridge::toCvCopy(msg,sensor_msgs::image_encodings::BGR8);
           }
           catch (cv_bridge::Exception& e){
                ROS_ERROR("cv_bridge exception: %s",e.what());
                return;
           }
       
       //在opencv窗口画红圈
       if(cv_ptr->image.rows > 60 && cv_ptr->image.cols > 60)
            cv::circle(cv_ptr->image,cv::Point(50,50) , 10 , CV_RGB(255,0,0));

       //生成opencv窗口
       cv::imshow(OPENCV_WINDOW,cv_ptr->image);
       cv::waitKey(3);

       //将opencv生成的话题信息,转换为Image图像信息,通过iamge_pub发布出去,可以通过rqt_image_view订阅话题,查看opencv生成的红圈
       image_pub.publish(cv_ptr->toImageMsg());    
    }
};

int main(int argc,char ** argv){
     ros::init(argc,argv,"image_converter");
     ImageConverter ic;
     ros::spin();
     return 0;

}

ROS+OpenCV 图像绘制(python)

python 复制代码
#!/usr/bin/env python
# -*- coding: utf-8 -*-

import rospy
import cv2
from cv_bridge import CvBridge, CvBridgeError
from sensor_msgs.msg import Image

class image_converter:
    def __init__(self):    
        # 创建cv_bridge,声明图像的发布者和订阅者
        self.image_pub = rospy.Publisher("cv_bridge_image", Image, queue_size=1)
        self.bridge = CvBridge()
        self.image_sub = rospy.Subscriber("/usb_cam/image_raw", Image, self.callback)

    def callback(self,data):
        # 使用cv_bridge将ROS的图像数据转换成OpenCV的图像格式
        try:
            cv_image = self.bridge.imgmsg_to_cv2(data, "bgr8")
        except CvBridgeError as e:
            print e

        # 在opencv的显示窗口中绘制一个圆,作为标记
        (rows,cols,channels) = cv_image.shape
        if cols > 60 and rows > 60 :
            cv2.circle(cv_image, (60, 60), 30, (0,0,255), -1)

        # 显示Opencv格式的图像
        cv2.imshow("Image window", cv_image)
        cv2.waitKey(3)

        # 再将opencv格式额数据转换成ros image格式的数据发布
        try:
            self.image_pub.publish(self.bridge.cv2_to_imgmsg(cv_image, "bgr8"))
        except CvBridgeError as e:
            print e

if __name__ == '__main__':
    try:
        # 初始化ros节点
        rospy.init_node("cv_bridge_test")
        rospy.loginfo("Starting cv_bridge_test node")
        image_converter()
        rospy.spin()
    except KeyboardInterrupt:
        print "Shutting down cv_bridge_test node."
        cv2.destroyAllWindows()

ROS+OpenCV物体识别

源码

get2DLocation():获取桌面以及桌面物体的坐标

设置红色、绿色通道,通过像素点灰度值判断出黑色桌子的具体位置,将黑色像素点具体位置的二进制数值设置为255,非黑设置为0,计算出桌子中心点,最后将非0点画上方框
找红点、画蓝框

识别绿色圆柱(contours:轮廓)


分析


结果

小结

相关推荐
兵慌码乱5 天前
基于 MediaPipe 与 PySide2 的手势交互音乐控制系统实现:轻量化视觉交互全流程解析
python·opencv·计算机视觉·人机交互·手势识别·mediapipe·pyside2
小小杨树7 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
H__Rick9 天前
自动对焦学习-3
人工智能·学习·计算机视觉
计算机科研狗@OUC9 天前
(cvpr26) AIMDepth: Asymmetric Image-Event Mamba for Monocular Depth Estimation
人工智能·深度学习·计算机视觉
qq_366566509 天前
2026最新:5款AI视频口型同步工具实测横评,视频翻译后嘴型对不上的终极解决方案
人工智能·计算机视觉·新媒体运营
梦想三三9 天前
OpenCV银行卡数字识别项目(图像预处理与字符分割)
人工智能·opencv·计算机视觉
kaikaile19959 天前
图像稀疏化分解 + 压缩感知(CS)重建 MATLAB
开发语言·计算机视觉·matlab
武子康9 天前
调查研究-180 roboflow/supervision:计算机视觉工程里的“胶水层“,为什么值得关注?
人工智能·opencv·计算机视觉·chatgpt·llm·向量化
YOLO数据集集合9 天前
无人机风电设备智能巡检 风机叶片缺陷目标检测数据集实战 | 表面腐蚀漏油识别 工业视觉质检 深度学习模型训练落地10337期
人工智能·深度学习·目标检测·计算机视觉·无人机