在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

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

凡億PCB ? 來源:CSDN技術社區 ? 作者: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具有很強的跨平臺特性:

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

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

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

二、GuiLite移植

2.1 硬件準備

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

2.2 驅動準備

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

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

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

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

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

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)
{
}
//創建一個函數指針結構體
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執行函數界面處添加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】歡迎添加關注!文章轉載請注明出處。

審核編輯:湯梓紅

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

    關注

    2290

    文章

    11018

    瀏覽量

    362669
  • 移植
    +關注

    關注

    1

    文章

    394

    瀏覽量

    28593
  • GitHub
    +關注

    關注

    3

    文章

    481

    瀏覽量

    17480

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

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

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    RT-thread源碼移植STM32F10x和STM32F4xx

    RT-thread源碼移植STM32F10x和STM32F4xx: 一、源碼下載 點擊入門->下載 ? 在歷史版本里邊隨便選取一個 ? 會進入百度云盤的下載地址,里邊有全部版本的源碼
    的頭像 發表于 11-15 09:38 ?3214次閱讀
    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移植分享的嗎

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

    基于stm32oled屏幕介紹

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

    OLED是如何移植STM32F407ZET上的

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

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

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

    為什么開發GuiLite?如何使用?

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

    增強STM32 F4GUI特性

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

    GuiLite移植效果展示

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

    GuiLite:一個優秀的單片機圖形庫

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

    AN4904_從STM32F1STM32F4的軟件移植

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

    AN4616_從STM32F401/411系列移植STM32L4/STM32L4plus系列微控制器

    AN4616_從STM32F401/411系列移植STM32L4/STM32L4plus系列微控制器
    發表于 11-21 17:06 ?1次下載
    AN4616_從<b class='flag-5'>STM32F</b>401/411系列<b class='flag-5'>移植</b><b class='flag-5'>到</b><b class='flag-5'>STM32L4</b>/<b class='flag-5'>STM32L4</b>plus系列微控制器

    AN4649_從STM32F1STM32L4/STM32L4plus的軟件移植

    AN4649_從STM32F1STM32L4/STM32L4plus的軟件移植
    發表于 11-21 17:06 ?2次下載
    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
    的頭像 發表于 02-25 09:22 ?1185次閱讀

    我將GuiLite移植到了STM32F4開發板上

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

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

    、外設及性能對比以及從 STM32F4xx 移植 GD32F4xx 的移植步驟,旨在讓開發者能夠快速從
    的頭像 發表于 09-06 09:40 ?2415次閱讀
    【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 系
    主站蜘蛛池模板: 四虎永久在线精品免费观看地址 | 1000又爽又黄禁片在线久 | 深夜在线观看大尺度 | 精品一区 二区三区免费毛片 | 日韩毛片在线影视 | 亚洲mm8成为人影院 亚洲qingse中文在线 | 女同国产 | 日产毛片 | 久青草久青草高清在线播放 | 黄色大秀| 四虎精品成人a在线观看 | 精品欧美小视频在线观看 | 成在线人永久免费播放视频 | 日韩一级特黄 | 99久热成人精品视频 | 日本一区二区不卡视频 | 成人免费视频一区 | 欧美性xxxxbbbb| 久久97精品久久久久久久看片 | 色aaa| 性欧美在线| 亚洲h视频 | 国产一级特黄高清在线大片 | 国产在线视频资源 | 天天舔天天射天天干 | 国产精品亚洲色图 | 亚洲综合久久综合激情久久 | 97夜夜澡人人爽人人喊一欧美 | v天堂网| 成人激情站 | 丁香婷婷亚洲六月综合色 | 亚洲四虎永久在线播放 | 苦瓜se影院在线视频网站 | 在线观看免费视频一区 | 理论片人人51| v视界影院最新网站 | 色宅男看片午夜大片免费看 | 日本黄色大片在线观看 | 日本人xxxxxxxxx69 | 日本边添边爱边摸边做边爱 | 又粗又大的机巴好爽欧美 |