Micro:Bit手柄试用之一MagicPad (解决蓝牙与gamePad包共存)

前言

原创文章,转载引用务必注明链接。由于本人初次接触Micro:Bit,水平有限,如有疏漏,欢迎指正。

Micro:Bit真好玩!

DFRobot的论坛相关资料算是国内比较丰富的了,个人感觉MB比Arduino更有趣!感谢DFRobot,总会带来各种新奇、有趣价格相对不贵的模块,无论是Intel Edison还是micro:bit,都设计了大量模块,非常棒。文章原载于DFRobot论坛。

1、MagicPad设想

这次拿到micro:bit gamepad 遥控手柄 ,把玩了一下,发现很多神奇的功能,查阅了大量资料文档,算是管中窥豹,后续会分享给大家。这次做一个小项目,涉及到部分知识。目前想做的是:mb作为蓝牙遥控器,控制手机拍照(自拍)、查找手机、自动切歌、丢失报警(GamePad震动)等等。

2、硬件解析

这里用到的硬件如下:

micro:bit会在另一篇文章里进行介绍,其具有加速度与电子罗盘、温度及亮度传感器。这里主要说说DFRobot出品的GamePad拓展板。

2.1 GamePad 4 MicroBit by DFRobot

FmeFt66nRP0WLYDvOcgXIoiRxPUk

板载资源包括:

8个可编程按键,1个振动电机,一个蜂鸣器,一个LED 。

相关资料可以在产品维库上找到,文档上提供了诸多示例,把玩了一下,非常有趣。然而由于产品并不是开源硬件,没有提供相关硬件引脚信息,只有封装好的MakeCode操作库,经过一番思索查找,在官方产品github页面找到引脚定义。

2.2 寻找 GamePad 引脚定义

687474703a2f2f77696b692e6466726f626f742e636f6d2e636e2f696d616765732f392f39382f444652303533362545352541342539362545352542442541322545352539422542452e706e67

  1. 从面板上可以看到标记了部分引脚如P0、P12、P16等,另外A、B就是复用microbit板上的A、B按钮。

  2. 打开main.ts文件,第20行看到如下代码:

    5b10dcf02d418.png

   enum GamerBitPin {
       //% block="X button"
       P1 = <number>DAL.MICROBIT_ID_IO_P1,
       //% block="Y button"
       P2 = <number>DAL.MICROBIT_ID_IO_P2,
       //% block="D-PAD up"
       P8 = <number>DAL.MICROBIT_ID_IO_P8,
       //% block="D-PAD down"
       P13 = <number>DAL.MICROBIT_ID_IO_P13,
       //% block="D-PAD left"
       P14 = <number>DAL.MICROBIT_ID_IO_P14,
       //% block="D-PAD right"
       P15 = <number>DAL.MICROBIT_ID_IO_P15,
   }

至此,我们结合相关,可知对应引脚信息如下:

引脚对应
P1按钮X
P2按钮Y
P8按键UP
P13按键Down
P14按键Left
P15按键Right
P5按键A
P11按键B
P0Buzzer|蜂鸣器
P16LED
P12Vibrator|振动器

参考mb引脚定义:

edge_connector.svg

P0/P1/P2又叫TouchPin,就是那三个大的引脚,其中音乐通常从P0输出。

2.3 测试一下

我们不借助DFRobot提供的MakeCode软件包,直接使用相关引脚看看:

https://makecode.microbit.org/_Cxpdt5MEVE8f

5b10ebc153b0f.png

【直接操作引脚模式】注意初始化引脚方向,否则会乱跑。TouchPi和BtnA/B好像会初始化执行这一操作。但是程序会跑飞,需要进一步测试完善。

5b10ebc155424.png

【DFRobot软件包操作模式】简洁很多,而且程序稳定。

3、软件部分

mb有诸多开发语言及开发环境可供选择,这里我们以MakeCode为例。

3.1 microbit Client —— MakeCode

MakeCode由微软开发,基于PXT (Programming eXperience Toolkit ),这种Visual Blocks开发最早在Scratch上看到,后来用过Webduino Blockly在线编辑器,彼时个人对它评价颇低

5b10ee4fc65cd.png

这次拿到mb本来是奔着microPython去的,其间测试的时候用了一下MakeCode,甚是喜欢,支持自定义函数,提供丰富的文档和拓展支持,下限上限都非常高,既适合小孩子入门,面对更复杂的需求也能完成。

由于我们的设想是mb通过蓝牙控制手机,所以需要使用Bluetooth软件包,但是添加DFRobot官方的gamePad包时会提示冲突。

5b10f1a8963a0.png

这优点类似radiobluetooth包的冲突,那么如何解决呢?想到两个思路:

  • 加法:既然知道了引脚定义,我们不用gamePad包,直接操作相关引脚
  • 减法:使用官方提供的更为完善的gamePad包,进行移植修改及删减,由于软件包较小,这也未尝不可
3.1.1 加法

在直接操作Pin的示例中,D-Pad多按几次程序就跑飞了,如图所示显示乱码,mb无响应。回过头来,看到on pin Px pressed模块比较稳定,但是仅限于3个TouchPin,有没有类似的手写模块呢?我们找到了在控制组件里找到on event模块,拖拽右击选择help,可以看到相关帮助手册。

5b10f31339586.png

看了相关的1/2/3/4/5,表示还没看懂,这里按下不表,后面搞懂再来。

3.1.2 减法

思路就是剥离gamePad包里面与蓝牙功能冲突的部分,只保留需要的功能,这就需要阅读gamePad源码进行修改移植,本以为很难,不想十分简单。

参考如下:

阅读MakeCode关于Creating Packages相关的手册内容,我们了解到了pxt.json文件,打开github上gamePad包的主页,果不其然:

{
    "name": "gamePad",
    "version": "0.0.0",
    "description": "This library is DFRobot gamer:bit provides the game handle control function.",
    "license": "GNU",
    "dependencies": {
        "core": "*",
        "radio": "*"
    },
    "files": [
        "README.md",
        "gamerpad.cpp",
        "main.ts",
        "_locales/zh/gamePad-strings.json"
    ],
    "testFiles": [
        "test.ts"
    ],
    "public": false
}

第8行"radio": "*"提示该软件包依赖radio包,但是radiobluetooth冲突,因此解决方法显而易见,我们fork一份gamePad包到自己的github账户下,修改pxt.json文件,删除radio包依赖,其实gamePad并不需要无线电功能才能运行,希望Lee可以改动一下。这里我改好的包地址为:

https://github.com/sjqlwy/pxt-gamePad

添加我的软件包地址即可以同时使用GamePad与蓝牙功能了。

5b10f6fccf667.png

至此我们解决了开发环境的冲突问题。

3.2 Android Server —— micro:bit APP

手机上需要安装一个服务软件,用来连接mb,并响应mb的指令。一种方式是使用可视化的MIT APP Invetor自己写程序,我们这里使用现成的micro:bitAPP即可,google play下载地址,无法访问的请下载附件。
5b10f835d5f9a.png

4、开始动手!

目前实现的功能包括:

  • 蓝牙控制
  • 照片视频拍摄控制(切换前后摄像头)
  • 音乐播放控制(音量+/-,切换歌曲)
  • Find My Phone
  • 手机丢失告警

代码如下:

https://makecode.microbit.org/_5aY3heCgtLud

5b150e29e43e6.png

这里我们借助Devices包中的相关block,如果你默认使用的是Radio包,则需要手动添加并替换radio。

部分说明:

  1. D-Pad控制音量加减和歌曲前后切歌,需要事先打开音乐播放器,如网易云音乐。
  2. 按A键开启前置摄像头5s后自拍,摇晃mb切换前后摄像头
  3. 按Y键,只要手机在蓝牙范围内,则会相应,这样就不怕手机丢在角落找不到了
  4. 当手机-mb之间距离发生变化时(读取RSSI值Received signal strength indication),进行判断,返回0-4的数值,0=no signal,4=full signal

下载烧录此程式到mb后,在Android手机上你需要执行以下步骤:

  1. 把MakeCode生成的hex文件拷贝到microbit磁盘内
  2. 在安卓手机上,如果micro:bit已经在已配对设备里,则选择取消保存。每次更新hex文件都要取消配对并重新配对,否则蓝牙通讯会失败。
  3. 在手机上运行Samsung micro:bit程序,选择Connect并与micro:bit进行配对。
  4. 按照图示操作让mb进入蓝牙配对模式:同时按住A和B键,短按Reset键,此时可以看到显示“PARING MODE”,松开A和B键。
  5. 回到手机端,输入密钥即可完成配对。
  6. reset键重置mb使其进入我们烧入的程序,初始化成功会显示一个笑脸。
  7. 手机端选择mb进行连接,成功后mb会显示"C"(Connected),断开会显示"D"(Disconnect)。
  8. 使用相关按键就可以实现功能了,快去试一试

5、后记

  • 官方也提供了iOS的程序,但是本人没条件测试
  • 测试过程使用microUSB供电,会出现不稳定情况
  • 目前我们实现了mb远程控制手机的功能,了解了基础的蓝牙操作,下一步尝试安卓蓝牙串口发送自定义程序;APP Inventor手写程序;mb与Linux 蓝牙串口通讯
  • 看到论坛里遥控小车用的mb作为主控,两块mb进行通讯更方便些,后面会尝试手写BeagleBone Blue|RPi的Linux蓝牙服务端与mb连接接收控制,暂时还没看到有人做

转载于:https://www.cnblogs.com/sjqlwy/p/mb_magicpad.html

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值