python控制nao机器人身体动作实例详解
人气:0今天读的代码,顺便写了出来,与文档的对比,差不多。
import sys import motion import almath import naoqi from ALProxy def StiffnessOn(proxy): pName="Body" pStiffnessLists pTime=1.0 proxy.stiffnessInterpolation(pName,pStiffnessLists,pTime) def main(robotIP): try: motionProxy=ALProxy("ALMotion",robotIP,9559) except Exception,e: print:"could not create a proxy!" print:"error is ",e try: postureProxy=ALProxy("ALRobotPosture",robotIP,9559) except Exception,e: print:"could not create a proxy!" print:"error is ",e StiffnessOn(motionProxy) postureProxy.goToPosture("StandInit",0.5) space=motion.FRAME_ROBOT coef=0.5 times=[coef,2.0*coef,3.0*coef,4.0*coef] isAbsolute=False dy=+0.06 dz=-0.03 dwx==+0.30 effector="Torso" path=[ [0.0,-dy,dz,-dwx,0.0,0.0], [0.0,0.0,0.0,0.0,0.0,0.0], [0.0,+dy,dz,+dwx,0.0,0.0], [0.0,0.0,0.0,0.0,0.0,0.0] ] axisMask=almath.AXIS_MASK_ALL motionProxy.post.postionInterpolation(effector,space,path,times,isAbsolute) #motion of arms with block process axisMask=almath.AXIS_MASK_VEL times=[1.0*coef,2.0*coef] dy=+0.03 effecor="RArm" path=[ [0.0,dy,0.0,0.0,0.0,0.0], [0.0,0.0,0.0,0.0,0.0,0.0] ] motionProxy.positionInterpolation(effector,space,path,axisMask,times,inAbsolute) if __name__=="__main__": robotIP="127.0.0.1" if len(sys.argv)<=1: print"useage default robotIP" else: robotIP=sys.arv[1] main(robotIP)
实例二,控制左右胳膊
#-*-encoding:UTF-8 -*- import sys import motion import almath form naoqi import ALProxy def StiffnessOn(proxy): pName="Body" pStiffnessLists=1.0 pTimeLists=1.0 proxy.stiffnessInterpolation(pName,pStiffnessLists,pTimeLists) def main(robotIP): #create a proxy to almtion try: motionProxy=ALProxy("ALMotion",robotIP,9559) except Exception,e: print "could not create a proxy" print "error is ",e #create a proxy to alrobotposture try: postureProxy=ALProxy("ALRobotPosture",robotIP,9559) except Exception,e: print "could not create a proxy" print "error is ",e StiffnessOn(motionProxy) postureProxy.goToPosture("StandInit",0.5) space=motion.FRAME_ROBOT isAbsolute=False effectorList=["LArm","RArm"] #motion of arms with block process axisMaskList=[almath.AXIS_MASK_VEL,almath.AXIS_MASK_VEL] timeLists=[[1.0],[1.0]] pathList=[ [ [0.0,-0.04,0.0,0.0,0.0,0.0]], [ [0.0,0.04,0.0,0.0,0.0,0.0]] ] motionProxy.positionInterpolation(effectorLists,space,pahtLists,axisMaskList,timeLists,isAbsolute) effectorLists=["LArm","RArm","Torso"] axisMaskLists=[ almath.AXIS_MASK_VEL, almath.AXIS_MASK_VEL, almath.AXIS_MASK_ALL ] timeLists=[ [[0.0,0.0,0.0,0.0,0.0,0.0]], [[0.0,0.0,0.0,0.0,0.0,0.0]], [0.0,+dy,0.0,0.0,0.0,0.0], [0.0,-dy,0.0,0.0,0.0,0.0], [0.0,0.0,0.0,0.0,0.0,0.0] ] motionProxy.positionInterpolations(effectorList,space,pathList,axisMaskList,timeList,isAbsolute) if __name__=="__main__": robotIP="127.0.0.1" if(sys.argv<1): print"usege default ip" else: robotIP=sys.arv[1] main(robotIP)
感受:
这些小的程序最不好处理的就是path中的数据了。这些数据是怎么获得的?最大的可能就是在choregraph中3D视图中测试得到,当然还有一种可能就是将choregraph与实体机连接,将机器人置于practice状态,这样操作来获得数据。后者操作性更强,但由于实际原因,用前者的可能性是最大的。
您可能感兴趣的文章:
- Python实现企业微信机器人每天定时发消息实例
- Python调用钉钉自定义机器人的实现
- Python使用微信接入图灵机器人过程解析
- 基于python的itchat库实现微信聊天机器人(推荐)
- python实现机器人卡牌
- Python实现微信机器人的方法
- Python3从零开始搭建一个语音对话机器人的实现
- 基于Python的微信机器人开发 微信登录和获取好友列表实现解析
- Python实现微信翻译机器人的方法
- Python qqbot 实现qq机器人的示例代码
- python实现微信自动回复机器人功能
- 如何用Python做一个微信机器人自动拉群
- Python QQBot库的QQ聊天机器人
- 使用python接入微信聊天机器人
- itchat-python搭建微信机器人(附示例)
- python实现微信机器人: 登录微信、消息接收、自动回复功能
- 手把手教你使用Python创建微信机器人
- Python开发企业微信机器人每天定时发消息实例
加载全部内容