当前位置:   article > 正文

索尼 toio™ 应用创意开发征文|探索创新的玩乐世界——云旅游

索尼 toio™ 应用创意开发征文|探索创新的玩乐世界——云旅游

随着《国家宝藏》近几年的爆火,越来越多的年轻人开始去关注和了解中国的文物古迹。由于许多有趣的文物古迹分布在全国各地,所以想把科技与文物古迹的内容相结合,让人们可以随时随地的对感兴趣的文物古迹进行了解。 通过深入的了解,我发现toio的可玩性以及可扩展性非常的大,所以我觉得可以使用索尼的toio来实现我的想法。

创意概述:

使用手柄控制Q宝机器人在地图中探索,抵达探索点后,触发对应文物古迹的视频介绍。由于地图大小的限制,所以目前暂定5个探索点,分别为:三星堆博物馆、金沙遗址博物馆、陕西省博物馆、湖北省博物馆以及湖南里耶秦简博物馆。后续如果地图增加,可以考虑扩充探索点。

物料准备:

索尼toio机器人、PS5手柄、自定义操作垫(地图)、PC

编程语言:

目前toio支持多种编程语言,如:JSP、unity、 python以及scratch,考虑到Python是今年发布的,所以打算使用Python作为该项目的编程语言。

需要用到的库:toio、pygame、moviepy、asyncio等

创意实施:

思路已经确定好了,那么接下……

安装所需的库。由于在这个项目中用到了一些第三方的库,所以我们首先要进行安装。

A、toio库:

由于该库目前无法通过pip进行安装,所以我们需要使用官方提供的安装步骤进行安装,具体参考:https://github.com/toio/toio.py

B、Pygame库:

Pygame是一个功能十分强大的库,通过该库,我们可以制作出一些有意思的游戏。安装步骤如下:

pip install Pygame

C、moviepy库:

Moviepy是一个视频编辑的库,由于Pygame2.0目前已经移除了“Movie”功能,所以需要使用moviepy代替该功能。安装步骤如下:

pip install moviepy

D、asyncio库:

asyncio是一个标准库,所需我们不需要安装即可直接调用。

以上已经把需要的库全部安装完毕了,但是有几点需要注意:

  1. 如果想要使用toio,Python版本一定是要3.11及以上。

  2. 操作系统要求如下,若不满足,可能导致程序无法运行。

了解完以上内容后,接下来就可以创建我们项目了。

  1. 创建对象,完成蓝牙的扫描和连接。完成库的安装后,接下来就要尝试通过程序完成Q宝的扫描与连接了。结合官方给的说明,可以很容易的完成Q宝的扫描与连接的程序,程序如下:(执行该程序,与Q宝配对并连接,3秒后自动断开。目前,该程序只连接一个Q宝,如果想要连接多个,需要修改“num”的值,以及需要创建多个Q宝对象即可。由于本项目不涉及多个Q宝,所以暂时不讨论详细步骤。)

  2. 通过“read()”方法读取地图中的坐标值。参考指导手册,官方为Q宝提供了丰富的API接口(参考:https://toio.github.io/toio.py/)。此时,可以根据实际情况选择性的使用。由于用到了官方提供的地图,所以需要让Q宝读取地图中的坐标值。

    根据官方说明,使用“api.id_information.read()”可以获取到一个列表,列表中包含了两组键值对。一组是“center”中心位置,另一组是“sensor”传感器位置,由于两者的坐标相差不大,所以我选择了“sensor”的数据。

    参考程序如下:每隔0.5秒扫描Q宝当前的位置,并打印当前Q宝获取到的坐标值。此时,掌握了如何获取Q宝的实时坐标,后期,将配合这些坐标完成特殊的功能。视频如下:

    读取坐标

  3. 加入joystick,通过手柄轻松控制Q宝。为了增加趣味性和探索性,计划加入一个外部的控制器,可以操控Q宝在地图中进行探索。Joystick是pygame中的一个可以支持外部手柄的模块,通过该模块与Q宝结合,使用常见的游戏手柄就可以轻松的控制Q宝进行移动。目前官方支持的手柄包括joy-con,PS4,PS5,XBox 360,其他型号的手柄可以进行尝试。因为手头正好有PS5的Dual Sense,所以使用PS5手柄作为控制器来操控Q宝。视频如下:

    手柄控制

    参考程序如下:

    1. 初始化:

      1. import pygame
      2. import time
      3. import asyncio
      4. from toio import *
      5. from moviepy.editor import *

    2. 创建“Joystick”对象:

      1. pygame.event.get()
      2. #创建Jocstick对象
      3. Joystick = pygame.joystick
      4. J_Count = Joystick.get_count()
      5. for i in range(J_Count):
      6. joystick = Joystick.Joystick(i)
      7. joystick.init()
      8. axes = joystick.get_numaxes()

    3. 获取左摇杆的数值,并操控Q宝:

      1. #获取摇杆的前、后、左、右数值,通过数值控制Q宝移动。
      2. axis = joystick.get_axis(0)
      3. if axis > 0.5:
      4. await cube_1.api.motor.motor_control(10, -10)
      5. elif axis < -0.5:
      6. await cube_1.api.motor.motor_control(-10, 10)
      7. axis1 = joystick.get_axis(1)
      8. if axis1 > 0.5:
      9. await cube_1.api.motor.motor_control(-20, -20)
      10. elif axis1 < -0.5:
      11. await cube_1.api.motor.motor_control(20, 20)
      12. if axis1 > -0.1 and axis1 < 0.1 and axis > -0.1 and axis < 0.1:
      13. await cube_1.api.motor.motor_control(0, 0)
      14. time.sleep(0.1)

    4. 使用moivepy,播放指定视频。

      开头已经介绍过,由于pygame2.0移除了“movie”功能,所以选择使用moviepy替代。

      程序如下:(通过“clip.preview()”播放视频。)

通过以上的分解步骤,基本上程序的骨架已经搭建好,后续,只需要对每个部分进行细化即可。 

自定义操作垫(地图)参考如下:

 整体程序如下:

  1. import pygame
  2. import time
  3. import asyncio
  4. from toio import *
  5. from moviepy.editor import *
  6. pygame.joystick.init()
  7. pygame.init()
  8. done = False
  9. async def toio_contal():
  10. #创建播放列表
  11. start = VideoFileClip("C:/Users/pc/Desktop/video/start.mp4")
  12. clip = VideoFileClip("C:/Users/pc/Desktop/video/虎符介绍.mp4")
  13. clip1 = VideoFileClip("C:/Users/pc/Desktop/video/秦简介绍.mp4")
  14. clip2 = VideoFileClip("C:/Users/pc/Desktop/video/青铜神树介绍.mp4")
  15. clip3 = VideoFileClip("C:/Users/pc/Desktop/video/太阳神鸟介绍.mp4")
  16. clip4 = VideoFileClip("C:/Users/pc/Desktop/video/越往勾践剑介绍.mp4")
  17. clip5 = VideoFileClip("C:/Users/pc/Desktop/video/清明上河图动画.mp4")
  18. clip6 = VideoFileClip("C:/Users/pc/Desktop/video/清明上河图介绍.mp4")
  19. num = 0
  20. judge = 0
  21. pygame.display.set_caption("toio_cube")
  22. #Q宝连接语句
  23. dev_list = await BLEScanner.scan(1)
  24. cube_1 = ToioCoreCube(dev_list[0].interface)
  25. await cube_1.connect()
  26. print("Q宝_A已连接")
  27. start.preview()
  28. start.close()
  29. while done == False:
  30. pygame.event.get()
  31. #创建Jocstick对象
  32. Joystick = pygame.joystick
  33. J_Count = Joystick.get_count()
  34. for i in range(J_Count):
  35. joystick = Joystick.Joystick(i)
  36. joystick.init()
  37. axes = joystick.get_numaxes()
  38. '''
  39. Left -> Right - Axis 0
  40. Up -> Down - Axis 1
  41. for i in range(axes):
  42. axis = joystick.get_axis(i)
  43. print("Axis {} value: {:>6.3f}".format(i, axis))
  44. '''
  45. #获取摇杆的前、后、左、右数值,通过数值控制Q宝移动。
  46. axis = joystick.get_axis(0)
  47. if axis > 0.5:
  48. await cube_1.api.motor.motor_control(10, -10)
  49. elif axis < -0.5:
  50. await cube_1.api.motor.motor_control(-10, 10)
  51. axis1 = joystick.get_axis(1)
  52. if axis1 > 0.5:
  53. await cube_1.api.motor.motor_control(-20, -20)
  54. elif axis1 < -0.5:
  55. await cube_1.api.motor.motor_control(20, 20)
  56. if axis1 > -0.1 and axis1 < 0.1 and axis > -0.1 and axis < 0.1:
  57. await cube_1.api.motor.motor_control(0, 0)
  58. time.sleep(0.1)
  59. # 获取Q宝坐标
  60. t_date = await cube_1.api.id_information.read()
  61. t_x = t_date.sensor.point.x
  62. t_y = t_date.sensor.point.y
  63. print("x:", t_x, "y:", t_y)
  64. if 70<t_x<103 and 500<t_y<530:
  65. await cube_1.api.motor.motor_control(0,0)
  66. num=1
  67. if 50<t_x<100 and 620<t_y<650:
  68. await cube_1.api.motor.motor_control(0, 0)
  69. num=2
  70. if 159<t_x<192 and 570<t_y<590:
  71. await cube_1.api.motor.motor_control(0, 0)
  72. num=3
  73. if 265<t_x<295 and 490<t_y<515:
  74. await cube_1.api.motor.motor_control(0, 0)
  75. num=4
  76. if 245<t_x<275 and 655<t_y<670:
  77. await cube_1.api.motor.motor_control(0, 0)
  78. num=5
  79. if t_x==314 and t_y==673:
  80. await cube_1.api.motor.motor_control(0, 0)
  81. num=6
  82. match num:
  83. case 1:
  84. if judge == 0:
  85. judge = 1
  86. clip2.preview()
  87. clip2.close()
  88. num = 0
  89. case 2:
  90. if judge == 1:
  91. judge =2
  92. pygame.display.set_mode(flags=pygame.FULLSCREEN)
  93. clip1.preview()
  94. clip1.close()
  95. num = 0
  96. case 3:
  97. if judge == 2:
  98. judge = 3
  99. clip3.preview()
  100. clip3.close()
  101. num = 0
  102. case 4:
  103. if judge == 3:
  104. judge = 4
  105. clip4.preview()
  106. clip4.close()
  107. num = 0
  108. case 5:
  109. if judge == 4:
  110. judge == 0
  111. clip.preview()
  112. clip.close()
  113. num = 0
  114. case 6:
  115. clip6.preview()
  116. clip6.close()
  117. num = 0
  118. print("judge:",judge,"num:",num)
  119. if __name__ == '__main__':
  120. asyncio.run(toio_contal())

 以上为本次项目的程序,使用手柄控制Q宝在地图中进行移动,到达指定区域,触发特定事件后,播放对应的讲解视频。

最终展示视频

注:由于用到了第三方的视频,故以上示例仅作为分享展示作用。 

        通过上述示例,我们就可以实现远程的云旅游了,即使在家也可以通过toio查看全国,乃至全世界的文物展示啦。toio的功能十分的强大,不同的编程方式搭配不同的创意就可以拥有不同的玩法。也希望可以看到越来越多的的玩家,创客,乃至开发者可以制作出丰富有趣的示例。 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/456863
推荐阅读
相关标签
  

闽ICP备14008679号