博客
关于我
独立按键
阅读量:363 次
发布时间:2019-03-04

本文共 622 字,大约阅读时间需要 2 分钟。

micro:bit按键控制灯的程序设计说明

本实验旨在通过micro:bit的按键与LED灯之间进行状态切换的控制。以下是实现该功能的详细步骤和代码实现。

实验目标

- 当按下按键(s1)时,改变LED灯的状态。 - 当松开按键后,LED灯恢复原来的状态。

实现步骤

1. **定义变量并初始化** - 使用`P3^2`作为输入端口,用于检测按键状态。 - `LED1`用于控制LED灯的状态。
  1. 按键检测与状态判断

    • 检测按键是否按下(即P3^2输入端口的值为低电平)。
    • 如果按键未按下(即P3^2==0),进入防抖动处理。
  2. 防抖动处理

    • 在松开按键前,延迟1秒以避免误触。
    • 当按键松开后,进入LED灯状态切换逻辑。
  3. LED灯状态切换

    • 当按键按下时,切换LED灯的状态(开启或关闭)。
    • 使用while(!s1)循环,确保只有在按键松开时才执行状态切换操作。
  4. C代码实现

    ```c: if(s1 == 0) { delay(1000); // 防抖动处理 if(s1 == 0) { LED1 = ~LED1; // 切换LED灯状态 } while(!s1); // 检测松开按键状态 } ```

    以上代码实现了按键与LED灯之间的状态控制逻辑。按键按下时,会先进入防抖动处理,随后切换LED灯的状态并保持在松开状态直到按键再次被按下。

    通过本实验,可以了解如何利用micro:bit的输入输出端口进行简单的按键控制,同时掌握防抖动处理的关键技术。

转载地址:http://pcyg.baihongyu.com/

你可能感兴趣的文章
OpenLayers 项目分析(三)-OpenLayers中定制JavaScript内置类
查看>>
Openlayers中使用Cluster实现点位元素重合时动态聚合与取消聚合
查看>>
Openlayers中使用Cluster实现缩放地图时图层聚合与取消聚合
查看>>
Openlayers中使用Image的rotation实现车辆定位导航带转角(判断车辆图片旋转角度)
查看>>
Openlayers中加载Geoserver切割的EPSG:900913离线瓦片图层组
查看>>
Openlayers中将某个feature置于最上层
查看>>
Openlayers中点击地图获取坐标并输出
查看>>
Openlayers中设置定时绘制和清理直线图层
查看>>
Openlayers图文版实战,vue项目从0到1做基础配置
查看>>
Openlayers实战:modifystart、modifyend互动示例
查看>>
Openlayers实战:判断共享单车是否在电子围栏内
查看>>
Openlayers实战:加载Bing地图
查看>>
Openlayers实战:绘制图形,导出geojson文件
查看>>
Openlayers实战:绘制图形,导出KML文件
查看>>
Openlayers实战:绘制多边形,导出CSV文件
查看>>
Openlayers实战:绘制带箭头的线
查看>>
Openlayers实战:输入WKT数据,输出GML、Polyline、GeoJSON格式数据
查看>>
Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
查看>>
Openlayers高级交互(11/20):显示带箭头的线段轨迹,箭头居中
查看>>
Openlayers高级交互(14/20):汽车移动轨迹动画(开始、暂停、结束)
查看>>