![](https://file1.elecfans.com//web2/M00/97/F0/wKgZomTnRu2AbHlVAACV5HVD_qY022.gif)
![](https://file1.elecfans.com//web2/M00/97/F0/wKgZomTnRu2AFZ-UAAABH5UOQQI842.jpg)
AWTK全稱 Toolkit AnyWhere,是 ZLG 開發的開源 GUI 引擎,旨在為嵌入式系統、WEB、各種小程序、手機和 PC 打造的通用 GUI 引擎,為用戶提供一個功能強大、高效可靠、簡單易用、可輕松做出炫酷效果的 GUI 引擎。
簡介
狀態機是一個常用的設計模式,在有的情況下采用狀態機,邏輯清晰,實現簡單。在 AWPLC 中,也是可以采用狀態機模式的,本文以一個簡化版的紅綠燈為例,演示在 AWPLC 中實現狀態機的方法。
確定系統存在的狀態,并選取我們關注的狀態。比如,在本系統中,我們選取紅燈、黃燈、綠燈三個狀態; 確定在各個狀態下系統的行為。比如,在本系統中,在紅燈狀態下,點亮紅色 LED 燈;在黃燈狀態下,點亮黃色 LED 燈;在綠燈狀態下,點亮綠色 LED 燈; 確定各個狀態之間轉換的條件。比如,在本系統中,在紅燈狀態下,超時進入黃燈狀態下;在黃燈狀態下,超時進入綠燈狀態下;在綠燈狀態下,超時進入紅燈狀態下。
狀態轉換如下圖所示:
![](https://file1.elecfans.com//web2/M00/97/F0/wKgZomTnRu2AGQ0NAADpLXk-NrM744.png)
1. 系統組成
3 個 LED。
LED 都用軟件模擬。
PLC程序
1. 變量定義
STATE_RED 表示紅色狀態,是一個常量,取值為 1;
STATE_YELLOW 表示黃色狀態,是一個常量,取值為 2;
STATE_GREEN 表示綠色狀態,是一個常量,取值為 3;
STATE 表示系統當前的狀態;
LED_RED 表示紅色 LED 燈,映射到第 1 個數字輸出;
LED_YELLOW 表示黃色 LED 燈,映射到第 2 個數字輸出;
LED_GREEN 表示綠色 LED 燈,映射到第 3 個數字輸出。
![](https://file1.elecfans.com//web2/M00/97/F0/wKgZomTnRu2AeK9JAAFov-1x3hc522.png)
如果系統當前狀態 STATE 等于 STATE_RED 時,表明當前處于紅燈狀態:點亮紅色 LED 燈,定時器保持工作,當定時器超時,設置系統當前狀態為黃燈狀態;
如果系統當前狀態 STATE 等于 STATE_YELLOW 時,表明當前處于黃燈狀態:點亮黃色 LED 燈,定時器保持工作,當定時器超時,設置系統當前狀態為綠燈狀態;
如果系統當前狀態 STATE 等于 STATE_GREEN 時,表明當前處于綠燈狀態:點亮綠色 LED 燈,定時器保持工作,當定時器超時,設置系統當前狀態為綠燈狀態。
* 值得注意的是,這里使用了功能塊 MOVE 對變量進行賦值。按道理來說,對變量進行賦值,直接拉根線連接起來就可以了,為什么還要加個 MOVE 呢?原因在于,這里是條件賦值,即在定時器超時的時候,才對 STATE 進行賦值。
*這就需要利用功能的執行控制(Execution Control),當功能塊啟用執行控制(Execution Control)時,只有其輸入引腳 EN 為 TRUE 時,其后續賦值才生效。
具體實現如下圖所示:
用戶界面
應用程序不需要編程,用 AWTK Designer 設計好界面,將控件與模型進行綁定即可。下面介紹一下控件與模型的綁定方法。這里用的是 AWTK-MVVM,數據綁定規則與 AWTK-MVVM 是完全一樣的。
模型可以用 io、plc 或者 io+plc。io 可以用來綁定 IO 變量,plc 可以用來綁定程序 PLC 內部變量。
![](https://file1.elecfans.com//web2/M00/97/F0/wKgZomTnRu2ANN4zAAL_tuMIPs4806.png)
運行效果:系統啟動后,三個 LED 燈循環點亮,和跑馬燈不同的是,三個 LED 點亮的時間并不完全相同。
*由此可見,在 AWPLC 功能塊圖的幫助下,我們不要寫 C 代碼或腳本,即可完成應用程序的開發。AWPLC 用低代碼降低了開發的門檻,提高了開發的效率。AWPLC 等您來玩!
AWPLC 目前還處于開發階段的早期,寫這個系列文章的目的,除了用來驗證目前所做的工作外,還希望得到大家的指點和反饋。如果您有任何疑問和建議,請在評論區留言。
【版權聲明】本文為ZLG開發者社區用戶原創內容,未經授權不得轉載。歡迎更多用戶到社區交流互動、創作博文,一經采用,可獲得百元京東E卡。
![](https://file1.elecfans.com//web2/M00/97/F0/wKgZomTnRu6AaRsVAARmtXhrJ5o228.jpg)
![](https://file1.elecfans.com//web2/M00/97/F0/wKgZomTnRu6AVNZ7AAC2Hh6LevA985.jpg)
![](https://file1.elecfans.com//web2/M00/97/F0/wKgZomTnRu6ACoCSAACL_TffxQM025.jpg)
![](https://file1.elecfans.com//web2/M00/97/F0/wKgZomTnRu6AKCxmAACg0BL51P4252.jpg)
![](https://file1.elecfans.com//web2/M00/97/F0/wKgZomTnRu6AA7AUAAB5J39ieQw898.jpg)
![](https://file1.elecfans.com//web2/M00/97/F1/wKgZomTnRu6ADl_HAADvie_3xuM267.jpg)
![](https://file1.elecfans.com//web2/M00/97/F1/wKgZomTnRu-AaGO_AADDl_n4KOw909.jpg)
-
致遠電子
+關注
關注
13文章
409瀏覽量
31427
原文標題:【產品應用】用 AWTK 和 AWPLC 快速開發嵌入式應用程序 (7)- 用狀態機實現紅綠燈
文章出處:【微信號:ZLG_zhiyuan,微信公眾號:ZLG致遠電子】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
【ELF 2學習板試用】命令行功能測試-shell腳本進行IO控制-紅綠燈項目
AWTK-WEB 快速入門(4) - JS Http 應用程序
![<b class='flag-5'>AWTK</b>-WEB <b class='flag-5'>快速</b>入門(4) - JS Http <b class='flag-5'>應用程序</b>](https://file.elecfans.com/web2/M00/50/DA/pYYBAGLH6TyAB71EAAAPQ7KgtYA038.png)
【星閃派物聯網開發套件體驗連載】智能交通燈
七大嵌入式GUI盤點
【AWTK最新動態】AWTK 1.8版本發布
![【<b class='flag-5'>AWTK</b>最新動態】<b class='flag-5'>AWTK</b> 1.8版本發布](https://file.elecfans.com/web2/M00/50/DA/pYYBAGLH6TyAB71EAAAPQ7KgtYA038.png)
如何在FPGA中實現狀態機
【插針機HMI開發】用AWTK開發人機界面
![【插針<b class='flag-5'>機</b>HMI<b class='flag-5'>開發</b>】<b class='flag-5'>用</b><b class='flag-5'>AWTK</b><b class='flag-5'>開發</b>人機界面](https://file.elecfans.com/web2/M00/50/DA/pYYBAGLH6TyAB71EAAAPQ7KgtYA038.png)
STM32 ST-LINK Utility 4.2燒程序,過程中ST LINK的紅綠燈一直不停閃爍,顯示燒錄成功芯片沒有反應為什么?
Verilog狀態機+設計實例
![Verilog<b class='flag-5'>狀態機</b>+設計實例](https://file1.elecfans.com/web2/M00/C0/EA/wKgaomXI1-KAXkFgAAA1Fl4mqhA227.png)
評論