zoukankan      html  css  js  c++  java
  • c++实现ros by example volume1 例子timed_out_and_back功能

    之前没有查找相关资料,过后发现有相似功能例程,网址:http://blog.csdn.net/scliu12345/article/details/44538927

    之前以为ros::Rate 时间片用完后,会重新从while(ros::ok())开始,后来证明该想法是不对的,应该是从断点处继续执行。上文的网址博文有源码中关键部分的注释,我的只是一个不同思路,但建议用上文博文的方法。

    cpp源文件放在beginer_turtorials/src下。

    编辑功能包目录中的CMakeList,txt文件,加入下面两行:

    add_executable(move_my_turtlebot src/move_my_turtlebot.cpp)

    target_link_libraries(move_my_turtlebot ${catkin_LIBRARIES})

    回到工作环境目录

    $ cd ~/catkin_ws

    编译

    $ catkin_make

    运行是先launch主节点,我的是roslaunch turtlebot_bringup minimal.launch

    然后,rosrun beginner_turtorials move_my_turtlebot



    <pre name="code" class="cpp">// move_my_turtlebot.cpp : 定义控制台应用程序的入口点。
    //
    
    #include "ros/ros.h"
    #include "geometry_msgs/Twist.h"
    
    #define pi 3.1415926
    
    int main(int argc, char **argv)
    {
    	ros::init(argc,argv,"move_my_turtlebot");
    	ros::NodeHandle n;
    	ros::Publisher vel_pub = n.advertise<geometry_msgs::Twist>("/cmd_vel_mux/input/safety_controller",1);
    
    	unsigned char rate;
    	rate = 50;
    	ros::Rate loop_rate(rate);
    	float linear_speed, goal_distance, linear_duration, angular_speed, goal_angle, angular_duration;
    	
    	linear_speed = 0.2;
    	goal_distance = 1.0;
    	linear_duration = goal_distance / linear_speed;
    
    	angular_speed = 1.0;
    	goal_angle = pi;
    	angular_duration = goal_angle / angular_speed;
    
    	int linear_ticks,angular_ticks;
    	linear_ticks = angular_ticks = 0;
    	linear_ticks =int(linear_duration*rate);
    	angular_ticks =int(angular_duration*rate);
    
    	geometry_msgs::Twist msg;
    
    	while (ros::ok())
    	{		
    		if(linear_ticks != 0)//先前行
    		{			
    			msg.linear.x = linear_speed;
    			vel_pub.publish(msg);
    			msg.linear.x = 0;
    			ros::spinOnce();
    			linear_ticks--;
    			loop_rate.sleep();
    		}
    		else if (angular_ticks != 0)//后旋转
    		{
    			msg.angular.z = angular_speed;
    			vel_pub.publish(msg);
    			msg.angular.z = 0;
    			ros::spinOnce();
    			angular_ticks--;
    			loop_rate.sleep();
    		}
    		else//退出
    		{	msg.linear.x = 0;
    			msg.angular.z = 0;
    			vel_pub.publish(msg);
    			ros::spinOnce();
    			loop_rate.sleep();
    			ROS_INFO("%s", "Stopping the robot ...");
    			break;
    		}
    	}	
    	return 0;
    }

    好的实现应该是如下的,完成走出及回来的过程。

    // move_my_turtlebot2.cpp
    //
    
    #include "ros/ros.h"
    #include "geometry_msgs/Twist.h"
    
    #define pi 3.1415926
    
    int main(int argc, char **argv)
    {
    	ros::init(argc,argv,"move_my_turtlebot2");
    	ros::NodeHandle n;
    	ros::Publisher vel_pub = n.advertise<geometry_msgs::Twist>("/cmd_vel_mux/input/safety_controller",1);
    
    	unsigned char rate;
    	rate = 50;
    	ros::Rate loop_rate(rate);
    	float linear_speed, goal_distance, linear_duration, angular_speed, goal_angle, angular_duration;
    	
    	linear_speed = 0.2;
    	goal_distance = 1.0;
    	linear_duration = goal_distance / linear_speed;
    
    	angular_speed = 1.0;
    	goal_angle = pi;
    	angular_duration = goal_angle / angular_speed;
    
    	int ticks;
    	
    
    	geometry_msgs::Twist msg;
    
    	while (ros::ok())
    	{		
    		for(char re=0;re<2;re++)
    		{
    			msg.linear.x = linear_speed;
    			int ticks=int(linear_duration*rate);
    			for(int i=0;i<ticks;i++)
    			{
    				vel_pub.publish(msg);
    				loop_rate.sleep();	
    			}
    
    			msg.linear.x = 0;
    			vel_pub.publish(msg);
    			ros::Duration(1).sleep();
    
    			msg.angular.z = angular_speed;
    			ticks=int(angular_duration*rate);
    			for(int i=0;i<ticks;i++)
    			{
    				vel_pub.publish(msg);
    				loop_rate.sleep();	
    			}
    
    			msg.angular.z = 0;
    			vel_pub.publish(msg);
    			ros::Duration(1).sleep();
    
    		}
    		
    		msg.linear.x = 0;
    		msg.angular.z = 0;
    		vel_pub.publish(msg);
    		ROS_INFO("%s", "Stopping the robot ...");
    		break;
    		
    	}	
    	return 0;
    }



    
              
    
  • 相关阅读:
    iTextSharp:创建一个新pdf文件
    SQL SERVER 2000/2005中默认不区分大小写
    问题:No VSS database (srcsafe.ini) found. Use the SSDIR environment variable or run netsetup
    直接打印pdf文档
    在sql中应用临时表
    Happy 牛 year!
    控制台打印汉字的方法
    关于文档写作、幻灯片制作以及资料整理的一点见解
    借助weka实现的分类器进行针对文本分类问题的特征词选择实验(实验代码备份)
    国际会议级别[备份]
  • 原文地址:https://www.cnblogs.com/siahekai/p/11000818.html
Copyright © 2011-2022 走看看