ROS 2 Humble Hawksbill 发布消息或速度

创建节点,这些节点以字符串消息/速度的形式通过主题发布。 这里使用的例子是一个简单的发布系统; 发布字符串或速度。

一个简单的hello ros如下所示:

import rclpy
from rclpy.node import Node

from std_msgs.msg import String


class MinimalPublisher(Node):

    def __init__(self):
        super().__init__('minimal_publisher')
        self.publisher_ = self.create_publisher(String, 'topic', 10)
        timer_period = 0.5  # seconds
        self.timer = self.create_timer(timer_period, self.timer_callback)
        self.i = 0

    def timer_callback(self):
        msg = String()
        msg.data = 'Hello ROS2 World: %d' % self.i
        self.publisher_.publish(msg)
        self.get_logger().info('Publishing: "%s"' % msg.data)
        self.i += 1


def main(args=None):
    rclpy.init(args=args)

    minimal_publisher = MinimalPublisher()

    rclpy.spin(minimal_publisher)

    # Destroy the node explicitly
    # (optional - otherwise it will be done automatically
    # when the garbage collector destroys the node object)
    minimal_publisher.destroy_node()
    rclpy.shutdown()


if __name__ == '__main__':
    main()

 

注释后的第一行代码 import rclpy 以便可以使用它的 Node 类。

import rclpy
from rclpy.node import Node

下一条语句导入节点用于构造其在主题上传递的数据的内置字符串消息类型。

from std_msgs.msg import String

这些线代表节点的依赖关系。回想一下,必须将依赖项添加到 package.xml

接下来,创建 MinimalPublisher 类,它继承自 Node(或者是 Node 的子类)。

class MinimalPublisher(Node):

以下是类的构造函数的定义。 super().__init__ 调用 Node 类的构造函数并给它你的节点名称,在本例中为 minimum_publisher。

create_publisher 声明节点通过名为 topic 的主题发布字符串类型的消息(从 std_msgs.msg 模块导入),并且“队列大小”为 10。队列大小是必需的 QoS(服务质量)设置,用于限制如果订阅者没有足够快地接收它们,则排队消息的数量。

接下来,创建一个带有回调的计时器,每 0.5 秒执行一次。 self.i 是回调中使用的计数器。

def __init__(self):
    super().__init__('minimal_publisher')
    self.publisher_ = self.create_publisher(String, 'topic', 10)
    timer_period = 0.5  # seconds
    self.timer = self.create_timer(timer_period, self.timer_callback)
    self.i = 0

timer_callback 创建一个附加了计数器值的消息,并使用 get_logger().info 将其发布到控制台。

def timer_callback(self):
    msg = String()
    msg.data = 'Hello ROS2 World: %d' % self.i
    self.publisher_.publish(msg)
    self.get_logger().info('Publishing: "%s"' % msg.data)
    self.i += 1

最后,定义了 main 函数。

def main(args=None):
    rclpy.init(args=args)

    minimal_publisher = MinimalPublisher()

    rclpy.spin(minimal_publisher)

    # 显式销毁节点
    # (可选 - 否则会自动完成
    # 当垃圾收集器销毁节点对象时)
    minimum_publisher.destroy_node()
    rclpy.shutdown()

首先初始化 rclpy 库,然后创建节点,然后它“spins”节点,以便调用其回调。 


将其逐句更新为发布cmd_vel:

import rclpy
from rclpy.node import Node

# from std_msgs.msg import String
from geometry_msgs.msg import Twist



class MinimalPublisher(Node):

    def __init__(self):
        super().__init__('my_pub')
        self.publisher_ = self.create_publisher(Twist, 'turtle1/cmd_vel', 10)
        timer_period = 1  # seconds
        self.timer = self.create_timer(timer_period, self.timer_callback)
        self.i = 0

    def timer_callback(self):
        vel = Twist()
#        vel.data = 'My Hello ROS2 World: %d' % self.i
        vel.linear.x=1.0
        vel.angular.z=0.01*self.i
        self.publisher_.publish(vel)
        self.get_logger().info('Publishing: x"%f"' % vel.linear.x)
        self.get_logger().info('Publishing: z"%f"' % vel.angular.z)
        self.i += 1


def main(args=None):
    rclpy.init(args=args)

    minimal_publisher = MinimalPublisher()

    rclpy.spin(minimal_publisher)

    # Destroy the node explicitly
    # (optional - otherwise it will be done automatically
    # when the garbage collector destroys the node object)
    minimal_publisher.destroy_node()
    rclpy.shutdown()


if __name__ == '__main__':
    main()

是不是非常简单。


测试一下效果:

 


 

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhangrelay

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值