Skip to content

Micro:bit 模拟传球小程序

6 1536765823

今天我们来实现一个模拟传球小程序,通过按键 A 和 B 来控制球( led 小灯)左右移动,通过这个小程序,你将了解到如何使用 Micro:bit 提供的逻辑、循环、事件和选择模块。需要注意的一点是,学习编程的重点在于学习思考问题解决问题的过程,编程本身只是一个工具,是为了帮你解决问题的工具,如何思考才是最重要的。

[amazon_link asins=’B0746C94ZW,B077ND7YJ4,B077BVZKZ4′ template=’CopyOf-ProductGrid’ store=’boyd-23′ marketplace=’CN’ link_id=”]

效果图:

Micro:bit 模拟传球小程序

实现的功能

  1. 程序开始时,一个小球( led 小灯)从屏幕上方移动到屏幕中间

  2. 当按钮 A 按下时,小球向右移动,碰到屏幕边缘停止

  3. 当按钮 B 按下时,小球向左移动,碰到屏幕边缘停止

  4. 如果小球已经处于屏幕最右边,此时按下按钮 A,给出箭头提示按按钮 B,因为小球无法再往右移动

  5. 如果小球已经处于屏幕最左边,此时按下按钮 A,给出箭头提示按按钮 B,因为小球无法再往左移动

  6. 如果小球正向右移动,此时按下按钮 B,小球向左移动

  7. 如果小球正向左移动,此时按下按钮 A,小球向右移动

知识点

  • led 点阵及坐标

  • 循环

    • 无限循环

    • 条件循环

  • 按钮按下事件

  • 逻辑判断

  • 精灵

知识点解析

led点阵及坐标

Micro:bit 自带了一个 5×5 的 led 点阵屏,可用于文字或图型展示,左上角为  (0,0) 点,右下角为 (4,4) 点,水平方向(从左到右)为 x轴 方向,依次递增 [0-4],垂直方向(从上到下)为 y轴 方向,依次递增 [0-4],

Micro:bit 模拟传球小程序

各个点坐标分布如下 (x,y) :






(0,0) (1,0) (2,0) (3,0) (4,0)
(0,1) (1,1) (2,1) (3,1) (4,1)
(0,2) (1,2) (2,2) (3,2) (4,2)
(0,3) (1,3) (2,3) (3,3) (4,3)
(0,4) (1,4) (2,4) (3,4) (4,4)

循环

无限循环

无限循环,可以参考 前导知识-程序的流程与基本概念 里面关于无限循环的解释,顾名思义,就是一直会进行下去的循环,从进入循环体开始,从上到下执行,实行完毕后会回到循环体开头再从上到下执行循环体。

无限循环 模块位于 基本 分类下

Micro:bit 模拟传球小程序

有条件循环

有条件循环与无限循环的不同点在于,有条件循环是带条件判断的,如果条件满足,就进入循环体执行,执行完一遍之后,再次判断条件,如果条件成立,则继续从上到下执行循环体,否则不继续执行循环体。

Micro:bit 提供了 4 种有条件循环,位于 循环 分类下

  • 固定执行次数循环

  • 带条件判断循环

  • 带索引循环

  • 遍历数组循环


详细解释见下图

Micro:bit 模拟传球小程序

按钮按下事件

按钮按下事件是事件的一种,关于 事件 这一概念可以参考 前导知识-程序的流程与基本概念 里面关于事件的解释,即当某个按钮被按下时应该执行的动作,micro bit 自带了 3个按钮,分别是正面的 A B 按钮和背面的 重置 按钮,但是 重置 按钮的行为不能被更改,默认为重新执行程序,因此没有对应的事件,并且 A B 可以同时按下,所以有 3 个按钮按下事件,位于 输入 分类下

  • 当按钮 A 按下

  • 当按钮 B 按下

  • 当按钮 A+B 同时按下

Micro:bit 模拟传球小程序


逻辑判断

逻辑判断模块位于 逻辑 分类下,具体解释如下图

Micro:bit 模拟传球小程序

其中,选择结构可以相互组合组成更为复杂的选择结构,比如下面的例子包含了 3个选择结构,组成了逻辑:

如果 item > 01
   如果 item = 52
       显示数字 5
   显示数字 1
否则
   如果 item = 03)
       显示数字 0
   显示数字 -1

Micro:bit 模拟传球小程序

举个例子,当 item 为 5 时,将显示数字 5 和 1,当 item 为 -2 时,显示数字 -1

精灵

精灵是游戏编程里一个常用的概念,精灵代表了一个角色,或是一个人物,在 Micro:bit 里它是一个LED,我们可以控制它进行游戏,它可以移动,可以检测有没有和其他精灵或者屏幕边缘碰撞,它可以有各种各样的属性,比如它当前的位置,它当前的方向等,我们可以在 游戏 分类下找到这些模块。

Micro:bit 模拟传球小程序

思路

了解完了知识点,我们来理一理实现思路。

  1. 当开机时,创建一个精灵,控制它从屏幕顶端移动到屏幕中间,即 y 坐标 增加 2 次

  2. 精灵会不停朝一个方向移动,需要用到一个循环,不停向当前方向移动 1

  3. 当按下按钮 A 时,精灵向右移动,控制精灵的 x 坐标每次加 1

  4. 当按下按钮 B 时,精灵向左移动,控制精灵的 x 坐标每次减 1 (增加 -1)

  5. 当按下按钮 A 时,如果精灵碰到屏幕右边,则显示指向按钮 B 的箭头

  6. 当按下按钮 B 时,如果精灵碰到屏幕左边,则显示指向按钮 A 的箭头

注意上面的用词,当 xxx 时,代表了一个 事件,如果 xx 则 xx,代表了一个 选择结构

思考题: 知识点和思路都教给你了,思考下如何运用上面提到的模块实现这个游戏呢?

实现

接下来我们一步一步完成这个游戏:

  1. 「基本」->「当开机时」模块到编程区

  2. 「变量」->「设置变量」,取名为 jingling

  3. 「游戏」->「创建精灵」,坐标改为 x : 2,y : 0

  4. 「变量」->「将 item 设为」上一步 的模块,把 item 改为 jingling

  5. 「基本」->「暂停」模块,暂停 500ms

  6. 「循环」->「固定次数循环」模块,设置重复次数为 2  次

  7. 「游戏」-> 「更改 x 幅度为 1」模块到「固定次数循环」里,把 x 改为 y

  8. 「基本」->「暂停」模块到「固定次数循环」里,暂停 500ms


    Micro:bit 模拟传球小程序

  9. 「变量」->「设置变量」,取名为 fudu,值为0

  10. 「基本」->「无限循环」

  11. 「游戏」-> 「更改 x 幅度为 1」模块,1 改为 变量 fudu,由于 fudu 默认为 0,因此精灵不移动

  12. 「基本」->「暂停」,暂停 500ms


    Micro:bit 模拟传球小程序

  13. 「输入」->「当按钮A按下时」

  14. 「逻辑」->「x = x」,第一个 x 换成「游戏」->「jingling x」,第二个参数改为 4,即 jingling 在最右侧

  15. 「逻辑」->「如果为」,条件改成 上一步 的条件

  16. 「基本」->「显示 LED」到「如果为」里,画一个向右的箭头

  17. 「基本」->「暂停」模块到「如果为」里,暂停 500ms

  18. 「变量」->「将 item 设为」1,把 item 改为 fudu,这样按下 A 时 jingling 就会不停加 1,即向右移动


    Micro:bit 模拟传球小程序

  19. 选中「当按钮A按下时」按 Ctrl + C 复制,并按 Ctrl + V 粘贴

  20. 更改 上一步 粘贴的模块,把 按钮 A 改为 按钮 B,「如果为」条件改为 = 0

  21. 箭头改为 向左

  22. fudu 改为 -1


    Micro:bit 模拟传球小程序

然后就完成啦,oh~yeah~

完整程序图

Micro:bit 模拟传球小程序

hex 文件下载: hex 文件(请右键另存为)

始发于微信公众号: 暴王不暴燥

4.6 11 votes
Article Rating
Subscribe
Notify of
guest

This site uses Akismet to reduce spam. Learn how your comment data is processed.

0 Comments
Oldest
Newest Most Voted
Inline Feedbacks
View all comments
0
Would love your thoughts, please comment.x
()
x