基于ROS利用客户端和服务端实现C++节点和python节点间传送图像

基于ROS利用客户端和服务端实现C++节点和python节点间传送图像

配置ROS下和python3通信以及配置python3可用的cv_bridge

  • 环境安装和使用

参考:https://blog.csdn.net/qq_33445388/article/details/116034290

sudo apt-get install ros-melodic-cv-bridge python-catkin-tools python3-dev python3-catkin-pkg-modules python3-numpy python3-yaml 

在需要用到的cv_bridge工作空间内(将vision_opencv作为另一package了)

 git clone https://github.com/ros-perception/vision_opencv.git src/vision_opencv
 apt-cache show ros-melodic-cv-bridge | grep Version
 cd src/vision_opencv/
 git checkout 1.13.0
 cd ../../

指示catkin将内置包安装到安装位置,

catkin config --install
catkin build cv_bridge

需要使用cv_bridge的时候 source install/setup.bash --extend 即可自己建立的其他功能包正常catkin_make
例如, catkin_make -DCATKIN_WHITELIST_PACKAGES=service_example -DPYTHON_EXECUTABLE=/usr/bin/python3
指定编译有改动的某一package,以及和python3通信时用-DPYTHON_EXECUTABLE=/usr/bin/python3

  • cv_bridge传递ROS下的图像消息在python和C++中的使用

C++
cv::Mat---->cv_bridge::CvImagePtr---->sensor_msgs::Image

  sensor_msgs::ImagePtr msgLeft;
    msgLeft = cv_bridge::CvImage(std_msgs::Header(), "rgb8",imLeft ).toImageMsg();
    srv.request.src=*msgLeft;

sensor_msgs::Image---->cv_bridge::CvImagePtr---->cv::Mat

sensor_msgs::Image msg=srv.response.dit;#request.dit是sensor_msgs::Image格式
cv_bridge::CvImagePtr cv_ptr = cv_bridge::toCvCopy(msg,  "rgb8"); 
cv::Mat imResponse= cv_ptr->image;

python
sensor_msgs::Image----->cv2能处理的格式

   cv_img = bridge.imgmsg_to_cv2(request.src, "rgb8")#request.src是sensor_msgs::Image格式
    # cv2.imshow("frame" , cv_img)
    # cv2.waitKey(1)
    im= cv2.resize(cv_img, (400, 400))

cv2能处理的格式----->sensor_msgs::Image

  response.dit=bridge.cv2_to_imgmsg(im, "rgb8")

cv_bridge编码信息
mono8: CV_8UC1, grayscale image
mono16: CV_16UC1, 16-bit grayscale image
bgr8: CV_8UC3, color image with blue-green-red color order
rgb8: CV_8UC3, color image with red-green-blue color order
bgra8: CV_8UC4, BGR color image with an alpha channel
rgba8: CV_8UC4, RGB color image with an alpha channel

2.报错解决

有未定义的引用时,一般是库没链接到位

find_package(catkin REQUIRED COMPONENTS
  roscpp
  rospy
  std_msgs
  sensor_msgs
  message_generation
  cv_bridge
  image_transport
)
catkin_package(
#  INCLUDE_DIRS include
#  LIBRARIES service_example
 CATKIN_DEPENDS roscpp rospy std_msgs sensor_msgs message_runtime cv_bridge
#  DEPENDS system_lib
)
)

3.友情提醒

http://wiki.ros.org/cn/ROS/Tutorials
要用到ros的某个基础模块时,如cv_bridge,在该网址里搜索cv_bridge即可

  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
ROS系统服务端客户端的概念可以理解为提供服务和请求服务的节点服务端节点提供服务,客户端节点请求服务,它们之通过消息传递进行通信。 下面是一个简单的服务端客户端Python编程示例: 服务端代码: ```python #!/usr/bin/env python import rospy from std_srvs.srv import Empty def my_service_callback(request): print("My service has been called!") #实现服务功能 return [] rospy.init_node('my_service_server') my_service = rospy.Service('/my_service', Empty, my_service_callback) print("My service is ready to receive requests!") rospy.spin() #保持节点运行状态 ``` 客户端代码: ```python #!/usr/bin/env python import rospy from std_srvs.srv import Empty rospy.init_node('my_service_client') rospy.wait_for_service('/my_service') #等待服务启动 my_service_proxy = rospy.ServiceProxy('/my_service', Empty) response = my_service_proxy() #发送请求 ``` 上述代码服务端使用`rospy.Service`函数创建一个服务节点,指定服务名称为`/my_service`,服务类型为`Empty`,并指定回调函数`my_service_callback`用于处理服务请求。 客户端使用`rospy.ServiceProxy`函数创建一个服务代理,指定服务名称为`/my_service`,服务类型为`Empty`,并通过调用`my_service_proxy()`方法发送请求,最终获得服务的响应结果。 需要注意的是,服务端客户端节点名称应该相互独立,避免节点名称冲突。同时,在ROS系统服务端客户端节点的启动顺序也很重要,需要确保服务端节点客户端节点之前启动。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值