1 #01_hello_world.py 2 3 import anki_vector 4 5 def main(): 6 args = anki_vector.util.parse_command_args() 7 with anki_vector.Robot(args.serial) as robot: 8 print("Say 'Hello World'...") 9 robot.say_text("Hello World") 10 11 if __name__ == "__main__": 12 main()
首先,第3行引入anki_vector模块,其实就是一个叫作anki_vector的文件夹,目前全部的程序,只须要引入这个模块就拥有vector的全部控制功能了。html
anki_vector.Robot(args.serial),这一句是建立一个robot对象,并链接到你的小V,每一个程序开头通常都少不了这一行。而Robot这个对象的建立也是具备不少参数的,在这个例子中它只带了一个参数,其余的参数都使用默认参数。下面列出了这个重要的构造函数的全部参数及默认值:
class Robot: def __init__(self, serial: str = None,#矢量序号。机器人的序号(ex. 00e20100)位于向量的底面,或从Vector的调试屏幕访问。用于肯定要加载哪一个向量配置。 ip: str = None,#Vector的ip地址。(可选) config: dict = None,#自定义的dict,覆盖Vector配置中的值。(可选) default_logging: bool = True,#记录日志 behavior_activation_timeout: int = 10,#链接超时时间。 cache_animation_list: bool = True,#获取启动时可用的动画列表。 enable_face_detection: bool = False,#相册开关。 enable_camera_feed: bool = False,#相机开关 enable_audio_feed: bool = False,#音频开关 enable_custom_object_detection: bool = False,#自定义对象检测开关 enable_nav_map_feed: bool = None,#导航地图开关 show_viewer: bool = False,#相机画面开关 show_3d_viewer: bool = False,#3D画面开关 requires_behavior_control: bool = True):#是否控制小V的行为系统 pass
能够有选择的填入,普通状况下只须要小V的编号serial就好了。python
anki_vector目录下存放的就是SDK库源码了,这是最重要的,接下来我就阅读这一部分。git
examples目录下存放着一些应用例子,就是调用了anki_vector模块的示例程序,包含了上面讲的01_hello_world.py例程,若是还不清楚怎么调用anki_vector,能够多看看这部分。github
剩下的都是一些可有可无的文件,感兴趣能够翻阅一下。编程
接下来打开anki_vector目录:api
虽然文件不少,可是并不复杂,没有太多的嵌套,就一个平滑的文件列表,里面每个py文件都实现了vector的一个控制功能(例如:背灯的控制由lights.py实现,照相的控制由camera.py实现),少数py文件用于实现基础功能和最后汇总(例如robot.py用于汇总对vector的控制功能,在调用这个库时只须要建立一个Robot类的对象,其余的操做全由这个对象间接完成)。浏览器
最重要的是,这些文件与官网API几乎是一一对应,也就是说,每一个文件内都封装了一个功能类。框架
下面是在线文档中的API,能够与上面的库目录对比着看,对每一个API的说明也是对每一个文件的说明:函数
具体每一个类实现了哪些方法,能够点击对应的在线文档API进去看,也能够直接看源码。工具
浏览了anki_vector库的概貌以后,咱们再回到最早讲的hello world程序,看看在那几个调用中,到底发生了什么。
四:hello world内部实现
这个程序里,其实程序里面最不理解的就是这两句:
1 args = anki_vector.util.parse_command_args() 2 with anki_vector.Robot(args.serial) as robot: 3 robot.say_text("Hello World") 4 pass
按照调用次序顺藤摸瓜,从anki_vector模块中找到util模块,再从util模块找到parse_command_args函数的实现,调用的时候是不带参数的:
而后先看一下say_text函数:建立一个protobuf定义的协议结构体对象,而后填充内容,而后使用gRPC发送给小V。gRPC是基于protobuf和http2.0的一种通用的RPC,使用它能够方便的生成服务端和客户端代码,由此也能够看出小V内部使用的是gRPC服务端。
看完这些后,大致明白了robot.py的做用,这个模块不作具体的工做,只是简单的把其余基础模块的功能集成进来,为外部用户提供一个统一的接口。从这个文件的开头也能看出,它引用了同级目录下的几乎全部模块。
五:功能模块详解
了解完这些,对SDK源码已经有全局的了解。以后将调出几个具体的功能讲一下,全部功能的实现流程都大体相同。