搜尋

按鈕依序開關燈

這篇文章會延續「依序點燈」一文,搭配「按鈕按下」、「函式參數」積木,做出按下按鈕 A 就依序亮燈,按下按鈕 B 就反向依序關燈的效果。

相關文章參考:依序點燈函式參數按鈕按下

積木程式原理

開啟「依序點燈」文章裡面的範例解答,使用範例積木繼續編輯 ( 開啟後點擊上方 Edit Code 按鈕 )。

範例連結:依序點燈

micro:bit - 按鈕依序開關燈

將滑鼠移到「定義函式」積木上方,按下右鍵,點選編輯函式

micro:bit - 按鈕依序開關燈

將函式新增一個「布林值」參數,命名為「關燈」。

micro:bit - 按鈕依序開關燈

在函式的下方,放入「如果...否則...那麼」積木,判斷如果關燈為 true 就不點亮這個 LED,如果關燈為 false 就點亮這個 LED。

micro:bit - 按鈕依序開關燈

接著要放入按鈕的程式,步驟如下:

micro:bit - 按鈕依序開關燈

完整得程式積木長相如下:

micro:bit - 按鈕依序開關燈

micro:bit 啟動之後,按壓 A 或 B 按鈕,就可以看到燈號依序亮起或關閉的效果。

micro:bit - 按鈕依序開關燈

範例解答

範例解答:按鈕依序開關燈

延伸練習

如果已經熟悉了按鈕依序開關燈的原理,還可以嘗試更多好玩的作法:

  • 上面的程式如果按下 A 或 B 超過 25 下,會造成數字大於 25 或小於 0,請修正這個問題 ( 解答 )。
  • 修改成只有一顆燈在移動 ( 解答 )。

意見回饋

如果有任何建議或問題,可傳送「意見表單」給我,謝謝~

micro:bit 教學

基本介紹

關於 micro:bit micro:bit 硬體規格 micro:bit 開發方式 使用 MakeCode 開始控制 micro:bit

程式積木

基本 輸入 輸入 ( V2 ) 輸入 ( 更多 ) 音效 音效 ( V2 ) 燈光 燈光 ( 更多 ) 廣播 廣播 ( 更多 ) 迴圈 邏輯 變數 數學

進階積木

函式 陣列 文字 圖像 遊戲 引腳 引腳 ( 更多、V2 ) 控制 序列

擴展積木

超音波 ( 偵測距離 ) 溫濕度 伺服馬達 紅外線接收 紅外線發射 MAX7219 點矩陣 LCD1602 顯示器 OLED1306 顯示器 TM1637 七段顯示器

入門範例

跳動的心 簡單煙火動畫 倒數計時放煙火 改變動畫預設時間 剪刀石頭布 ( 按鈕 ) 搖骰子 一直向下的箭頭 指北針 長條圖顯示亮度 光影魔術手 愛心呼吸燈 愛心小夜燈 按鈕秀文字 按鈕計數器 晃動計步器 顯示隨機圖案 空中傳愛 ( 廣播 ) 超時空跑馬燈 ( 廣播 ) 長條圖顯示音量 ( V2 ) 拍手換圖案 ( V2 ) 亮度樂器 ( V2 ) 翻轉大黃蜂音效 ( V2 )

燈光範例

燈光繞圈 ( 座標 ) 燈光繞圈 ( 數字函式 ) 循環霹靂燈 依序點燈 ( 座標 ) 依序點燈 ( 數字函式 ) 隨機不重複的燈 按鈕依序開關燈 平衡燈 ( 姿勢 ) 平衡燈 ( 旋轉感測 ) 陣列點燈 ( 顯示圖形 ) 陣列點燈 ( 動畫 ) 移動速度不同的燈

遊戲範例

小瑪莉遊戲機 射擊幽浮 記憶大考驗 翻轉吃豆子 猴子接香蕉 老鼠走迷宮 吃角子老虎機 太鼓達人 貪吃蛇 心電感應 ( 廣播 )

電子元件範例

閃爍的 LED 燈 全彩 LED 光線變化 長條圖顯示土壤濕度 小夜燈 ( 光敏電阻 ) LED 顯示溫濕度 LCD1602 顯示溫濕度 超音波倒車雷達 七段顯示器顯示距離 人體紅外線偵測 旋鈕控制 LED 亮度 電流急急棒 OLED 繪製數學圖形 OLED 顯示手繪圖案 觸碰開燈 ( 引腳按下 ) 觸碰開燈 ( 類比訊號 ) 水果鋼琴 ( 類比訊號 )

MoonCar 自走車

MoonCar 教學導讀 關於 MoonCar 自走車 程式積木介紹 控制移動和轉彎 七彩魔幻 LED 超音波隔空推車 超音波倒車雷達 超音波隔空彈鋼琴 超音波自動避障 偵測和辨識顏色 辨識顏色+演奏音樂 辨識顏色+控制移動 紅外線遙控器控制移動 micro:bit 廣播遙控 趨光性自走車 指北車 ( 永遠轉向北方 ) 循跡自走車 循跡自走車+辨識顏色 聽到聲音就移動 ( V2 )

EZStartKit 擴充板

EZ Start Kit 教學導讀 關於 EZ Start Kit+ 程式積木介紹 LED 基本控制 LED + 按鈕開關 LED + 可變電阻 LED 光感應小夜燈 RGB LED 基本控制 RGB LED + 紅外線遙控器 OLED 顯示文字與數字 OLED 顯示動態數字 OLED 文字跑馬燈 OLED 繪製圖形 OLED 繪製正弦波圖形 OLED 倒數計時器 OLED 顯示手繪圖案 繼電器 + 紅外線遙控器