ROS与STM32的串口通信

STM32程序

参考上一篇 Ubuntu16之STM32开发–点灯和串口通信, 主要代码节选如下:

uint8_t count = 0;


  while (1)
  {
		++count;
		HAL_GPIO_TogglePin(LD2_GPIO_Port, LD2_Pin);
		printf("Hello, %3d\r\n", count);
		HAL_Delay(100);
  }

每100ms串口发送给上位机 “Hello, %3d\r\n” 的字符, 串口识别为 /dev/ttyACM0.

ROS程序

mkdir -p ~/catkin_ws/src
cd ~/catkin_ws/src
catkin_create_pkg serial_communication roscpp std_msgs
cd serial_communication/src	
touch serial_communication.cpp
gedit serial_communication.cpp  # code serial_communication.cpp

~/catkin_ws/src/serial_communication/src/serial_communication.cpp 内容:

//reference: https://www.cnblogs.com/li-yao7758258/p/5794005.html

#include <string>
#include <ros/ros.h> // 包含ROS的头文件
#include <boost/asio.hpp> //包含boost库函数
#include <boost/bind.hpp>
#include "std_msgs/String.h" //ros定义的String数据类型

using namespace std;
using namespace boost::asio; //定义一个命名空间,用于后面的读写操作

unsigned char buf[12]; //定义字符串长度

int main(int argc, char **argv)
{

  ros::init(argc, argv, "serial_communication"); //初始化节点
  ros::NodeHandle n;

  ros::Publisher chatter_pub = n.advertise<std_msgs::String>("chatter", 1000); //定义发布消息的名称及sulv

  ros::Rate loop_rate(10);

  io_service iosev;
  serial_port sp(iosev, "/dev/ttyACM0"); //定义传输的串口
  sp.set_option(serial_port::baud_rate(115200));
  sp.set_option(serial_port::flow_control());
  sp.set_option(serial_port::parity());
  sp.set_option(serial_port::stop_bits());
  sp.set_option(serial_port::character_size(8));

  while (ros::ok())
  {
    //write(sp, buffer(buf1, 6));  //write the speed for cmd_val
    //write(sp, buffer("Hellq world", 12));
    read(sp, buffer(buf));
    string str(&buf[0], &buf[11]); //将数组转化为字符串
    //if (buf[10] == '\n')
    {
      std_msgs::String msg;
      std::stringstream ss;
      ss << str;

      msg.data = ss.str();

      ROS_INFO("%s", msg.data.c_str()); //打印接受到的字符串
      chatter_pub.publish(msg);         //发布消息

      ros::spinOnce();

      loop_rate.sleep();
    }
  }

  iosev.run();
  return 0;
}

保存后, 打开 ~/catkin_ws/src/serial_communication/CMakeLists.txt, 最后面加上:

add_executable(serial_communication src/serial_communication.cpp)
target_link_libraries(serial_communication ${catkin_LIBRARIES})

保存.

# 第一个终端
roscore

# 第二个终端
cd ~/catkin_ws
catkin_make
source devel/setup.bash
chmod 777 /dev/ttyACM0
# 如果之前 CuteCom 已经打开, 记得关了, 免得USB虚拟串口占用.  
rosrun serial_communication serial_communication

然后就会看到ROS中打印出如下信息:

lz@lz-pc:~/catkin_ws$ rosrun serial_communication serial_communication
[ INFO] [1542939474.069999764]: Hello,  74
[ INFO] [1542939474.169567482]: Hello,  75
[ INFO] [1542939474.269443664]: Hello,  76
[ INFO] [1542939474.369511941]: Hello,  77
[ INFO] [1542939474.469562788]: Hello,  78
[ INFO] [1542939474.569548019]: Hello,  79
[ INFO] [1542939474.669471010]: Hello,  80
[ INFO] [1542939474.769552072]: Hello,  81
[ INFO] [1542939474.869545703]: Hello,  82
[ INFO] [1542939474.969443991]: Hello,  83

工程下载

stm32: https://download.csdn.net/download/weifengdq/10802433
ros: https://download.csdn.net/download/weifengdq/10802444
github: https://github.com/weifengdq/ROS-STM32

  • 7
    点赞
  • 70
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
ROS(机器人操作系统)是一款成熟的机器人操作系统,具有完备的生态体系,未来的发展意义可以成为机器人届中的”Linux、Android“。机器人的开发学习要综合软硬件的协同开发,硬件开发有些部分倾向于底层的设计和使用。软件开发可以依托C++、PYTHON等高级语言进行ROS接口应用开发,或者兼容ROS系统。本系列的ROS开发课程包含下位机开发、上位机开发、基于MBD(基于模型设计的开发)等。下位机作为机器人设计的基础部分是学习机器人操作系统必经之路,下位机我们通常会选择Arduino(适合学习不适合工程,代码执行效率差)、STM32系列产品(工程应用广泛,适合学习和工程开发,代码针对性强),当然还有NXP系列、51系列、TI DSP等,后期可以根据产品的性能和成本要求去考虑;上位机部分,主要是基于工控机、树莓派Raspberry、英伟达Jetson等可以运行操作系统的嵌入式设备再基于ROS操作系统进行实训学习。网络上对于ROS类的教学比较多,但是系统化从底层向高阶层层递升的教学方法偏少,知识碎片化严重,对机器人开发工程师深远的发展有负面影响,基于此本人通过多年自身的学习和工程实践,将机器人开发课程系统化、具象化、模块化地引导式学习,每节课程都有相应的课件和代码引导。对致力于机器人事业的学生有推动作用,且增强信心,系统化自己的机器人知识。为自己的职业规划和事业发展奠定坚实基础。最后,你们的支持,就是老师不断创作的动力!老师会不断更新机器人类相关知识,希望”与子同裳“。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值