目錄
一、實驗目的
二、實驗設備
三、實驗步驟
3.1 新建工程
3.2 新建畫面
3.3 添加控件
3.4 模擬工程
3.5 硬件驗證
一、實驗目的
單片機或PLC的串口與VGA驅動板相連驅動大尺寸VGA顯示器或電視機進行圖片,動畫等的顯示。
二、實驗設備
下載軟件一個,HMIMaker下載鏈接,http://www.gz-yixian.com/Download.asp,單片機智能顯示終端一個; 用戶51、AVR、PIC、STM等單片機(帶串口UART)實驗電路板一個。
三、實驗步驟
3.1 新建工程

HMIMaker軟件界面如上圖所示,點擊菜單[工程]>[新建工程]進入新工程設置界面。下圖是新工程設置界面,用戶根據實際的硬件填寫相應的參數。

下圖是新工程的界面。在該畫面的左邊工程導航欄內有《畫面》,《子窗口》,《模擬LCD/VGA顯示器》三個元素。其中,每個工程必須至少包含一個畫面。

3.2 新建畫面

在新工程界面左邊的工程導航欄內鼠標右鍵選中《畫面》元素,彈出子菜單如上圖所示右鍵子菜單。鼠標左鍵單擊選中《新建畫面》元素,進入新畫面設置界面如下圖所示。您只能設置畫面的名字,而畫面的寬度和高度與您的顯示硬件的分辨率是相同的,它會填充整個屏幕。點擊[確定]便給新工程增加了一個畫面。

3.3 添加控件

如上圖所示,鼠標移動到新工程界面左邊的工程導航欄內,左鍵點擊選中新畫面將Win0.drw激活為當前活動文件。

HMIMaker軟件界面上點擊菜單[控件]>[動態圖片]如上圖所示。將鼠標移到新畫面Win0.drw上,此時鼠標變成十字形狀,按下鼠標左鍵并拖動至合適大小后松開左鍵,這樣便給畫面添加了一個指定的控件。在畫面的同一位置單擊鼠標左鍵(不拖動),鼠標退出十字狀態。鼠標左鍵點擊菜單[工程]>[保存工程]。

雙擊該控件,彈出控件屬性修改對話框,鼠標選中[基本控制]標簽選項如下圖所示。

如上圖所示,其中m_DynamicImages表示該控件關聯了一個變量(也可以說是控件地址)。動態圖片其實是由多幀圖片構成的一個組合。如上圖所示可以知道,動態圖片控件有兩種用法:條件顯示和循環播放。
當選中“條件顯示”的時候,表示顯示動態圖片中與m_DynamicImages值大小一樣編號的圖片,比如m_DynamicImages=1,則表示顯示第1幀圖片。
當選中“循環播放”的時候,表示以時間間隔m_DynamicImages個50豪秒循環播放動態圖片中的多幀圖片,這樣可以達到顯示動畫的目的。這個時候,如果想停止播放,只要將m_DynamicImages變為0就可以。
退出對話框,點擊菜單[HMI變量],進入下圖所示界面。

如上圖所示,鼠標左鍵點擊變量地址一欄的“28”選中m_DynamicImages變量。雙擊:

從圖中可以看出,m_DynamicImages變量的類型是無符號char(占1個字節),所以占據地址“28”,它的初時值大小是“2”。 鼠標左鍵點擊菜單[工程]>[保存工程]。
3.4 模擬工程
用戶51、AVR、PIC、STM等單片機的串口連接電腦的串口并向工程發送數據便可以改變控件對應的變量值,從而達到改變控件的顯示。 在本實驗中我們使用電腦的串口COM3和用戶單片機串口進行連接。HMIMaker軟件界面上點擊菜單[工程]>[工程屬性]進入新工程屬性設置對話框。如下圖所示。

在上圖的命令接收串口號選中COM3,點擊右邊的[連接]按鈕。如下圖所示表示串口COM3可以接收發送命令數據了。 點擊[確定]按鈕,回到主界面。在主界面下端的狀態欄中可以看到,COM3已經連接成功,如下圖所示。

設置好串口后,那么用戶單片機發什么樣的數據可以改變Win0.drw中的m_DynamicImages的大小呢?
首先,您要讓工程進入模擬仿真狀態,有兩種方法可以進入仿真狀態:
1:點擊菜單[查看]>[全屏仿真]進入全屏方式的仿真狀態。

2:在工程界面左邊的工程導航欄內鼠標左鍵選中《模擬LCD/VGA顯示器》元素。

其次,在激活仿真功能之后,用戶通過單片機串口向電腦COM3發送下面的數據(注意:十六進制)就可以把m_DynamicImages變為0。
81 00 02 1C 00 00 00 01 00 00XX XX
解釋如下:
1 | 2 | 3 | 4 | 5 | 6 | 7 |
0x81 | 0x00 | 0x02 | 1C 00 00 00 | 01 00 | 00 | XX XX |
幀頭, 固定 為 0x81 | 指令代碼,00 表示設置變量 | 接收方 設備地址 | 變量起始地址 | 數據個數 | 變量大小,十進制就是 “0” | 前面所有數據的校驗和,兩個字節數據 |
當動態圖片選擇“條件顯示”的時候,m_DynamicImages變為0表示顯示第0幀圖片。 當動態圖片選擇“循環播放”的時候,m_DynamicImages變為0表示停止循環播放動態圖片。
3.5 硬件驗證
上面已經完成了工程的仿真,現在我們把工程下載到目標硬件上,脫離電腦進行實際的顯示。 首先,我們編譯工程并生成目標硬件所需要的FLASH文件,移動鼠標執行如下圖所示操作。

其次,我們通過USB串口把剛才編譯后的工程下載到目標硬件上。注意,如果是第一次使用需要安裝USB驅動,具體見“快速入門”的介紹。移動鼠標執行如下圖所示操作。

最后,下載完之后要給目標硬件重新斷電和上電。
用戶51、AVR、PIC、STM等單片機的串口連接目標硬件的串口并發送數據便可以改變控件對應的變量值,從而達到改變控件的顯示。
像“模擬工程“這個步驟一樣,用戶通過單片機串口向目標硬件發送下面的數據(注意:十六進制)就可以把m_DynamicImages變為0。
81 00 02 1C 00 00 00 01 00 00 XX XX
當動態圖片選擇“條件顯示”的時候,m_DynamicImages變為0表示顯示第0幀圖片。 當動態圖片選擇“循環播放”的時候,m_DynamicImages變為0表示停止循環播放動態圖片。
-
單片機
+關注
關注
6076文章
45494瀏覽量
670227 -
人機界面
+關注
關注
5文章
564瀏覽量
45606 -
工控機
+關注
關注
10文章
2079瀏覽量
53313 -
串口屏
+關注
關注
8文章
621瀏覽量
39495 -
VGA控制板
+關注
關注
0文章
11瀏覽量
6717
發布評論請先 登錄
基于友晶DE10-Nano開發板的VGA顯示控制器模塊設計
廣州易顯VGA驅動板設置動態圖片控件實驗流程
廣州易顯VGA卡設置進度條實驗教程
SGTools--動畫控件--屏幕實現動畫顯示 就是這么簡單
單片機怎么驅動電機?
4K和8K顯示器驅動板的區別
工業顯示器對比商用顯示器在使用時出現故障的處理方法有何不同?
i.MX8M Plus PSPLASH如何在顯示器上設置不同的行為?
單片機如何驅動大屏幕VGA顯示器顯示圖片和動畫
評論