当前位置:首页 > 单片机 > 单片机
[导读]环境:主机:WIN10开发环境:MDK5.13MCU:STM32F103说明:前面的文章已经介绍了本GUI的基本功能,目前有的控件有文本控件,图片控件,以及进度条控件,这是我项目中所需要的,读者可以参考这些代码增加自己所需的控件。

环境:

主机:WIN10

开发环境:MDK5.13

MCU:STM32F103


说明:

前面的文章已经介绍了本GUI的基本功能,目前有的控件有文本控件,图片控件,以及进度条控件,这是我项目中所需要的,读者可以参考这些代码增加自己所需的控件。本文展示一个综合实例,显示一个完整的界面。文中用到调度框架pt-thread。


实现效果:



源代码:

gui.h:gui头文件


/**

*Copyright(c),2015-2025

*@filegui.h

*@briefgui头文件

*@authorjdh

*@version1.0

*@date2015/9/6

*/

#ifndef_GUI_H_

#define_GUI_H_

/*********************************************************************

*头文件

**********************************************************************/

#include"gui_interface.h"

#include"gui_text_lib.h"

#include"gui_2d_lib.h"

#include"gui_widget_text.h"

#include"gui_widget_image.h"

#include"gui_widget_progbar.h"

/*********************************************************************

*函数

**********************************************************************/

/**

*@brief初始化gui

*/

voidgui_init(void);

/**

*@brief销毁控件

*@paramhandle:控件句柄

*/

voidgui_widget_delete(void*handle);

#endif




gui.c:gui主文件


/**

*Copyright(c),2015-2025

*@filegui.c

*@briefgui主文件

*@authorjdh

*@date2015/9/6

*/

/*********************************************************************

*头文件

**********************************************************************/

#include"gui.h"

#include"stdlib.h"

/*********************************************************************

*函数

**********************************************************************/

/**

*@brief初始化gui

*/

voidgui_init(void)

{

////初始化字库

//font_init();

}

/**

*@brief销毁控件

*@paramhandle:控件句柄

*/

voidgui_widget_delete(void*handle)

{

free(handle);

handle=(void*)0;

}




实例:

gui_mode_fence.h


/**

*Copyright(c),2015-2025

*@filegui_mode_fence.h

*@brief围栏界面模块头文件

*@authorjdh

*@date2015/11/22

*/

#ifndef_GUI_MODE_FENCE_H_

#define_GUI_MODE_FENCE_H_

/*********************************************************************

*头文件

**********************************************************************/

#include"world.h"

/*********************************************************************

*宏定义

**********************************************************************/

/**

*@brief工作间隔,单位:ms

*/

#defineINTERVAL_GUI_MODE_FENCE100

/*********************************************************************

*函数

**********************************************************************/

/**

*@brief模块载入

*/

voidgui_mode_fence_load(void);

/**

*@brief模块运行

*/

voidgui_mode_fence_run(void);

/**

*@brief设置显示状态

*@paramenable:0:关闭显示,1:打开显示

*/

voidgui_mode_fence_show(uint8_tenable);

/**

*@brief得到当前的显示状态

*@retval0:关闭显示,1:打开显示

*/

uint8_tgui_mode_fence_get_show(void);

#endif




gui_mode_fence.c


/**

*Copyright(c),2015-2025

*@filegui_mode_fence.c

*@brief围栏模式界面模块主文件

*@authorjdh

*@date2015/11/22

*@update2015/12/11

*/

/*********************************************************************

*头文件

**********************************************************************/

#include"gui_mode_fence.h"

#include"status_bar.h"

#include"gui_schedule.h"

#include"para_manage.h"

#include"slave_manage.h"

/*********************************************************************

*数据结构

**********************************************************************/

/**

*@brief按键状态

*/

struct_Key_State

{

uint8_tok;

uint8_tcancel;

uint8_tleft;

uint8_tright;

};

/*********************************************************************

*静态变量

**********************************************************************/

/**

*@briefpt任务变量

*/

staticstructptpt_task;

/**

*@brief当前显示状态.0:未显示,1显示

*/

staticuint8_tState_Show=0;

/**

*@brief控件

*/

//警报距离

staticWidget_Text_HandleWidget_Text_Alarm_Distance;

//状态

staticWidget_Text_HandleWidget_Text_State;

//距离

staticWidget_Text_HandleWidget_Text_Distance;

/**

*@brief按键状态

*/

staticstruct_Key_StateKey_State=

{

.ok=0,

.cancel=0,

.left=0,

.right=0

};

/**

*@brief从机信息

*/

staticstruct_Slave_InfoSlave_Info_Show;

/*********************************************************************

*静态函数

**********************************************************************/

/**

*@brief任务运行

*@retval任务状态

*/

staticintpt_run(structpt*pt);

/**

*@brief按键处理

*/

staticvoiddeal_key(void);

/**

*@brief更新界面

*/

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LCD屏幕和LED屏幕是常见的显示技术,用于电视、电脑显示器和移动设备等。本文将详细介绍LCD屏幕和LED屏幕的区别,包括工作原理、亮度、对比度、能效、颜色表现、尺寸和价格等方面的对比。

关键字: lcd屏 oled屏 电视

OLED屏是一种利用有机二极管发光的显示屏,它制作相对简单,且只需低的驱动电压,这个特征使得OLED屏在显示界有了非常突出的优势。

关键字: oled屏 二极管 驱动电压

众所周知,10 月 14 日凌晨 1 点举行新品发布会,预计将带来 iPhone 12 系列新品,包括 iPhone 12 mini、iPhone 12、iPhone 12 Pro、iPhone 12 Pro Max 四...

关键字: 京东方 oled屏

屏幕大概是客户对手机除机身颜色外的第二考虑了,如今,各式各样的屏幕样式层出不穷,有全面屏、刘海屏、水滴、挖孔屏等,但是有很多人忽视了屏幕材料本身的变化。智能手机刚开始发展时多用IPS屏幕,但IPS屏幕的色彩较暗淡,画质较...

关键字: 手机屏幕 oled屏 lcd屏

  本周二,苹果一项最新的专利申请通过了,这项专利是关于一种拥有金属机身和可对折OLED显示屏的设备,并且在中间还采用了铰链设计。   这项专利名为“柔性显示设备&rdquo

关键字: oled屏 专利 苹果

  oled成为显示产业突破口   OLED技术起源于欧美,但实现大规模产业化的国家/地区主要集中在东亚,如日本、中国大陆和台湾地区等。全球OLED产业还处于产业化初期。全球涉足OLED

关键字: OLED oled屏 三星

目前,AMOLED已经成为智能手机的首选显示技术,渗透率持续上升。据Omdia报告,今年智能手机中使用的AMOLED面板出货量将从2019年的4.71亿片激增至5.13亿片,AMOLED面板的渗透率急剧上升,而且这种增长...

关键字: oled屏 oled面板 新iphone

周所周知,三星一直以来都是苹果的OLED屏幕的主要供货商在。据最新消息称,京东方的第一批批OLED屏并未通过苹果的质量测试。而苹果已经下定了7500万块新iPhone OLED屏的订单,其中三星独占5500万块,LG D...

关键字: iPhone oled屏 京东方

5月20日,索尼在北京举行的新品发布会上正式推出了索尼Xperia 1。该机是索尼首款采用4K OLED屏的手机,并汇聚人眼对焦功能、三镜头相机系统、电影大师、经典颜色等多项索尼黑科技于一体,售

关键字: oled屏 索尼xperia 骁龙855

据外媒最新报道称,苹果正在跟三星一起商讨,对iPhone使用的OLED屏进行大升级,具体来说就是,有意让iPhone用上120GHz的刷新率的屏幕,这对于三星来说并不是难事。 其实苹果升

关键字: iPhone oled屏 苹果
关闭
关闭