索尼 toio™应用创意开发征文|一步两步三步模拟浇花系统

news2024/9/27 19:20:32

目录

1.toio™介绍

2、创意分析

2.1 创意设计

2.2 创意落地

3、创意实现

3.1 环境安装

3.2 核心玩法

总结


1.toio™介绍

索尼的toio™是一款启发创意的机器人产品,旨在通过与真实世界的互动,为各年龄段的用户提供娱乐体验。这款产品具有高度的灵活性和可定制性,可满足编程初学者、高级用户和专业开发者的多样STEAM学习和编程需求。

toio™核心Q宝是一款仅有乒乓球大小的白色立方体,但它能够创造各种广泛的应用和娱乐方式。这个开源机器人的规格和应用程序接口都是公开的,可以通过多种编程语言和平台,如JavaScript、Python、Unity和可视化编程等,来创作各种丰富的应用和创意作品。通过toio™开发者们能够以更加直观的方式与数字世界互动,通过身体动作、手势、声音等多种方式来打造创新而沉浸式的体验。

资料地址:

Python教程:https://github.com/toio/toio.py/blob/main/SETUP_GUIDE.zh.md

CSDN报道:开发创想,灵感跃动,索尼 toio™应用创意开发征集活动即将开启_CSDN资讯的博客-CSDN博客

官方网站:索尼toio™教育方案

2、创意分析

2.1 创意设计

基于toio™自动浇花系统,我们可以进一步扩展创意,打造一个智能植物养护系统。该系统可以通过传感器监测土壤湿度、空气温度以及光照强度,并根据设定的条件进行智能化的植物养护。系统可以收集并分析植物生长的数据,比如土壤湿度、光照强度和温度等。通过机器学习算法,系统可以逐渐学习不同植物的生长模式,并根据实际情况进行优化调整,以提供更加个性化的养护方案。

2.2 创意落地

在查看资料之后发现Q宝真是个玩具,没有外接接口无法接收传感器的信息,这里只能选择模拟行为。我这里直接使用Python做一个随时间衰减的土壤密度函数,等土壤密度达到临界值Q宝会发出提醒并重置土壤密度函数。总共使用两个Q宝,一个Q宝做检测土壤密度,待达到临界之后Q宝会亮起红灯,一个Q宝移动过去重置,发信息交互之后重置检测函数,后期再研究之后看是否能通过蓝牙接收真实传感器数据。

3、创意实现

3.1 环境安装

环境安装主要是跟着Github资料进行安装,主要脚本如下:

setuptools

安装setuptools软件包,命令如下:

python -m pip install setuptools --upgrade

toio.py

安装toio.py软件包,命令如下:

python -m pip install toio-py --upgrade

bleak

安装bleak软件包,命令如下:

python -m pip install bleak

ipykernel

安装ipykernel软件包,命令如下:

python -m pip install ipykernel

确认

在命令提示符下执行以下命令进行验证,查看toio.py是否按照成功。

python -c "import toio.scanner; print('ok')"

若屏幕中显示“ok”,说明toio.py已成功安装。

若屏幕中显示“ImportError”,说明导入失败,请尝试重新安装.wh1文件,并确保已经进入到保存该文件的目录中。 若再次显示安装失败 请检查python的版本,确保python版本为3.11及以上。

3.2 核心玩法

核心代码:

import asyncio
from asyncio import sleep

from toio import *

green_cube_location = None
red_cube_arrived = True
wait_time = 30

async def check():
    global green_cube_location
    global red_cube_arrived
    # 获得位置
    def pos_handler(payload: bytearray):
        global green_cube_location
        id_info = IdInformation.is_my_data(payload)
        if isinstance(id_info, PositionId):
            green_cube_location = id_info.center

    def move_handler(payload: bytearray):
        global red_cube_arrived,wait_time
        motor_response = Motor.is_my_data(payload)
        if isinstance(motor_response, ResponseMotorControlTarget):
            print(motor_response)
            red_cube_arrived = True
            wait_time = 30
    # 连接两个cube
    dev_list = await BLEScanner.scan(2)
    assert len(dev_list) == 2
    detector_cube = ToioCoreCube(dev_list[0].interface)
    change_detect = ToioCoreCube(dev_list[1].interface)

    print("连接成功")
    await asyncio.gather(detector_cube.connect(), change_detect.connect())

    red = IndicatorParam(duration_ms=0, color=Color(r=255, g=0, b=0))

    green = IndicatorParam(duration_ms=0, color=Color(r=0, g=255, b=0))

    await asyncio.gather(
        detector_cube.api.indicator.turn_on(green), change_detect.api.indicator.turn_on(red)
    )

    print("展示吧小宝贝")
    while True:
        wait_time = wait_time -1
        # 时间到了,移动过去
        if wait_time == 0:
            await detector_cube.api.id_information.register_notification_handler(
                pos_handler
            )
            await change_detect.api.motor.register_notification_handler(move_handler)

            for _ in range(30):
                if green_cube_location is not None and red_cube_arrived:
                    red_cube_arrived = False
                    print("change_detect: move to", str(green_cube_location))
                    await change_detect.api.motor.motor_control_target(
                        timeout=5,
                        movement_type=MovementType.Linear,
                        speed=Speed(
                            max=100,
                            speed_change_type=SpeedChangeType.AccelerationAndDeceleration,
                        ),
                        target=TargetPosition(
                            cube_location=green_cube_location,
                            rotation_option=RotationOption.AbsoluteOptimal,
                        ),
                    )

                await asyncio.sleep(1)

            await change_detect.api.motor.unregister_notification_handler(move_handler)
            await detector_cube.api.id_information.unregister_notification_handler(
                pos_handler
            )
            # 停一秒
            await sleep(1)
    print("结束,断开链接")
    await asyncio.gather(detector_cube.disconnect(), change_detect.disconnect())
# 启动
asyncio.run(check())

解决的问题

  • 连接Q宝,进行程序上传
  • Q宝进行通讯
  • Q宝移动
  • 土壤函数衰减和重置
  • Q宝亮灯

上面代码基本上都是官方代码的拼凑,用起来还是比较简单的。

总结

1、在测试的过程中,Q宝的官网和github提供了足够的资料和翔实的代码实例,对于拥有变成经验的同学来说还是很方便的,只要稍微组合就可以开发出自己的玩法。

2、toio™当前作为小孩子的玩具是很好的,在可用的条件下做出一些有意思的事情,也能锻炼小孩的思考能力。

对于Q宝这类小机器人未来的方向应该是在于教育和培训,小型机器人可能成为教育领域的有力助手,通过个性化的教学方法和互动学习,提高孩子的学习兴趣,提升教育质量。

3、当前还是存在一些不方便的地方,比如不能联网限制了数据的获取,不能外接限制了扩展,还有就是价格略贵,作为教学工具还可以。但如果可以增加高级版本,在高级版本中可以增加一些拓展接口,这样Q宝会具有更多灵活性和扩展性,也会在未来发展的越来越好。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/985078.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【已解决】pyqt5的打包exe软件图标菜单栏/任务栏/小图标/窗口图标未显示

1.起因: 希望:pyqt5 项目,pyinstaller main.spec 打包,我想要 main.exe 就像一个普通的应用软件一样显示我自定义的图标。 结果: main.exe 左侧图标还是老土的样子,并没有成为我的图标。独立运行是&#…

API接口与电商平台之间的联系,采集京东平台数据按关键字搜索商品接口示例

关键字搜索商品的重要性: 1.引入精准流量 关键词第一个也是最重要的作用就是为我们宝贝引进精准的流量,这一作用无论是在自然搜索中还是直通车中都是一样的。 第一步关乎的是我们宝贝的展现,而第二步用户是否会点进我们的宝贝,…

爬虫爬取mp3文件例子

相信训练模型时数据集的获取也是一个很头疼的事情,搞cv领域的可以扛着摄像头架起三脚架拍摄获取(以前干过),但是如果是nlp领域的呢,特别是chatgpt等大模型出来后对这类文本等数据的需求更大,如果没有现成的…

攻防世界-WEB-Web_php_include

打开靶机 通过代码审计可以知道,存在文件包含漏洞,并且对伪协议php://进行了过滤。 发现根目录下存在phpinfo 观察phpinfo发现如下: 这两个都为on 所以我们就可以使用data://伪协议 payload如下: - ?pagedata://text/plain,…

测试可用的淘宝API(商品详情数据、买家信息、卖家信息、店铺信息、订单信息)

什么是API? API全称Application Programming Interface,即应用程序编程接口,是一些预先定义的函数,或指软件系统不同组成部分衔接的约定,用于传输数据和指令,使应用程序之间可以集成和共享数据资源。 简单来说&#…

SQL语言的分类:DDL(数据库、表的增、删、改)、DML(数据的增、删、改)

数据库管理系统(数据库软件)功能非常多,不仅仅是存储数据,还要包含:数据的管理、表的管理、库的管理、账户管理、权限管理等。 操作数据库的SQL语言,基于功能,划分为4类: 1、数据定…

64位Office API声明语句第110讲

【分享成果,随喜正能量】以大慈为所住,给一切众生快乐,观众生心与菩萨心平等平等。以大悲为住处,不轻末学,善根成熟了他会发心,将来也能成佛。舍有为而不执著无为,住无为而不舍有为,…

正方实践系统打卡

Use HTTP (已完成) 📜 使用指南 🛖 项目结构 log 日志文件 use 使用情况 (待) data.py 数据 log.py 日志 main.py 主函数 只需要修改data.py文件内容即可: header ——> 头文件 User-AgentCookieAccept user ——> 用户信息 ZFT…

Kafka3.0.0版本——消费者(消费者组详细消费流程图解及消费者重要参数)

目录 一、消费者组详细消费流程图解二、消费者的重要参数 一、消费者组详细消费流程图解 创建一个消费者网络连接客户端,主要用于与kafka集群进行交互,如下图所示: 调用sendFetches发送消费请求,如下图所示: (1)、Fet…

RabbitMQ: Routing结构

生产者 package com.qf.mq2302.routing;import com.qf.mq2302.utils.MQUtils; import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection;public class EmitLog {public static final String EXCHANGE_NAME"emitlogs";public static void main(…

基于Jmeter和Jenkins搭建性能测试框架

搭建这个性能测试框架是希望能够让每个人(开发人员、测试人员)都能快速的进行性能测试,而不需要关注性能测试环境搭建过程。因为,往往配置一个性能环境可能需要很长的时间。 1、性能测试流程 该性能测试框架工作的流程主要有&am…

【代码随想录】dfs和bfs (所有可能的路径、岛屿数量)

所有可能的路径&#xff1a; 力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 class Solution { public:vector<int> path;vector<vector<int>> result;void dfs(vector<vector<int>> graph, int x){//1 确认递归函数…

Java日志框架的扛把子 - SLF4J - SLF4J的原理和实践

1. Java世界中的日志框架 Java世界中的日志框架 其中&#xff0c;slf4j和jcl属于门面日志框架&#xff0c;而其它的几个则是真正干活的ddidic底层日志框架。冷知识&#xff1a;其中标红的日志框架&#xff0c;它们的作者是同一人。不同的日志框架&#xff0c;API接口往往也不一…

解锁前端Vue3宝藏级资料 第一章 带你深入了解Vue3项目创建 2 (使用 Webpack 5 搭建 vue项目)

在之前的文章中&#xff0c;我们已经了解了如何使用Vue CLI来创建Vue项目的开发环境。现在&#xff0c;大家已经可以轻松地运用Vue CLI来构建自己的Vue项目了。然而&#xff0c;你可能仍然对背后的工作原理感到困惑。接下来&#xff0c;我将引导你们在不使用Vue CLI的情况下&am…

Python超入门(1)__迅速上手操作掌握Python

# 1.第一个代码&#xff1a;输出语句 # 1.第一个代码&#xff1a;输出语句 print("My dogs name is Huppy!") print(o----) print( ||| ) print("*" * 10) """ 输出结果&#xff1a; My dogs name is Huppy! o----||| ********** "&…

私有化部署即时通讯平台,完美替代飞书和钉钉的SaaS系统

在当今快速发展的数字化时代&#xff0c;企业对于安全、灵活、可定制的即时通讯平台需求不断增长。作为一家领先的品牌&#xff0c;WorkPlus专注于提供私有化部署的即时通讯平台&#xff0c;完美替代飞书和钉钉的SaaS系统。本文将重点介绍WorkPlus如何通过创新的解决方案&#…

2023高教社杯数学建模B题思路分析 - 多波束测线问题

# 1 赛题 B 题 多波束测线问题 单波束测深是利用声波在水中的传播特性来测量水体深度的技术。声波在均匀介质中作匀 速直线传播&#xff0c; 在不同界面上产生反射&#xff0c; 利用这一原理&#xff0c;从测量船换能器垂直向海底发射声波信 号&#xff0c;并记录从声波发射到…

【MATLAB第72期】基于MATLAB的LightGbm(LGBM)梯度增强决策树多输入多输出回归预测模型

【MATLAB第72期】基于MATLAB的LightGbm(LGBM)梯度增强决策树多输入多输出回归预测模型 一、学习资料 (LGBM)是一种基于梯度增强决策树(GBDT)算法。 往期研究了多输入单输出回归预测方法&#xff0c;本次研究多输入多输出回归预测。 参考链接&#xff1a; lightgbm原理参考链…

高德地图API使用教程

高德地图API使用教程 开发前准备获取key值和相关安全密钥 简单使用需求开发h5范围打卡-vue3地图选点-vue3 开发前准备 获取key值和相关安全密钥 进入高德开放平台 https://lbs.amap.com/ 登录后&#xff0c;打开我的应用&#xff08;无账号要先注册&#xff09; 打开我的应用…

3dsmax 蒙皮替换骨架

需求 本文描述部分来源于 TAZORN&#xff0c;最后附上Python实现 保留蒙皮信息&#xff0c;将骨骼替换成新的骨架模型M上的Skin目前指定的是骨架A&#xff0c;在蒙皮信息不变的情况 下更换成骨架B 替换的操作需要用到 SkinUtilities 工具 手动进行骨骼替换的方法 Snapshot原…