当前位置:首页 > 单片机 > 单片机
[导读]环境:主机:WIN10开发环境:MDK5.13MCU:STM32F103源代码:gui_widget_progbar.h/***Copyright(c),2015-2025*@filegui_widget_progbar.h*@brief文本控件头文件*@authorjdh*@date2015/11/22*/#ifndef_GUI_WIDGET_PROGBA

环境:

主机:WIN10

开发环境:MDK5.13

MCU:STM32F103



源代码:

gui_widget_progbar.h


/**

*Copyright(c),2015-2025

*@filegui_widget_progbar.h

*@brief文本控件头文件

*@authorjdh

*@date2015/11/22

*/

#ifndef_GUI_WIDGET_PROGBAR_H_

#define_GUI_WIDGET_PROGBAR_H_

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

*头文件

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

#include"gui_interface.h"

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

*宏定义

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

/**

*@brief文本长度.单位:字节

*/

#defineLEN_WIDGET_TEXT32

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

*数据结构

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

/**

*@brief进度条数据结构

*/

typedefstruct_Widget_Progbar

{

//x轴位置

uint16_tx;

//y轴位置

uint16_ty;

//水平尺寸

uint16_txsize;

//垂直尺寸

uint16_tysize;

}*Widget_Progbar_Handle;

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

*函数

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

/**

*@brief创建控件

*@paramx:左上角x坐标

*@paramy:左上角y坐标

*@paramxsize:水平尺寸

*@paramysize:垂直尺寸

*@retval控件句柄

*/

Widget_Progbar_Handlegui_widget_progbar_create(uint16_tx,uint16_ty,uint16_txsize,uint16_tysize);

/**

*@brief设置进度

*@paramvalue:百分比,0-100

*/

voidgui_widget_progbar_set_value(Widget_Progbar_Handlehandle,uint8_tvalue);

#endif




gui_widget_progbar.c


/**

*Copyright(c),2015-2025

*@filegui_widget_progbar.c

*@brief进度条控件主文件

*@authorjdh

*@date2015/11/22

*/

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

*头文件

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

#include"gui_widget_progbar.h"

#include"gui_2d_lib.h"

#include"stdlib.h"

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

*静态变量

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

/**

*@brief百分比

*/

staticuint8_tPercent=0;

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

*静态函数

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

/**

*@brief控件显示

*@paramhandle:控件句柄

*/

staticvoidshow(Widget_Progbar_Handlehandle);

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

*函数

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

/**

*@brief创建控件

*@paramx:左上角x坐标

*@paramy:左上角y坐标

*@paramxsize:水平尺寸

*@paramysize:垂直尺寸

*@retval控件句柄

*/

Widget_Progbar_Handlegui_widget_progbar_create(uint16_tx,uint16_ty,uint16_txsize,uint16_tysize)

{

Widget_Progbar_Handlehandle;

//控件初始化

handle=malloc(sizeof(*handle));

handle->x=x;

handle->y=y;

handle->xsize=xsize;

handle->ysize=ysize;

//显示

show(handle);

returnhandle;

}

/**

*@brief设置进度

*@paramvalue:百分比,0-100

*/

voidgui_widget_progbar_set_value(Widget_Progbar_Handlehandle,uint8_tvalue)

{

if(Percent==value)

{

return;

}

if(value

{

//清除区域

gui_fill_rect(handle->x,handle->y,handle->x+handle->xsize,handle->y+handle->ysize,0);

//显示

gui_draw_rect(handle->x,handle->y,handle->x+handle->xsize,handle->y+handle->ysize);

}

//显示

gui_fill_rect(handle->x+handle->xsize*Percent/100,handle->y,

handle->x+handle->xsize*value/100,handle->y+handle->ysize,1);

Percent=value;

}

/**

*@brief控件显示

*@paramhandle:控件句柄

*/

staticvoidshow(Widget_Progbar_Handlehandle)

{

//清除区域

gui_fill_rect(handle->x,handle->y,handle->x+handle->xsize,handle->y+handle->ysize,0);

//显示

gui_draw_rect(handle->x,handle->y,handle->x+handle->xsize,handle->y+handle->ysize);

Percent=0;

}

测试代码:


//进度条

staticWidget_Progbar_HandleWidget_Progbar;

Widget_Progbar=gui_widget_progbar_create(9,39,111,8);

gui_widget_progbar_set_value(Widget_Progbar,50);



效果图:


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

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屏 苹果
关闭
关闭