www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > 公眾號(hào)精選 > 嵌入式云IOT技術(shù)圈
[導(dǎo)讀]最近智能小車的項(xiàng)目還在加功能調(diào)試中,等后續(xù)調(diào)試完畢后更文。今天咱們就來分享一個(gè)在Github上看到的非常有意思的GUI開源項(xiàng)目。 1 主角介紹 今天介紹的主角是Github上開源的項(xiàng)目GuiLite,同時(shí)碼云上也有同步,由大佬idea4good提供。 1.1 GuiLite特點(diǎn)(來自碼云

最近智能小車的項(xiàng)目還在加功能調(diào)試中,等后續(xù)調(diào)試完畢后更文。今天咱們就來分享一個(gè)在Github上看到的非常有意思的GUI開源項(xiàng)目。

1 主角介紹

今天介紹的主角是Github上開源的項(xiàng)目GuiLite,同時(shí)碼云上也有同步,由大佬idea4good提供。

1.1 GuiLite特點(diǎn)(來自碼云官網(wǎng))

開源項(xiàng)目網(wǎng)站:

https://github.com/idea4good/GuiLite

https://gitee.com/idea4good

GuiLite提供了不少運(yùn)行實(shí)例,具體就是上面這些啦。

2 在小熊派(STM32)LCD(ST7789)上的展示效果

  • Hello Star 僅有100+行代碼,用于向開發(fā)者展示:如何使用GuiLite進(jìn)行“星空”效果的開發(fā)。


移植到小熊派后的效果如下:

  • Hello Molecule 僅有100多行代碼,它是基于GuiLite制作的分子運(yùn)動(dòng)效果。

移植到小熊派后的效果如下:

  • Hello Wave 僅有100+行代碼,用于向開發(fā)者展示:如何使用GuiLite進(jìn)行波形開發(fā)。

移植到小熊派后的效果如下:

由于公眾號(hào)只能發(fā)三個(gè)視頻,所以就發(fā)了這三個(gè)移植過后看起來效果流暢的,接下來看下如何移植這些案例到小熊派上。

2.1 移植過程

首先參考官網(wǎng)提供的MCU相關(guān)的說明文檔:

這里我拿了前面分享的一篇文章,里面的demo程序已經(jīng)把LCD相關(guān)的功能適配了,直接就用這個(gè)demo進(jìn)行移植,文章如下:

基于小熊派光強(qiáng)傳感器BH1750狀態(tài)機(jī)驅(qū)動(dòng)項(xiàng)目再升級(jí)(帶上位機(jī)曲線顯示)

以移植HelloStar為例,根據(jù)移植文檔說明:

1、首先下載該案例,然后將Uicode整個(gè)文件夾拷貝到我們的demo工程里:

2、接下來打開MDK Keil工程,將Uicode添加到我們的工程里:

3、添加文檔要求的函數(shù),以及定義的接口

在添加函數(shù)之前,我們要提供一個(gè)帶顏色的畫點(diǎn)函數(shù),代碼如下:

void LCD_Draw_ColorPoint(uint16_t x, uint16_t y,uint16_t color)
{
LCD_Address_Set(x, y, x, y);
LCD_Write_HalfWord(color);
}

然后添加對(duì)應(yīng)的函數(shù)和結(jié)構(gòu)體,通過外部引用HelloStar案例函數(shù):

//延時(shí)1ms函數(shù)
void delay_ms(int ms)
{
HAL_Delay(ms);
}
/* USER CODE END PFP */

/* Private user code ---------------------------------------------------------*/
/* USER CODE BEGIN 0 */
//RGB888轉(zhuǎn)RGB565
//Transfer GuiLite 32 bits color to your LCD color
#define GL_RGB_32_to_16(rgb) (((((unsigned int)(rgb)) & 0xFF) >> 3) | ((((unsigned int)(rgb)) & 0xFC00) >> 5) | ((((unsigned int)(rgb)) & 0xF80000) >> 8))
//Encapsulate your LCD driver:
void gfx_draw_pixel(int x, int y, unsigned int rgb)
{
//LCD_Fast_DrawPoint(x, y, GL_RGB_32_to_16(rgb));
//添加帶顏色的畫點(diǎn)函數(shù)
LCD_Draw_Point_Color(x, y, GL_RGB_32_to_16(rgb));
}
//Implement it, if you have more fast solution than drawing pixels one by one.
//void gfx_fill_rect(int x0, int y0, int x1, int y1, unsigned int rgb){}

//UI entry
struct EXTERNAL_GFX_OP
{
void (*draw_pixel)(int x, int y, unsigned int rgb);
void (*fill_rect)(int x0, int y0, int x1, int y1, unsigned int rgb);
} my_gfx_op;
extern void startHelloStar(void* phy_fb, int width, int height, int color_bytes, struct EXTERNAL_GFX_OP* gfx_op);

3、在主函數(shù)中調(diào)用

代碼如下:

LCD_Init();
LCD_Clear(BLACK);//清屏為黑色
my_gfx_op.draw_pixel = gfx_draw_pixel;
my_gfx_op.fill_rect = NULL;//gfx_fill_rect;
startHelloStar(NULL, 240, 240, 2, &my_gfx_op);

在編譯之前將Use MicroLIB選項(xiàng)去掉:

接下來編譯成功,燒錄程序,眼看就要成功了,結(jié)果屏幕啥都沒有!

最后通過Debug發(fā)現(xiàn),由于UIcode是采用堆進(jìn)行分配的,而小熊派上的LCD分辨率是240*240,所以我們需要調(diào)整下堆區(qū)的大小,這樣程序跑起來就不會(huì)有問題了。

其它的案例也是一樣的移植方法,大家也可以自己去嘗試,我已經(jīng)成功的移植了8個(gè)案例:


在公眾號(hào)后臺(tái)回復(fù):炫酷UI即可獲得所有移植成功的源代碼及源demo工程。

往期精彩

技術(shù)宅的浪漫——教你制作“520”表白神器

代碼寫得很牛逼但UI界面卻搞得很丑?來,楊工帶你!

最近收集的開源項(xiàng)目專欄(持續(xù)更新,收好車輪,方便造車)

覺得本次分享的文章對(duì)您有幫助,隨手點(diǎn)[在看]并轉(zhuǎn)發(fā)分享,也是對(duì)我的支持。

免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場,如有問題,請(qǐng)聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉