• 编程技巧


     

    ROS设置参数:

    1. rosrun + 参数服务器传递

    ros::init(argc, argv, "imu2txt");
    ros::NodeHandle nh("~");
    std::string file_name;
    nh.param<std::string>("file_name", file_name, "./imu_data.txt");

    首先在节点初始化之后获取参数服务器的参数,并设置初始值,如上面的程序就是在参数服务器的空间(即节点本身)获取名字为"file_name"的参数放到std::string file_name中,默认参数为后面那个。

    接着就可以rosrun了。下面是命令

    rosrun package node _parameter:=value

    在我们这里就是rosrun datatxt imu2txt _file_name:=~/Documents/test.txt就可以将节点内的参数改为想要的值了

    注意: string不需要加双引号,string第一个字符不能是数字

    2. roslaunch + 参数服务器传递

    同样是上面的例子,我们如果想通过roslaunch来调用的话,可以像下面这样,将参数放在node之间。

    <launch>
        <node name="imu2txt" pkg="data2txt" type="imu2txt" respawn="false" output="screen" >
            <param name="file_name"         type="string" value="/home/night_fury/Documents/record_bags/calibration/imudata_to_wall.txt"/>  
        </node>
    </launch>

    3. rosrun + main参数传递

    int main(int argc, char** argv)

    main函数有两个参数argc, argv。argc = length(argv),argv[0]是程序的名字,argv[1]到argv[argc - 1]是传递给程序的参数,按空格分割参数后以char指针的形式存储。这是C、C++的特性,跟ros无关,你编写的C++程序也可以这么用。你编写的ros程序甚至可以直接运行,并通过这种方式传递参数,而不用rosrun或者roslaunch。

    比如我们常用的map_server、rosbag就是用的这种参数传递方式。

    rosrun map_server map_saver -f ~/Documents/test或者直接找到二进制文件后map_saver -f ~/Documents/test

    像上面这样运行程序,那么

    argc=3  
    argv[0]="map_server"  
    argv[1]="-f"  
    argv[0]="test" 

    4. roslaunch + main参数传递

    续上,如果使用main参数传递,那在roslaunch应该怎么样呢?如下,使用args

    <launch>
        <node name="map_server" pkg="map_server" type="map_server" args="$(find costmap_2d)/test/willow-full-0.025.pgm 0.025" />
        <node name="rosplay" pkg="rosbag" type="play"
            args="-s 5 -r 1 --clock --hz=10 $(find costmap_2d)/test/simple_driving_test_indexed.bag" />
    </launch>

  • 相关阅读:
    创龙TMS320C6748开发板串口和中断学习笔记
    RTL8195AM开发板使用
    CC3100BoosterPack和CC31XXEMUBOOST板子的测试
    利尔达NB-IOT的PSM和eDRX低功耗模式笔记
    【原创】大数据基础之Zookeeper(3)选举算法
    【原创】大数据基础之Zookeeper(2)源代码解析
    【原创】大数据基础之Zookeeper(1)介绍、安装及使用
    【原创】论码农的财富修养
    【原创】大叔案例分享(2)处理大批量数据时如何实现“高效”同时实现“断点续传”功能
    【原创】大数据基础之Spark(1)Spark Submit即Spark任务提交过程
  • 原文地址:https://www.cnblogs.com/ashuoloveu/p/15696557.html
Copyright © 2020-2023  润新知