ROS1.0环境安装与配置

一、安装ROS1.0软件

采用直接导入Ubuntu18+ROS 镜像的方式

链接: https://pan.baidu.com/s/15CG3mXpxpqAYeBafS-vc8w
提取码:2022
安装后的ubuntu系统登录密码是1234

二、熟悉ROS基本命令,并运行小海龟demo例子,通过键盘控制小海龟运动。同时用话题查看器查看两个node之间的消息传递

1.启动ROS Master

打开一个终端(快捷键ctrl+alt+t),输入

roscore

alt

2.启动小海龟仿真器

再打开一个终端,输入

rosrun turtlesim turtlesim_node

alt

3.启动海龟控制节点

再打开一个新的终端,输入

rosrun turtlesim turtle_teleop_key

4.用话题查看器查看两个node之间的消息传递

输入

rostopic list

alt
查看话题,使用rostopic list,就会列举出现在的所有话题,查看某一话题的具体内容,添加info即可
如下:

rostopic info /turtle1/cmd_vel

alt

三、用C++或python写一个程序,控制小海龟走一个标准的圆形

1. 新建一个文件夹,命名为catkin_ws

mkdir -p ~/catkin_ws/src

2. 在文件夹 catkin_ws 下创建一个文件夹 src

cd ~/catkin_ws/src

3. 移动到src目录下输catkin_init_workspace,在src文件夹中出现CMakeLists.txt文件

catkin_init_workspace

4. 返回catkin_ws,对其进行编译

cd ~/catkin_ws
catkin_make

5. 来到workspace的src目录下,新建my_turtle_package包

cd ./src
catkin_create_pkg my_turtle_package std_msgs rospy roscpp

6. 进入my_turtle_package的src文件中

cd ./my_turtle_package/src

7. 新建画圆程序名为yuan.cpp

touch yuan.cpp

8. 打开yuan.cpp

gedit yuan.cpp

yuan.cpp

#include "ros/ros.h"
#include<geometry_msgs/Twist.h> //运动速度结构体类型  geometry_msgs::Twist的定义文件
 
int main(int argc, char *argv[])
{
    ros::init(argc, argv, "vel_ctrl");  //对该节点进行初始化操作
    ros::NodeHandle n;         //申明一个NodeHandle对象n,并用n生成一个广播对象vel_pub
    ros::Publisher vel_pub = n.advertise<geometry_msgs::Twist>("/turtle1/cmd_vel", 10);
    //vel_pub会在主题"/cmd_vel"(机器人速度控制主题)里广播geometry_msgs::Twist类型的数据
    ROS_INFO("draw_circle start...");//输出显示信息
    while(ros::ok())
    {
        geometry_msgs::Twist vel_cmd; //声明一个geometry_msgs::Twist 类型的对象vel_cmd,并将速度的值赋值到这个对象里面
 
        vel_cmd.linear.x = 2.0;//前后(+-) m/s
        vel_cmd.linear.y = 0.0;  //左右(+-) m/s
        vel_cmd.linear.z = 0.0;
 
        vel_cmd.angular.x = 0;
        vel_cmd.angular.y = 0;
        vel_cmd.angular.z = 1.8; //机器人的自转速度,+左转,-右转,单位是rad/s
        vel_pub.publish(vel_cmd); //赋值完毕后,发送到主题"/cmd_vel"。机器人的核心节点会从这个主题接受发送过去的速度值,并转发到硬件体上去执行
 
        ros::spinOnce();//调用此函数给其他回调函数得以执行(比例程未使用回调函数)
    }
    return 0;
}

9. 修改CMakeLists.txt

 cd ~/catkin_ws/src/my_turtle_package
 gedit CMakeLists

在CMakeLists.txt文件中找到##Declare a C++ executable,在这一行的前面加入以下代码:

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

10. 保存后进行编译:

cd ~/catkin_ws/
catkin_make

11. 新建一个终端,启动ros:

roscore

12. 打开第二个终端,启动rosnode:

rosrun turtlesim turtlesim_node

13. 打开第三个终端,启动my_turtle_package节点:

cd  ~/catkin_ws/
source devel/setup.bash 
rosrun my_turtle_package yuan

alt

  • 40
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
以下是一个简单的ROS2开发仿真环境的代码示例: URDF文件:在“my_robot/urdf”文件夹下创建名为“my_robot.urdf”的文件。 ```xml <?xml version="1.0"?> <robot name="my_robot" xmlns:xacro="http://www.ros.org/wiki/xacro"> <link name="base_link"> <visual> <geometry> <cylinder length="0.1" radius="0.1"/> </geometry> <origin xyz="0 0 0"/> </visual> </link> <joint name="base_joint" type="fixed"> <parent link="world"/> <child link="base_link"/> </joint> <link name="link1"> <visual> <geometry> <box size="0.1 0.1 0.1"/> </geometry> <origin xyz="0 0 0.1"/> </visual> </link> <joint name="joint1" type="revolute"> <parent link="base_link"/> <child link="link1"/> <origin xyz="0 0 0.1"/> <axis xyz="0 0 1"/> </joint> </robot> ``` 控制器配置文件:在“my_robot/controllers”文件夹下创建名为“my_robot_controllers.yaml”的文件。 ```yaml # Joints being controlled by the position_controllers position_controllers: - name: joint1_position_controller type: joint_state_controller/JointStateController joints: - joint1 - name: joint1_position_controller type: position_controllers/JointPositionController joints: - joint1 ``` 启动文件:在“my_robot/launch”文件夹下创建名为“my_robot.launch.py”的Python文件。 ```python import os import launch import launch_ros.actions def generate_launch_description(): urdf_file = os.path.join( get_package_share_directory('my_robot'), 'urdf', 'my_robot.urdf' ) controller_config_file = os.path.join( get_package_share_directory('my_robot'), 'controllers', 'my_robot_controllers.yaml' ) return launch.LaunchDescription([ launch.actions.DeclareLaunchArgument( 'use_sim_time', default_value='true', description='Use simulation (Gazebo) clock if true' ), launch.actions.ExecuteProcess( cmd=['gazebo', '--verbose', '-s', 'libgazebo_ros_init.so', urdf_file], output='screen' ), launch_ros.actions.Node( package='joint_state_publisher', executable='joint_state_publisher', name='joint_state_publisher' ), launch_ros.actions.Node( package='robot_state_publisher', executable='robot_state_publisher', name='robot_state_publisher', parameters=[{ 'robot_description': Command(['xacro', ' ', urdf_file]) }] ), launch_ros.actions.Node( package='controller_manager', executable='spawner.py', name='controller_spawner', arguments=[controller_config_file], output='screen' ) ]) ``` 这些代码只是一个简单的示例,您可以根据自己的需求和机器人模型进行修改和扩展。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值