搜尋

OLED 文字跑馬燈

這篇教學會使用 MakeCode 編輯 micro:bit 擴充板程式 ( EZ Start Kit+ ),使用文字、陣列、變數、迴圈和函式互相搭配,做出在 OLED 顯示器上顯示文字跑馬燈的效果 ( 單行跑馬燈、多行跑馬燈、多行不同速度跑馬燈 )。

顯示陣列中的文字

文字跑馬燈的原理,就是將「文字拆成陣列,依序顯示陣列的每個項目」,所以第一步需要顯示陣列中的文字,下方的範例,會先將文字根據空字元「""」拆成陣列,接著再將陣列的前 16 個項目組合成新的文字,最後透過 OLED 顯示 ( EZ Start Kit+ 的 OLED 一行最多 16 個字 )。

micro:bit 擴充板 ( EZ Start Kit+ ) - OLED 文字跑馬燈

micro:bit 擴充板 ( EZ Start Kit+ ) - OLED 文字跑馬燈

單行文字跑馬燈

使用「重複判斷 true」積木進行不斷重複的動作,每次重複時除了組合要顯示的文字外,也會將陣列的第一個項目移動到最後,如此一來每次組合就都會是全新的文字 ( 少掉開頭,結尾多一個 ),搭配暫停積木,就可以在 OLED 顯示跑馬燈的文字。

micro:bit 擴充板 ( EZ Start Kit+ ) - OLED 文字跑馬燈

micro:bit 擴充板 ( EZ Start Kit+ ) - OLED 文字跑馬燈

多行文字跑馬燈

要實現多行文字跑馬燈效果,除了可以多次重複單行文字跑馬燈的程式,也可以使用函式來簡化重複的程式碼,新增一個名為 show 的函式,新增一個文字參數 text,以及三個數字參數 speed、x、y ( speed 為跑馬燈速度、xy 為 OLED 顯示位置 )。

micro:bit 擴充板 ( EZ Start Kit+ ) - OLED 文字跑馬燈

將單行跑馬燈的程式放入函式裡,按照下圖將部分固定的文字或數字,改成函式的參數 text、speed、x 和 y

micro:bit 擴充板 ( EZ Start Kit+ ) - OLED 文字跑馬燈

函式完成後,在啟動時使用不同的變數建立多組文字,使用「不同的重複無限次」積木,呼叫函式,並調整函式的參數。

為什麼要使用不同的重複無限次積木呢?因為函式裡使用了「重複判斷 true」積木,如果按照順序執行函式,會因為這塊積木導致後方的函式無法執行 ( 一直卡在前一個函式的無窮迴圈 ),所以必須使用不同的重複無限次積木避開這個問題

micro:bit 擴充板 ( EZ Start Kit+ ) - OLED 文字跑馬燈

由於 makecode 在定義變數時,通常是定義為「全域變數」,如果要同時呈現不同的跑馬燈文字,需要切換到 JavaScript 修改程式碼,按照下圖,移除下方紅色匡起來的部分剪下,上方紅色匡起來的部分前方補上 let

micro:bit 擴充板 ( EZ Start Kit+ ) - OLED 文字跑馬燈

完成後「不要切換回積木」( 因為切換回積木會將修改的程式還原 ),直接將程式燒錄到 micro:bit,就會看見多行跑馬燈的效果 ( 文字不同、速度不同 )。

micro:bit 擴充板 ( EZ Start Kit+ ) - OLED 文字跑馬燈

範例解答

延伸練習

如果已經熟悉了 EZ Start Kit+ OLED 文字跑馬燈的原理,還可以嘗試更多好玩的作法:

  • 修改「單行跑馬燈」程式,加入按鈕開關積木,按下 A 出現一組文字跑馬燈,按下 B 出現另外一組文字跑馬燈 ( 解答 )。

意見回饋

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

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 顯示手繪圖案 繼電器 + 紅外線遙控器