ROS機器人底盤(18)-如何在實際項目中應(yīng)用ROS導(dǎo)航相關(guān)(1)

引言

我們知道啟動ROS相關(guān)應(yīng)用要么是roslaunch要么是rosrun,實際項目中不可能每次手動去運行這些命令因痛,簡單的就是寫到腳本里去径缅,但是涉及復(fù)雜的猪腕,就需要使用代碼去處理

在代碼中啟動roslaunch和rosrun

直接貼出代碼

import subprocess
import rospy
import rosnode

class launch_demo:
    def __init__(self, cmd=None):
        self.cmd = cmd

    def launch(self):
        self.child = subprocess.Popen(self.cmd)
        return True

    def shutdown(self):
        self.child.terminate()
        self.child.wait()
        return True

if __name__ == "__main__":
    rospy.init_node('launch_demo',anonymous=True)

    launch_nav = launch_demo(["roslaunch", "pibot_simulator", "nav.launch"])

    launch_nav.launch()

    r = rospy.Rate(0.2)
    r.sleep()

    rospy.loginfo("switch map...")
    r = rospy.Rate(1)
    r.sleep()

    rosnode.kill_nodes(['map_server'])

    map_name = "/home/pibot/ros_ws/src/pibot_simulator/maps/blank_map_with_obstacle.yaml"

    map_node = subprocess.Popen(["rosrun", "map_server", "map_server", map_name, "__name:=map_server"])

    while not rospy.is_shutdown():
        r.sleep()
  

上面使用python代碼啟動了一個PIBOT模擬器的導(dǎo)航,然后5s后切換了一個地圖

  • 使用subprocess.Popen可以啟動一個進程(roslaunch或者rosrun)
  • 使用rosnode.kill_nodes可以殺死一個rosnode

代碼中導(dǎo)航相關(guān)應(yīng)用

定點導(dǎo)航

from launch_demo import launch_demo
import rospy

import actionlib
from actionlib_msgs.msg import *
from move_base_msgs.msg import MoveBaseAction, MoveBaseGoal
from nav_msgs.msg import Path
from geometry_msgs.msg import PoseWithCovarianceStamped
from tf_conversions import transformations
from math import pi

class navigation_demo:
    def __init__(self):
        self.set_pose_pub = rospy.Publisher('/initialpose', PoseWithCovarianceStamped, queue_size=5)

        self.move_base = actionlib.SimpleActionClient("move_base", MoveBaseAction)
        self.move_base.wait_for_server(rospy.Duration(60))

    def set_pose(self, p):
        if self.move_base is None:
            return False

        x, y, th = p

        pose = PoseWithCovarianceStamped()
        pose.header.stamp = rospy.Time.now()
        pose.header.frame_id = 'map'
        pose.pose.pose.position.x = x
        pose.pose.pose.position.y = y
        q = transformations.quaternion_from_euler(0.0, 0.0, th/180.0*pi)
        pose.pose.pose.orientation.x = q[0]
        pose.pose.pose.orientation.y = q[1]
        pose.pose.pose.orientation.z = q[2]
        pose.pose.pose.orientation.w = q[3]

        self.set_pose_pub.publish(pose)
        return True

    def _done_cb(self, status, result):
        rospy.loginfo("navigation done! status:%d result:%s"%(status, result))

    def _active_cb(self):
        rospy.loginfo("[Navi] navigation has be actived")

    def _feedback_cb(self, feedback):
        rospy.loginfo("[Navi] navigation feedback\r\n%s"%feedback)

    def goto(self, p):
        goal = MoveBaseGoal()

        goal.target_pose.header.frame_id = 'map'
        goal.target_pose.header.stamp = rospy.Time.now()
        goal.target_pose.pose.position.x = p[0]
        goal.target_pose.pose.position.y = p[1]
        q = transformations.quaternion_from_euler(0.0, 0.0, p[2]/180.0*pi)
        goal.target_pose.pose.orientation.x = q[0]
        goal.target_pose.pose.orientation.y = q[1]
        goal.target_pose.pose.orientation.z = q[2]
        goal.target_pose.pose.orientation.w = q[3]

        self.move_base.send_goal(goal, self._done_cb, self._active_cb, self._feedback_cb)
        return True

    def cancel(self):
        self.move_base.cancel_all_goals()
        return True

if __name__ == "__main__":
    rospy.init_node('navigation_demo',anonymous=True)

    launch_nav = launch_demo(["roslaunch", "pibot_simulator", "nav.launch"])
    launch_nav.launch()

    r = rospy.Rate(0.2)
    r.sleep()

    rospy.loginfo("set pose...")
    r = rospy.Rate(1)
    r.sleep()
    navi = navigation_demo()
    navi.set_pose([-0.7,-0.4,0])

    rospy.loginfo("goto goal...")
    r = rospy.Rate(1)
    r.sleep()
    navi.goto([0.25,4, 90])

    while not rospy.is_shutdown():
        r.sleep()

上面完成設(shè)置機器人位置和導(dǎo)航到某一位置的功能

navi.set_pose([-0.7,-0.4,0]) 設(shè)置機器人位于地圖中位置(-0.7馏颂,-0.4) 姿態(tài)yaw=0°

navi.goto([0.25,4, 90]) 該接口調(diào)用一個服務(wù)完成機器人運動至位置(0.25示血,4)姿態(tài)yaw=90°

有了該接口就不難完成多點導(dǎo)航巡邏等應(yīng)用

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市救拉,隨后出現(xiàn)的幾起案子难审,更是在濱河造成了極大的恐慌,老刑警劉巖亿絮,帶你破解...
    沈念sama閱讀 211,194評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件告喊,死亡現(xiàn)場離奇詭異,居然都是意外死亡派昧,警方通過查閱死者的電腦和手機黔姜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評論 2 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來斗锭,“玉大人地淀,你說我怎么就攤上這事♂牵” “怎么了帮毁?”我有些...
    開封第一講書人閱讀 156,780評論 0 346
  • 文/不壞的土叔 我叫張陵,是天一觀的道長豺撑。 經(jīng)常有香客問我烈疚,道長,這世上最難降的妖魔是什么聪轿? 我笑而不...
    開封第一講書人閱讀 56,388評論 1 283
  • 正文 為了忘掉前任爷肝,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘灯抛。我一直安慰自己金赦,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,430評論 5 384
  • 文/花漫 我一把揭開白布对嚼。 她就那樣靜靜地躺著夹抗,像睡著了一般。 火紅的嫁衣襯著肌膚如雪纵竖。 梳的紋絲不亂的頭發(fā)上漠烧,一...
    開封第一講書人閱讀 49,764評論 1 290
  • 那天,我揣著相機與錄音靡砌,去河邊找鬼已脓。 笑死,一個胖子當(dāng)著我的面吹牛通殃,可吹牛的內(nèi)容都是我干的度液。 我是一名探鬼主播,決...
    沈念sama閱讀 38,907評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼邓了,長吁一口氣:“原來是場噩夢啊……” “哼恨诱!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起骗炉,我...
    開封第一講書人閱讀 37,679評論 0 266
  • 序言:老撾萬榮一對情侶失蹤照宝,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后句葵,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體厕鹃,經(jīng)...
    沈念sama閱讀 44,122評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,459評論 2 325
  • 正文 我和宋清朗相戀三年乍丈,在試婚紗的時候發(fā)現(xiàn)自己被綠了剂碴。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,605評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡轻专,死狀恐怖忆矛,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情请垛,我是刑警寧澤催训,帶...
    沈念sama閱讀 34,270評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站宗收,受9級特大地震影響漫拭,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜混稽,卻給世界環(huán)境...
    茶點故事閱讀 39,867評論 3 312
  • 文/蒙蒙 一采驻、第九天 我趴在偏房一處隱蔽的房頂上張望审胚。 院中可真熱鬧,春花似錦礼旅、人聲如沸膳叨。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽懒鉴。三九已至,卻和暖如春碎浇,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背璃俗。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評論 1 265
  • 我被黑心中介騙來泰國打工奴璃, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人城豁。 一個月前我還...
    沈念sama閱讀 46,297評論 2 360
  • 正文 我出身青樓苟穆,卻偏偏與公主長得像,于是被迫代替她去往敵國和親唱星。 傳聞我的和親對象是個殘疾皇子雳旅,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,472評論 2 348

推薦閱讀更多精彩內(nèi)容