跳到主要內容

以程式控制樹莓派 Raspberry Pi 的 ACT LED 指示燈

以程式控制樹莓派 Raspberry Pi 的 ACT LED 指示燈

這裡介紹如何撰寫程式控制樹莓派(Raspberry Pi)板子上內建的 ACT LED 指示燈。
樹莓派 Raspberry Pi B+ 上面有一個綠色的 ACT LED 指示燈,在預設的狀況下只要系統有存取 MicroSD 卡時,這個指示燈就會發亮,而這個指示燈也可以讓使用者透過程式來控制,依照使用的需求來動作。

首先進入 code 目錄中:
cd /sys/class/leds/ACT
這個目錄中包含了所有控制 ACT LED 指示燈會用到的系統檔案。
raspberry-pi-control-act-led-2

trigger

trigger 是用來設定指示燈觸發條件的檔案,預設的 trigger 設定會是 mmc0(MultiMediaCard),代表存取 MicroSD 卡時觸發 LED 指示燈,如果您將 trigger 這個檔案直接用 cat 輸出,其內容會像這樣:
none [mmc0] timer oneshot heartbeat backlight gpio cpu0 default-on
中括號代表目前所選擇的觸發條件,而其餘的都是使用者可以選擇的選項,以下介紹各種選項的使用方式。

手動控制指示燈

如果要完全使用手動控制指示燈,可以將觸發條件設定為 none
sudo sh -c 'echo none > trigger'
或是直接切換成 root 再執行也可以:
sudo su
echo none > trigger
然後再更改 brightness 的內容來控制燈號,設為大於 0 的值會讓指示燈開啟:
sudo sh -c 'echo 1 > brightness'
設定為 0 則會讓指示燈關閉:
sudo sh -c 'echo 0 > brightness'
brightness 的值可以設定的範圍是從 0 到 max_brightness 的值(也就是 255)之間,在一般的 Linux 下使用者可以透過 brightness 調整 LED 的亮度,不過由於 Raspberry Pi 的硬體不支援亮度的調整,只能開啟或是關閉,所以在 Raspberry Pi 上面,只要將 brightness 設定為大於 0 的值,不管其值為何,效果都是一樣的(都是開啟 LED 指示燈)。

One-shot LED Trigger

這種觸發條件適合用於一些沒有明確開啟與關閉的事件,使用這種觸發條件時,使用者只需要在事件發生時送出訊號,而指示燈在收到觸發訊號時會開啟,經過一小段時間後自動關閉。
這種觸發條件可以同時適用於較稀疏或是較密集的觸發事件,如果觸發事件很稀疏,那麼每一個事件觸發時指示燈就會閃一下,而如果觸發事件非常密集而且連續不斷,那麼指示燈就會以固定的頻率持續閃爍,表示持續有事件被接收到。
在使用這種觸發事件時,首先將 trigger 設定為 oneshot
sudo sh -c 'echo oneshot > trigger'
然後將 shot 設定為 1 來觸發事件:
sudo sh -c 'echo 1 > shot'
如果要更改持續事件的閃爍頻率,可以修改 delay_on 與 delay_off 兩個檔案內容:
sudo sh -c 'echo 33 > delay_on'
sudo sh -c 'echo 33 > delay_off'
這樣持續觸發事件閃爍的頻率就是 1 / (33 + 33) Hz。
一般來說觸發事件時,指示燈會開啟,平常如果沒有事件的時候,指示燈是熄滅的。而這個邏輯規則可以靠 invert 來調整,如果 invert 設定為 0(這是預設的狀況):
sudo sh -c 'echo 0 > invert'
指示燈在觸發時會開啟 delay_on ms,然後關閉 delay_off ms,如果設定為 1
sudo sh -c 'echo 1 > invert'
則會相反,在事件觸發時指示燈會關閉 delay_off ms,然後開啟 delay_on ms,平常沒有事件時,指示燈則是保持開啟的狀態。

以 CPU 狀態觸發

依照 CPU 的狀態觸發指示燈:
sudo sh -c 'echo cpu0 > trigger'
當 CPU 忙碌時指示燈就會開啟,當 CPU 進入 idle 狀態時則熄滅。

定時閃爍

不需任何觸發事件,讓指示燈依照固定的頻率持續閃爍:
sudo sh -c 'echo timer > trigger'
閃爍的頻率同樣可以透過 delay_on 與 delay_off 兩個檔案來指定:
sudo sh -c 'echo 50 > delay_on'
sudo sh -c 'echo 50 > delay_off'

模仿心跳閃爍

類似 timer,不過模仿心跳的方式閃爍:
sudo sh -c 'echo heartbeat > trigger'

持續開啟指示燈

將 trigger 設定為 default-on 會讓指示燈持續開啟:
sudo sh -c 'echo default-on > trigger'
如果您對於樹莓派的應用有興趣,建議您可以繼續閱讀物聯網的相關文章。
參考資料:Raspberry PiGitHubGitHub

留言

這個網誌中的熱門文章

2017通訊大賽「聯發科技物聯網開發競賽」決賽團隊29強出爐!作品都在11月24日頒獎典禮進行展示

2017通訊大賽「聯發科技物聯網開發競賽」決賽團隊29強出爐!作品都在11月24日頒獎典禮進行展示 LIS   發表於 2017年11月16日 10:31   收藏此文 2017通訊大賽「聯發科技物聯網開發競賽」決賽於11月4日在台北文創大樓舉行,共有29個隊伍進入決賽,角逐最後的大獎,並於11月24日進行頒獎,現場會有全部進入決賽團隊的展示攤位,總計約為100個,各種創意作品琳琅滿目,非常值得一看,這次錯過就要等一年。 「聯發科技物聯網開發競賽」決賽持續一整天,每個團隊都有15分鐘面對評審團做簡報與展示,並接受評審們的詢問。在所有團隊完成簡報與展示後,主辦單位便統計所有評審的分數,並由評審們進行審慎的討論,決定冠亞季軍及其他各獎項得主,結果將於11月24日的「2017通訊大賽頒獎典禮暨成果展」現場公佈並頒獎。 在「2017通訊大賽頒獎典禮暨成果展」現場,所有入圍決賽的團隊會設置攤位,總計約為100個,展示他們辛苦研發並實作的作品,無論是想觀摩別人的成品、了解物聯網應用有那些新的創意、尋找投資標的、尋找人才、尋求合作機會或是單純有興趣,都很適合花點時間到現場看看。 頒獎典禮暨成果展資訊如下: 日期:2017年11月24日(星期五) 地點:中油大樓國光廳(台北市信義區松仁路3號) 我要報名參加「2017通訊大賽頒獎典禮暨成果展」>>> 在參加「2017通訊大賽頒獎典禮暨成果展」之前,可以先在本文觀看各團隊的作品介紹。 決賽29強團隊如下: 長者安全救星 可隨意描繪或書寫之電子筆記系統 微觀天下 體適能訓練管理裝置 肌少症之行走速率檢測系統 Sugar Robot 賽亞人的飛機維修輔助器 iTemp你的溫度個人化管家 語音行動冰箱 MR模擬飛行 智慧防盜自行車 跨平台X-Y視覺馬達控制 Ironmet 菸消雲散 無人小艇 (Mini-USV) 救OK-緊急救援小幫手 穿戴式長照輔助系統 應用於教育之模組機器人教具 這味兒很台味 Aquarium Hub 發展遲緩兒童之擴增實境學習系統 蚊房四寶 車輛相控陣列聲納環境偵測系統 戶外團隊運動管理裝置 懷舊治療數位桌曆 SeeM智能眼罩 觸...

完形心理學!?讓我們了解“介面設計師”為什麼這樣設計

完形心理學!?讓我們了解“介面設計師”為什麼這樣設計 — 說服客戶與老闆、跟工程師溝通、強化設計概念的有感心理學 — 情況 1 : 為何要留那麼多空白? 害我還要滾動滑鼠(掀桌) 情況 2 : 為什麼不能直接用一頁展現? 把客戶的需求塞滿不就完工啦! (無言) 情況 3: 這種設計好像不錯,但是為什麼要這樣做? (直覺大神告訴我這樣設計,但我說不出來為什麼..) 雖然世界上有許多 GUI 已經走得又長又遠又厲害,但別以為這種古代人對話不會出現,一直以來我們只是習慣這些 GUI 被如此呈現,但為何要這樣設計我們卻不一定知道。 由於 完形心理學 歸納出人類大腦認知之普遍性的規則,因此無論是不是 UI/UX 設計師都很適合閱讀本篇文章。但還是想特別強調,若任職於傳統科技公司,需要對上說服老闆,需要平行說服(資深)工程師,那請把它收進最愛;而習慣套用設計好的 UI 套件,但不知道為何這樣設計的 IT 工程師,也可以透過本文來強化自己的產品說服力。 那就開始吧~(擊掌) 完形心理學,又稱作格式塔(Gestalt)心理學,於二十世紀初由德國心理學家提出 — 用以說明人類大腦如何解釋肉眼所觀察到的事物,並轉化為我們所認知的物件。它可說是現代認知心理學的基礎,其貫徹的概念就是「整體大於個體的總合 “The whole is other than the sum of the parts.” —  Kurt Koffka」。 若深究完整的理論將會使本文變得非常的艱澀,因此筆者直接抽取個人認為與 UI 設計較為相關的 7 個原則(如下),並搭配實際案例做說明。有興趣了解全部理論的話可以另外 Google。 1. 相似性 (Similarity)  — 我們的大腦會把相似的事物看成一體 如果數個元素具有類似的尺寸、體積、顏色,使用者會自動為它們建立起關聯。這是因為我們的眼睛和大腦較容易將相似的事物組織在一起。如下圖所示,當一連串方塊和一連串的圓形並排時,我們會看成(a)一列方塊和兩列圓形(b)一排圓形和兩排三角形。 對應用到介面設計上,FB 每則文章下方的按鈕圖標(按讚 Like / 留言Comment / 分享 Share)雖然功能各不相同,但由於它們在視覺上顏色、大小、排列上的相似性,用戶會將它們視認為...
opencv4nodejs Asynchronous OpenCV 3.x Binding for node.js   122     2715     414   0   0 Author Contributors Repository https://github.com/justadudewhohacks/opencv4nodejs Wiki Page https://github.com/justadudewhohacks/opencv4nodejs/wiki Last Commit Mar. 8, 2019 Created Aug. 20, 2017 opencv4nodejs           By its nature, JavaScript lacks the performance to implement Computer Vision tasks efficiently. Therefore this package brings the performance of the native OpenCV library to your Node.js application. This project targets OpenCV 3 and provides an asynchronous as well as an synchronous API. The ultimate goal of this project is to provide a comprehensive collection of Node.js bindings to the API of OpenCV and the OpenCV-contrib modules. An overview of available bindings can be found in the  API Documentation . Furthermore, contribution is highly appreciated....