0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

移植開源Gui框架GuiLite到STM32F4OLED屏幕

凡億PCB ? 來源:CSDN技術社區(qū) ? 作者:Top嵌入式 ? 2022-05-10 10:28 ? 次閱讀

最近在Github找到一個有趣的開源Gui框架:GuiLite。

按照說明移植了GuiLite到STM32F4OLED屏幕上,分析一下移植經驗。

一、GuiLite介紹

GuiLite是一個開源的Gui框架,只依賴于一個單一的頭文件庫(GuiLite.h),不需要很復雜的文件管理,代碼量平易近人,GuiLite由4千行C++代碼編寫,單片機上也能流暢運行,其最低的硬件運行要求如下:

CPU主頻 ROM大小 RAM大小
24 MHZ 29KB 9KB

同時GuiLite具有很強的跨平臺特性:

  • 支持的操作系統(tǒng)iOS/macOS/WatchOS,AndroidLinuxARM/x86-64),Windows(包含VR),RTOS… 甚至無操作系統(tǒng)的單片機
  • 支持的開發(fā)語言:C/C++, Swift, Java, Javascript, C#, Golang…
  • 支持的第3方庫:Qt, MFC, Winforms, CoCoa…

除此之外,GuiLite 提供一系列輔助開發(fā)工具:

  • 完美的“云” + “物聯(lián)網”解決方案:讓你輕松駕馭全球IoT業(yè)務
  • 支持多語言,采用 UTF-8 編碼;支持視頻播放
  • 資源制作工具為你定制自己的字體/圖片資源
  • 所見即所得的GUI布局工具
  • 編譯活躍度統(tǒng)計,及實時分析
  • 支持3D & Web
  • 支持Docker,一條命令啟動。

二、GuiLite移植

2.1 硬件準備

ceb5f0a8-cff1-11ec-bce3-dac502259ad0.pngSTM32F407開發(fā)板cee20472-cff1-11ec-bce3-dac502259ad0.pngOLED屏幕

2.2 驅動準備

這里我使用STM32CubeMX 對開發(fā)板進行外設配置,開啟STM32的硬件IIC,這里我用CubeMX開啟后如下:

cefc499a-cff1-11ec-bce3-dac502259ad0.png

配置完成生成代碼,同時將分配的堆空間增大:

cf10d432-cff1-11ec-bce3-dac502259ad0.png

代碼生成后,我們復制正點原子的OLED驅動工程代碼到Hardware硬件目錄下(自己創(chuàng)建一個該目錄)

cf24c802-cff1-11ec-bce3-dac502259ad0.png

在MDK里面添加文件,然后我們進行修改,注釋掉頭文件里面關于端口的定義,同時添加三個類型宏定義

cf3c3582-cff1-11ec-bce3-dac502259ad0.png

然后我們進入oled.c文件,將void OLED_WR_Byte(u8 dat,u8 cmd)void OLED_Init(void)函數分別替換為下面的內容:

OLED_WR_Byte:

voidOLED_WR_Byte(u8dat,u8cmd)
{
if(cmd)
HAL_I2C_Mem_Write(&hi2c1,0x78,0x40,I2C_MEMADD_SIZE_8BIT,&dat,1,0x100);
else
HAL_I2C_Mem_Write(&hi2c1,0x78,0x00,I2C_MEMADD_SIZE_8BIT,&dat,1,0x100);
}

OLED_Init:

//初始化SSD1306
voidOLED_Init(void)
{
OLED_WR_Byte(0xAE,OLED_CMD);//關閉顯示
OLED_WR_Byte(0xD5,OLED_CMD);//設置時鐘分頻因子,震蕩頻率
OLED_WR_Byte(80,OLED_CMD);//[3:0],分頻因子;[7:4],震蕩頻率
OLED_WR_Byte(0xA8,OLED_CMD);//設置驅動路數
OLED_WR_Byte(0X3F,OLED_CMD);//默認0X3F(1/64)
OLED_WR_Byte(0xD3,OLED_CMD);//設置顯示偏移
OLED_WR_Byte(0X00,OLED_CMD);//默認為0

OLED_WR_Byte(0x40,OLED_CMD);//設置顯示開始行[5:0],行數.

OLED_WR_Byte(0x8D,OLED_CMD);//電荷泵設置
OLED_WR_Byte(0x14,OLED_CMD);//bit2,開啟/關閉
OLED_WR_Byte(0x20,OLED_CMD);//設置內存地址模式
OLED_WR_Byte(0x02,OLED_CMD);//[1:0],00,列地址模式;01,行地址模式;10,頁地址模式;默認10;
OLED_WR_Byte(0xA1,OLED_CMD);//段重定義設置,bit0:0,0->0;1,0->127;
OLED_WR_Byte(0xC0,OLED_CMD);//設置COM掃描方向;bit3:0,普通模式;1,重定義模式COM[N-1]->COM0;N:驅動路數
OLED_WR_Byte(0xDA,OLED_CMD);//設置COM硬件引腳配置
OLED_WR_Byte(0x12,OLED_CMD);//[5:4]配置

OLED_WR_Byte(0x81,OLED_CMD);//對比度設置
OLED_WR_Byte(0xEF,OLED_CMD);//1~255;默認0X7F(亮度設置,越大越亮)
OLED_WR_Byte(0xD9,OLED_CMD);//設置預充電周期
OLED_WR_Byte(0xf1,OLED_CMD);//[3:0],PHASE1;[7:4],PHASE2;
OLED_WR_Byte(0xDB,OLED_CMD);//設置VCOMH電壓倍率
OLED_WR_Byte(0x30,OLED_CMD);//[6:4]000,0.65*vcc;001,0.77*vcc;011,0.83*vcc;

OLED_WR_Byte(0xA4,OLED_CMD);//全局顯示開啟;bit0:1,開啟;0,關閉;(白屏/黑屏)
OLED_WR_Byte(0xA6,OLED_CMD);//設置顯示方式;bit0:1,反相顯示;0,正常顯示
OLED_WR_Byte(0xAF,OLED_CMD);//開啟顯示
OLED_Clear();
}

然后在main.c文件如下位置添加oled測試代碼(記得添加頭文件和頭文件路徑)

cf58a0f0-cff1-11ec-bce3-dac502259ad0.png

下載程序,觀看現象

cf6f974c-cff1-11ec-bce3-dac502259ad0.png

此 OLED 驅動的準備已經完成,下一步就是移植 GuiLite

2.3 例程移植

首先,我們上GuiLite的例程展示官網:GuiLiteDemo,選擇Hello例程,將其中的 UI_Code文件夾復制到 Hardware 下:

cf88acd2-cff1-11ec-bce3-dac502259ad0.png

在 MDK 工程里面導入UICode下的GuiLite.h和UIcode.cpp文件

cfa5675a-cff1-11ec-bce3-dac502259ad0.png

我們在 main.c 文件開頭添加 GuiLite 接口代碼,接口代碼如下:

//畫點函數接口
voidgfx_draw_pixel(intx,inty,unsignedintrgb)
{
OLED_DrawPoint(x,y,rgb);
}
//畫面函數(未使用)
voidgfx_draw_fill(intx,inty,intw,intq,unsignedintrgb)
{
}
//創(chuàng)建一個函數指針結構體
structEXTERNAL_GFX_OP
{
void(*draw_pixel)(intx,inty,unsignedintrgb);
void(*fill_rect)(intx0,inty0,intx1,inty1,unsignedintrgb);
}my_gfx_op;
externvoidstartHelloCircle(void*phy_fb,intwidth,intheight,intcolor_bytes,structEXTERNAL_GFX_OP*gfx_op);

//設定延時函數接口
voiddelay_ms(intmilli_seconds)
{
HAL_Delay(milli_seconds);
}

之后在main函數中添加如下代碼

//傳遞函數指針
my_gfx_op.draw_pixel=gfx_draw_pixel;
my_gfx_op.fill_rect=NULL;//gfx_fill_rect;
//啟動畫圓
startHelloCircle(NULL,128,64,1,&my_gfx_op);

然后我們修改UIcode.cpp文件中的代碼,添加OLED頭文件,以及在UI執(zhí)行函數界面處添加OLED刷新函數

cfb86d00-cff1-11ec-bce3-dac502259ad0.png

之后在UIcode的第8行修改3D圓的參數,因為OLED大小128x64 ,所以我的配置如下:

cfd0963c-cff1-11ec-bce3-dac502259ad0.png

配置完成后,我們關閉Use MicroLIB選項,編譯代碼

cfe49c5e-cff1-11ec-bce3-dac502259ad0.png

編譯成功,下載代碼

d000cde8-cff1-11ec-bce3-dac502259ad0.png

三、Gui移植結果

下載完成后程序復位,可以在OLED上看到Demo的示例動畫。

d01a321a-cff1-11ec-bce3-dac502259ad0.png

原文標題:GuiLite移植到STM32F4詳細步驟

文章出處:【微信公眾號:凡億PCB】歡迎添加關注!文章轉載請注明出處。

審核編輯:湯梓紅

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • STM32
    +關注

    關注

    2262

    文章

    10846

    瀏覽量

    353650
  • 移植
    +關注

    關注

    1

    文章

    375

    瀏覽量

    28072
  • GitHub
    +關注

    關注

    3

    文章

    461

    瀏覽量

    16324

原文標題:GuiLite移植到STM32F4詳細步驟

文章出處:【微信號:FANYPCB,微信公眾號:凡億PCB】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    RT-thread源碼移植STM32F10x和STM32F4xx

    RT-thread源碼移植STM32F10x和STM32F4xx: 一、源碼下載 點擊入門->下載 ? 在歷史版本里邊隨便選取一個 ? 會進入百度云盤的下載地址,里邊有全部版本的源碼
    的頭像 發(fā)表于 11-15 09:38 ?2212次閱讀
    RT-thread源碼<b class='flag-5'>移植</b><b class='flag-5'>到</b><b class='flag-5'>STM32F</b>10x和<b class='flag-5'>STM32F4</b>xx

    開源GUI LittlevGL移植分享的嗎

    無意間發(fā)現一個開源GUI庫LittlevGL官方地址:https://littlevgl.com/STM32F429Discovery移植演示:https://littlevgl.c
    發(fā)表于 06-03 04:35

    基于stm32oled屏幕介紹

    基于stm32oled屏幕介紹,STM32 正點原子庫函數移植hal庫 oled SPI 顯示
    發(fā)表于 08-10 08:12

    OLED是如何移植STM32F407ZET上的

    OLED移植STM32F407ZET的詳細步驟一:說明開發(fā)板:STM32F407開發(fā)平臺:Keil uVision5模塊:0.96寸7針
    發(fā)表于 08-24 07:04

    【CW32飯盒派開發(fā)板試用體驗】移植GUILite

    相關API,顯示效果有限,不能滿足我們的日常需求。本文介紹將目前很熱門的嵌入式圖形庫GUILite移植CW32的方法。 1. GUILite簡介
    發(fā)表于 05-21 19:28

    為什么開發(fā)GuiLite?如何使用?

    。 為了聚焦UI核心原理,GuiLite會一直保持單片機的代碼體量。 新功能:在單片機上運行“波形控件”實例 -- HelloWave 單片機硬件配置:STM32F103ZET6(512K ROM,64K
    發(fā)表于 06-15 08:41

    增強STM32 F4GUI特性

    STM32 F4:以最少的資源提供增強的GUI特性
    的頭像 發(fā)表于 07-05 00:07 ?3380次閱讀

    STM32F429使用STM32CUBMX5.6移植touchGFX4.13

    TouchGFX2.STM32F429移植touchGFX(二)—— 使用MVP架構來實現GUI和硬件的雙向交互3.STM32F429移植t
    發(fā)表于 11-23 18:07 ?10次下載
    <b class='flag-5'>STM32F</b>429使用<b class='flag-5'>STM32</b>CUBMX5.6<b class='flag-5'>移植</b>touchGFX4.13

    GuiLite移植效果展示

    平臺:STM32L4R9,640K RAM,2048K FLASHRTOS:FreeRTOS屏幕:ST7789UI:GuiLite,https://gitee.com/idea4
    發(fā)表于 12-27 19:02 ?9次下載
    <b class='flag-5'>GuiLite</b><b class='flag-5'>移植</b>效果展示

    GuiLite:一個優(yōu)秀的單片機圖形庫

    ????本文給大家推薦一個很不錯的Gui庫:GuiLite,非常好用,希望對你有所幫助。 GuiLite介紹 ??? GuiLite是一個開源
    的頭像 發(fā)表于 07-06 11:03 ?3008次閱讀

    AN4904_從STM32F1STM32F4的軟件移植

    AN4904_從STM32F1STM32F4的軟件移植
    發(fā)表于 11-21 17:06 ?3次下載
    AN4904_從<b class='flag-5'>STM32F</b>1<b class='flag-5'>到</b><b class='flag-5'>STM32F4</b>的軟件<b class='flag-5'>移植</b>

    AN4649_從STM32F1STM32L4/STM32L4plus的軟件移植

    AN4649_從STM32F1STM32L4/STM32L4plus的軟件移植
    發(fā)表于 11-21 17:06 ?0次下載
    AN4649_從<b class='flag-5'>STM32F</b>1<b class='flag-5'>到</b><b class='flag-5'>STM32L4</b>/<b class='flag-5'>STM32L4</b>plus的軟件<b class='flag-5'>移植</b>

    GuiLite移植STM32

    GuiLite是一個開源的圖形用戶界面框架,只依賴于一個單一的頭文件庫(GuiLite.h),不需要很復雜的文件管理,代碼量平易近人。 Gu
    的頭像 發(fā)表于 02-25 09:22 ?913次閱讀

    我將GuiLite移植到了STM32F4開發(fā)板上

    摘要:最近在做Github找到一個有趣的開源Gui框架GuiLite,按照說明移植GuiLite
    的頭像 發(fā)表于 06-26 09:14 ?1128次閱讀
    我將<b class='flag-5'>GuiLite</b><b class='flag-5'>移植</b>到了<b class='flag-5'>STM32F4</b>開發(fā)板上

    【GD32 MCU 移植教程】8、從 STM32F4xx 系列移植 GD32F4xx 系

    、外設及性能對比以及從 STM32F4xx 移植 GD32F4xx 的移植步驟,旨在讓開發(fā)者能夠快速從
    的頭像 發(fā)表于 09-06 09:40 ?731次閱讀
    【GD32 MCU <b class='flag-5'>移植</b>教程】8、從 <b class='flag-5'>STM32F4</b>xx 系列<b class='flag-5'>移植</b><b class='flag-5'>到</b> GD32<b class='flag-5'>F4</b>xx 系