ROS与windows进行TCP传送消息时的问题解决

本文总结了在QT应用中实现ROS与UDP数据交互时遇到的两个关键问题及其解决方法。问题一涉及如何在QT槽函数中初始化带有参数构造函数的类成员。解决方法是使用初始化列表来正确初始化这些数据成员。问题二涉及到ROS TCP通信时出现的10053错误,这是由于ROS服务器在一秒钟内未收到数据导致的套接字关闭。通过修改rosserial_server源码中的超时时间解决了这个问题。
摘要由CSDN通过智能技术生成

 这几天为了解决这些问题一直在发愁,今天晚上终于成功了,前后算起来花了将近4天的时间,现在做一个总结。

想要在QT中制作一个上位机实现三个主要功能:

  • 使用UDP协议接收外部发过来的数据
  • 对接受到的UDP数据进行处理,得到想要的数据
  • 将处理好的数据按照ROS的格式和要求使用TCP协议转发出去

在此过程中遇到两个主要的问题:

问题一: 成员变量是类对象,且该类对象的构造函数是含有参数的

UDP部分的功能已经实现,主要的实现程序如下:

#include "widget.h"
#include "ui_widget.h"
#include <QHostAddress>

Widget::Widget(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::Widget)
{
    ui->setupUi(this);


    //分配空间,指定父对象
    udpSocket = new QUdpSocket(this);

    //绑定
    udpSocket->bind(10022);

    setWindowTitle("本端口为:10022");


    //当对方成功发送数据过来
    //自动触发 readyRead()
    connect(udpSocket,SIGNAL(readyRead()),this,SLOT(dealMsg()));

}

void Widget::dealMsg()
{

    //读取对方发送的内容
    char buf[1024] = {0};
    QHostAddress cliAddr;  //对方IP
    quint16 port;           //对方端口
    qint64 len = udpSocket->readDatagram(buf,sizeof(buf),&cliAddr,&port);
    if(len > 0)
    {
        //格式化
        QString str = QString ("%1").arg(buf);   //获取的数据
        //给编辑区设置内容
        ui->textEdit->append(str);
    }

}

Widget::~Widget()
{
    delete ui;
}

而ros与windows通信的例程可以参考我之前写的一篇博客:《基于rosserial_windows实现ROS与windows通信(亲测可行)》

其中给的代码例程如下:

/* rosserial_hello_world.cpp : Example of sending command velocities from Windows using rosserial
 */
 
  • 3
    点赞
  • 44
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
为了在Windows系统中与Ubuntu系统中的ROS进行通信,可以使用ROSTCP/IP协议栈。下面是实现ROS Windows TCP通信的步骤: 1. 在Windows系统中安装ROS,可以使用ROSWindows版本或者使用虚拟机在Windows系统中运行Ubuntu系统。 2. 在Windows系统中安装ROSTCP/IP协议栈,可以使用ROSroscpp库中的TCP/IP协议栈或者使用第三方库,例如Boost.Asio。 3. 在Windows系统中编写TCP/IP Client程序,连接到Ubuntu系统中的ROS TCP/IP Server。 4. 在Windows系统中发送数据到Ubuntu系统中的ROS TCP/IP Server,可以使用ROSroscpp库中的TCP/IP协议栈提供的接口。 5. 在Ubuntu系统中编写TCP/IP Server程序,接收来自Windows系统的数据,并将其转发给ROS系统中的其他节点。 6. 在Ubuntu系统中使用ROSroscpp库中的TCP/IP协议栈提供的接口,将接收到的数据转发给ROS系统中的其他节点。 下面是一个简单的ROS Windows TCP通信的例子: ```cpp // Windows TCP/IP Client程序 #include <ros/ros.h> #include <ros/network.h> #include <boost/asio.hpp> int main(int argc, char **argv) { ros::init(argc, argv, "ros_tcp_client"); ros::NodeHandle nh; boost::asio::io_service io_service; boost::asio::ip::tcp::socket socket(io_service); boost::asio::ip::tcp::resolver resolver(io_service); boost::asio::connect(socket, resolver.resolve({"192.168.1.100", "12345"})); // 连接到Ubuntu系统中的ROS TCP/IP Server std::string message = "Hello, ROS!"; boost::asio::write(socket, boost::asio::buffer(message)); // 发送数据到Ubuntu系统中的ROS TCP/IP Server return 0; } // Ubuntu ROS TCP/IP Server程序 #include <ros/ros.h> #include <ros/network.h> #include <boost/asio.hpp> void handle_accept(boost::asio::ip::tcp::socket socket, ros::Publisher pub) { boost::asio::streambuf buffer; boost::asio::read_until(socket, buffer, "\n"); // 接收来自Windows系统的数据 std::istream is(&buffer); std::string message; std::getline(is, message); pub.publish(message); // 将接收到的数据转发给ROS系统中的其他节点 } int main(int argc, char **argv) { ros::init(argc, argv, "ros_tcp_server"); ros::NodeHandle nh; ros::Publisher pub = nh.advertise<std::string>("ros_tcp_data", 1000); boost::asio::io_service io_service; boost::asio::ip::tcp::acceptor acceptor(io_service, boost::asio::ip::tcp::endpoint(boost::asio::ip::tcp::v4(), 12345)); while (ros::ok()) { boost::asio::ip::tcp::socket socket(io_service); acceptor.accept(socket); handle_accept(std::move(socket), pub); } return 0; } ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

编程芝士

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

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

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

打赏作者

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

抵扣说明:

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

余额充值