转自 | 嵌入式大杂烩
GT-HMI
GT-HMI(Human Machine Interface) 国产开源 GUI 框架及永久免费设计软件。
开源许可协议:MIT
它提供创建具有易于使用的图形元素,精美的视觉效果和低内存占用的嵌入式 GUI 所需的一切。针对国内市场及用户需求,使用习惯进行了优化设计,为国内工程师量身打造!
产品由中国高通 GENITOP 倾心打造,继承了中国高通 30 年的汉显威廉希尔官方网站 及汉字威廉希尔官方网站 积累。产品分为上位机 GT-HMI Designer 和下位机 GT-HMI Engine。
GT HMI Designer是一款功能强大的嵌入式人机界面设计软件。它提供直观的可视化设计界面,支持多种常用控件和丰富的交互功能。此外,它还支持多国语言界面设计和强大的仿真功能。通过GT HMI Designer,可以轻松设计出美观、交互性强的界面,满足各种应用场景的需求。
GT HMI Engine是一款功能强大、高性能、多平台、多语言、稳定可靠的嵌入式人机界面引擎,提供丰富的控件和强大的交互功能。
特性
上位机设计软件 GT-HMI Designer 永久免费,下位机威廉希尔官方网站 框架 GT-HMI Engine 开源,使用无拘束;
GT-HMI Designer 内嵌下位机威廉希尔官方网站 框架编译器,可自动生成下位机代码;
提供 GT-HMI 模块,已适配 GT-HMI 上下位机软件及驱动,可以用于前期开发调试,也可以直接作为显示模块使用;
多平台兼容,移植便捷;
上位机设计软件 GT-HMI Designer;
可直接生成交互代码,免去写代码的繁琐工作;
interwetten与威廉的赔率体系 器仿真即见即所得;
内置了大量常用的组件,如按钮、文本框、进度条、单选框等;
支持高通全系列点阵/矢量字库,支持中外文及小语种,多种字号及字体;
内置中英文及数字输入法;
持续更新的 GUI 示例库和 UI 资源库;
下位机威廉希尔官方网站 框架 GT-HMI Engine;
纯 C 语言编写,使用无门槛;
小巧高效,不限平台,最小仅需 24K RAM+32K FLASH,可运行在 Cortex-ARM M0M3 等小资源平台;
移植便捷,切换平台只需移植定时器、TP 和 LCD 接口,并提供移植教程及示例;
丰富详实的例程,配套的开发套件易于上手;
支持自定义功能开发,可用 GT-HMI Engine 自定义控件和功能,组合进 GT-HMI Designer 生成的标准代码;
软件架构
软件架构说明
| 目录 | 说明 |
|---|---|
| doc/ | 相关文档说明资料 |
| driver/ | 底层驱动相关的移植代码 |
| examples/ | 控件调用示例 |
| sources/ | gui 内部使用的 images 素材 |
| test/ | 单元测试代码 |
| src/ | gui 框架代码 |
| |-gt_conf.h | 配置 |
| |-core/ | gui 核心代码 |
| |-extra/ | 拓展控件 |
| |-font/ | 字体 |
| |-hal/ | 中间件,中间层 |
| |-others/ | 不好分类的代码 |
| |-utils/ | 工具类 |
| |-widgets/ | 控件 |
| |-|-gt_conf_widgets.h | 控件开关宏 |
演示示例
多国语言示例
#include"gt_ui.h" //screen_home gt_obj_st*screen_home=NULL; staticgt_obj_st*lab1=NULL; staticgt_obj_st*rect1=NULL; staticgt_obj_st*btn1=NULL; staticgt_obj_st*btn2=NULL; staticgt_obj_st*btn3=NULL; staticgt_obj_st*btn4=NULL; staticgt_obj_st*btn5=NULL; staticgt_obj_st*btn7=NULL; staticgt_obj_st*btn8=NULL; staticgt_obj_st*btn9=NULL; staticgt_obj_st*btn10=NULL; staticvoidbtn1_0_cb(gt_event_st*e){ gt_init_screen_1(); } staticvoidbtn2_0_cb(gt_event_st*e){ gt_init_screen_2(); } staticvoidbtn3_0_cb(gt_event_st*e){ gt_init_screen_3(); } staticvoidbtn4_0_cb(gt_event_st*e){ gt_init_screen_4(); } staticvoidbtn5_0_cb(gt_event_st*e){ gt_init_screen_5(); } staticvoidbtn7_0_cb(gt_event_st*e){ gt_init_screen_7(); } staticvoidbtn8_0_cb(gt_event_st*e){ gt_init_screen_8(); } staticvoidbtn9_0_cb(gt_event_st*e){ gt_init_screen_9(); } staticvoidbtn10_0_cb(gt_event_st*e){ gt_init_screen_10(); } voidgt_init_screen_home(void) { screen_home=gt_obj_create(NULL); gt_screen_set_bgcolor(screen_home,gt_color_hex(0xFFFFFF)); //lab1 lab1=gt_label_create(screen_home); gt_obj_set_pos(lab1,295,16); gt_obj_set_size(lab1,118,40); gt_label_set_font_color(lab1,gt_color_hex(0x000000)); gt_label_set_font_size(lab1,24); gt_label_set_font_family_cn(lab1,16); gt_label_set_font_align(lab1,GT_ALIGN_LEFT); gt_label_set_text(lab1,"语言设置"); //rect1 rect1=gt_rect_create(screen_home); gt_obj_set_pos(rect1,8,55); gt_obj_set_size(rect1,660,1); gt_rect_set_radius(rect1,0); gt_rect_set_bg_color(rect1,gt_color_hex(0xdbdbdb)); gt_rect_set_color_border(rect1,gt_color_hex(0xdbdbdb)); gt_rect_set_fill(rect1,1); gt_rect_set_border(rect1,0); //btn1 btn1=gt_btn_create(screen_home); gt_obj_set_pos(btn1,29,76); gt_obj_set_size(btn1,160,43); gt_btn_set_font_color(btn1,gt_color_hex(0x000000)); gt_btn_set_font_size(btn1,24); gt_btn_set_font_family_cn(btn1,16); gt_btn_set_font_family_en(btn1,84); gt_btn_set_font_align(btn1,GT_ALIGN_CENTER_MID); gt_btn_set_space(btn1,5,0); gt_btn_set_font_thick_en(btn1,30); gt_btn_set_font_thick_cn(btn1,30); gt_btn_set_font_gray(btn1,1); gt_btn_set_text(btn1,"中文"); gt_btn_set_color_background(btn1,gt_color_hex(0xddeeff)); gt_btn_set_radius(btn1,8); gt_obj_add_event_cb(btn1,btn1_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL); //btn2 btn2=gt_btn_create(screen_home); gt_obj_set_pos(btn2,264,76); gt_obj_set_size(btn2,160,43); gt_btn_set_font_color(btn2,gt_color_hex(0x000000)); gt_btn_set_font_size(btn2,24); gt_btn_set_font_family_cn(btn2,16); gt_btn_set_font_family_en(btn2,84); gt_btn_set_font_align(btn2,GT_ALIGN_CENTER_MID); gt_btn_set_space(btn2,5,0); gt_btn_set_font_thick_en(btn2,30); gt_btn_set_font_thick_cn(btn2,30); gt_btn_set_font_gray(btn2,1); gt_btn_set_text(btn2,"日语"); gt_btn_set_color_background(btn2,gt_color_hex(0xddeeff)); gt_btn_set_radius(btn2,8); gt_obj_add_event_cb(btn2,btn2_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL); //btn3 btn3=gt_btn_create(screen_home); gt_obj_set_pos(btn3,489,76); gt_obj_set_size(btn3,160,41); gt_btn_set_font_color(btn3,gt_color_hex(0x000000)); gt_btn_set_font_size(btn3,24); gt_btn_set_font_family_cn(btn3,16); gt_btn_set_font_family_en(btn3,84); gt_btn_set_font_align(btn3,GT_ALIGN_CENTER_MID); gt_btn_set_space(btn3,5,0); gt_btn_set_font_thick_en(btn3,30); gt_btn_set_font_thick_cn(btn3,30); gt_btn_set_font_gray(btn3,1); gt_btn_set_text(btn3,"韩语"); gt_btn_set_color_background(btn3,gt_color_hex(0xddeeff)); gt_btn_set_radius(btn3,8); gt_obj_add_event_cb(btn3,btn3_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL); //btn4 btn4=gt_btn_create(screen_home); gt_obj_set_pos(btn4,29,158); gt_obj_set_size(btn4,160,43); gt_btn_set_font_color(btn4,gt_color_hex(0x000000)); gt_btn_set_font_size(btn4,24); gt_btn_set_font_family_cn(btn4,16); gt_btn_set_font_family_en(btn4,41); gt_btn_set_font_align(btn4,GT_ALIGN_CENTER_MID); gt_btn_set_space(btn4,5,0); gt_btn_set_text(btn4,"英语"); gt_btn_set_color_background(btn4,gt_color_hex(0xddeeff)); gt_btn_set_radius(btn4,8); gt_obj_add_event_cb(btn4,btn4_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL); //btn5 btn5=gt_btn_create(screen_home); gt_obj_set_pos(btn5,263,158); gt_obj_set_size(btn5,160,43); gt_btn_set_font_color(btn5,gt_color_hex(0x000000)); gt_btn_set_font_size(btn5,24); gt_btn_set_font_family_cn(btn5,16); gt_btn_set_font_family_en(btn5,53); gt_btn_set_font_align(btn5,GT_ALIGN_CENTER_MID); gt_btn_set_space(btn5,5,0); gt_btn_set_text(btn5,"法语"); gt_btn_set_color_background(btn5,gt_color_hex(0xddeeff)); gt_btn_set_radius(btn5,8); gt_obj_add_event_cb(btn5,btn5_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL); //btn7 btn7=gt_btn_create(screen_home); gt_obj_set_pos(btn7,30,238); gt_obj_set_size(btn7,160,43); gt_btn_set_font_color(btn7,gt_color_hex(0x000000)); gt_btn_set_font_size(btn7,24); gt_btn_set_font_family_cn(btn7,16); gt_btn_set_font_family_en(btn7,53); gt_btn_set_font_align(btn7,GT_ALIGN_CENTER_MID); gt_btn_set_space(btn7,5,0); gt_btn_set_text(btn7,"西班牙语"); gt_btn_set_color_background(btn7,gt_color_hex(0xddeeff)); gt_btn_set_radius(btn7,8); gt_obj_add_event_cb(btn7,btn7_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL); //btn8 btn8=gt_btn_create(screen_home); gt_obj_set_pos(btn8,263,238); gt_obj_set_size(btn8,160,43); gt_btn_set_font_color(btn8,gt_color_hex(0x000000)); gt_btn_set_font_size(btn8,24); gt_btn_set_font_family_cn(btn8,16); gt_btn_set_font_family_en(btn8,41); gt_btn_set_font_align(btn8,GT_ALIGN_CENTER_MID); gt_btn_set_space(btn8,5,0); gt_btn_set_text(btn8,"泰语"); gt_btn_set_color_background(btn8,gt_color_hex(0xddeeff)); gt_btn_set_radius(btn8,8); gt_obj_add_event_cb(btn8,btn8_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL); //btn9 btn9=gt_btn_create(screen_home); gt_obj_set_pos(btn9,490,238); gt_obj_set_size(btn9,160,43); gt_btn_set_font_color(btn9,gt_color_hex(0x000000)); gt_btn_set_font_size(btn9,24); gt_btn_set_font_family_cn(btn9,16); gt_btn_set_font_family_en(btn9,75); gt_btn_set_font_align(btn9,GT_ALIGN_CENTER_MID); gt_btn_set_space(btn9,5,0); gt_btn_set_text(btn9,"阿拉伯语"); gt_btn_set_color_background(btn9,gt_color_hex(0xddeeff)); gt_btn_set_radius(btn9,8); gt_obj_add_event_cb(btn9,btn9_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL); //btn10 btn10=gt_btn_create(screen_home); gt_obj_set_pos(btn10,489,158); gt_obj_set_size(btn10,160,43); gt_btn_set_font_color(btn10,gt_color_hex(0x000000)); gt_btn_set_font_size(btn10,24); gt_btn_set_font_family_cn(btn10,16); gt_btn_set_font_family_en(btn10,60); gt_btn_set_font_align(btn10,GT_ALIGN_CENTER_MID); gt_btn_set_space(btn10,5,0); gt_btn_set_text(btn10,"俄语"); gt_btn_set_color_background(btn10,gt_color_hex(0xddeeff)); gt_btn_set_radius(btn10,8); gt_obj_add_event_cb(btn10,btn10_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL); gt_disp_load_scr_anim(screen_home,GT_SCR_ANIM_TYPE_NONE,500,0,true); }
矢量字库示例
#include"gt_ui.h"
//screen_home
gt_obj_st*screen_home=NULL;
staticgt_obj_st*lab1=NULL;
staticgt_obj_st*rect1=NULL;
staticgt_obj_st*btn1=NULL;
staticgt_obj_st*btn2=NULL;
staticgt_obj_st*btn3=NULL;
staticgt_obj_st*btn4=NULL;
staticgt_obj_st*btn5=NULL;
staticgt_obj_st*btn7=NULL;
staticgt_obj_st*btn8=NULL;
staticgt_obj_st*btn9=NULL;
staticgt_obj_st*btn10=NULL;
staticvoidbtn1_0_cb(gt_event_st*e){
gt_init_screen_1();
}
staticvoidbtn2_0_cb(gt_event_st*e){
gt_init_screen_2();
}
staticvoidbtn3_0_cb(gt_event_st*e){
gt_init_screen_3();
}
staticvoidbtn4_0_cb(gt_event_st*e){
gt_init_screen_4();
}
staticvoidbtn5_0_cb(gt_event_st*e){
gt_init_screen_5();
}
staticvoidbtn7_0_cb(gt_event_st*e){
gt_init_screen_7();
}
staticvoidbtn8_0_cb(gt_event_st*e){
gt_init_screen_8();
}
staticvoidbtn9_0_cb(gt_event_st*e){
gt_init_screen_9();
}
staticvoidbtn10_0_cb(gt_event_st*e){
gt_init_screen_6();
}
voidgt_init_screen_home(void)
{
screen_home=gt_obj_create(NULL);
gt_screen_set_bgcolor(screen_home,gt_color_hex(0xFFFFFF));
//lab1
lab1=gt_label_create(screen_home);
gt_obj_set_pos(lab1,207,10);
gt_obj_set_size(lab1,309,40);
gt_label_set_font_color(lab1,gt_color_hex(0x000000));
gt_label_set_font_size(lab1,24);
gt_label_set_font_family_cn(lab1,80);
gt_label_set_font_align(lab1,GT_ALIGN_LEFT);
gt_label_set_font_thick_en(lab1,30);
gt_label_set_font_thick_cn(lab1,30);
gt_label_set_font_gray(lab1,4);
gt_label_set_text(lab1,"矢量字库,灰度与多字形");
//rect1
rect1=gt_rect_create(screen_home);
gt_obj_set_pos(rect1,8,55);
gt_obj_set_size(rect1,660,1);
gt_rect_set_radius(rect1,0);
gt_rect_set_bg_color(rect1,gt_color_hex(0xdbdbdb));
gt_rect_set_color_border(rect1,gt_color_hex(0xdbdbdb));
gt_rect_set_fill(rect1,1);
gt_rect_set_border(rect1,0);
//btn1
btn1=gt_btn_create(screen_home);
gt_obj_set_pos(btn1,33,78);
gt_obj_set_size(btn1,160,43);
gt_btn_set_font_color(btn1,gt_color_hex(0x000000));
gt_btn_set_font_size(btn1,24);
gt_btn_set_font_family_cn(btn1,80);
gt_btn_set_font_family_en(btn1,84);
gt_btn_set_font_align(btn1,GT_ALIGN_CENTER_MID);
gt_btn_set_space(btn1,0,0);
gt_btn_set_font_thick_en(btn1,30);
gt_btn_set_font_thick_cn(btn1,30);
gt_btn_set_font_gray(btn1,4);
gt_btn_set_text(btn1,"中文宋体");
gt_btn_set_color_background(btn1,gt_color_hex(0xddeeff));
gt_btn_set_radius(btn1,8);
gt_obj_add_event_cb(btn1,btn1_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL);
//btn2
btn2=gt_btn_create(screen_home);
gt_obj_set_pos(btn2,266,76);
gt_obj_set_size(btn2,160,43);
gt_btn_set_font_color(btn2,gt_color_hex(0x000000));
gt_btn_set_font_size(btn2,24);
gt_btn_set_font_family_cn(btn2,80);
gt_btn_set_font_family_en(btn2,84);
gt_btn_set_font_align(btn2,GT_ALIGN_CENTER_MID);
gt_btn_set_space(btn2,0,0);
gt_btn_set_font_thick_en(btn2,30);
gt_btn_set_font_thick_cn(btn2,30);
gt_btn_set_font_gray(btn2,4);
gt_btn_set_text(btn2,"中文黑体");
gt_btn_set_color_background(btn2,gt_color_hex(0xddeeff));
gt_btn_set_radius(btn2,8);
gt_obj_add_event_cb(btn2,btn2_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL);
//btn3
btn3=gt_btn_create(screen_home);
gt_obj_set_pos(btn3,493,76);
gt_obj_set_size(btn3,160,41);
gt_btn_set_font_color(btn3,gt_color_hex(0x000000));
gt_btn_set_font_size(btn3,24);
gt_btn_set_font_family_cn(btn3,80);
gt_btn_set_font_family_en(btn3,84);
gt_btn_set_font_align(btn3,GT_ALIGN_CENTER_MID);
gt_btn_set_space(btn3,0,0);
gt_btn_set_font_thick_en(btn3,30);
gt_btn_set_font_thick_cn(btn3,30);
gt_btn_set_font_gray(btn3,4);
gt_btn_set_text(btn3,"英文斜体");
gt_btn_set_color_background(btn3,gt_color_hex(0xddeeff));
gt_btn_set_radius(btn3,8);
gt_obj_add_event_cb(btn3,btn3_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL);
//btn4
btn4=gt_btn_create(screen_home);
gt_obj_set_pos(btn4,33,160);
gt_obj_set_size(btn4,160,43);
gt_btn_set_font_color(btn4,gt_color_hex(0x000000));
gt_btn_set_font_size(btn4,24);
gt_btn_set_font_family_cn(btn4,80);
gt_btn_set_font_family_en(btn4,41);
gt_btn_set_font_align(btn4,GT_ALIGN_CENTER_MID);
gt_btn_set_space(btn4,0,0);
gt_btn_set_font_thick_en(btn4,30);
gt_btn_set_font_thick_cn(btn4,30);
gt_btn_set_font_gray(btn4,4);
gt_btn_set_text(btn4,"英文手写体");
gt_btn_set_color_background(btn4,gt_color_hex(0xddeeff));
gt_btn_set_radius(btn4,8);
gt_obj_add_event_cb(btn4,btn4_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL);
//btn5
btn5=gt_btn_create(screen_home);
gt_obj_set_pos(btn5,265,160);
gt_obj_set_size(btn5,160,43);
gt_btn_set_font_color(btn5,gt_color_hex(0x000000));
gt_btn_set_font_size(btn5,24);
gt_btn_set_font_family_cn(btn5,80);
gt_btn_set_font_family_en(btn5,53);
gt_btn_set_font_align(btn5,GT_ALIGN_CENTER_MID);
gt_btn_set_space(btn5,0,0);
gt_btn_set_font_thick_en(btn5,30);
gt_btn_set_font_thick_cn(btn5,30);
gt_btn_set_font_gray(btn5,4);
gt_btn_set_text(btn5,"日文黑体");
gt_btn_set_color_background(btn5,gt_color_hex(0xddeeff));
gt_btn_set_radius(btn5,8);
gt_obj_add_event_cb(btn5,btn5_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL);
//btn7
btn7=gt_btn_create(screen_home);
gt_obj_set_pos(btn7,32,240);
gt_obj_set_size(btn7,160,43);
gt_btn_set_font_color(btn7,gt_color_hex(0x000000));
gt_btn_set_font_size(btn7,24);
gt_btn_set_font_family_cn(btn7,80);
gt_btn_set_font_family_en(btn7,53);
gt_btn_set_font_align(btn7,GT_ALIGN_CENTER_MID);
gt_btn_set_space(btn7,0,0);
gt_btn_set_font_thick_en(btn7,30);
gt_btn_set_font_thick_cn(btn7,30);
gt_btn_set_font_gray(btn7,4);
gt_btn_set_text(btn7,"俄文");
gt_btn_set_color_background(btn7,gt_color_hex(0xddeeff));
gt_btn_set_radius(btn7,8);
gt_obj_add_event_cb(btn7,btn7_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL);
//btn8
btn8=gt_btn_create(screen_home);
gt_obj_set_pos(btn8,267,240);
gt_obj_set_size(btn8,160,43);
gt_btn_set_font_color(btn8,gt_color_hex(0x000000));
gt_btn_set_font_size(btn8,24);
gt_btn_set_font_family_cn(btn8,80);
gt_btn_set_font_family_en(btn8,41);
gt_btn_set_font_align(btn8,GT_ALIGN_CENTER_MID);
gt_btn_set_space(btn8,0,0);
gt_btn_set_font_thick_en(btn8,30);
gt_btn_set_font_thick_cn(btn8,30);
gt_btn_set_font_gray(btn8,4);
gt_btn_set_text(btn8,"泰文");
gt_btn_set_color_background(btn8,gt_color_hex(0xddeeff));
gt_btn_set_radius(btn8,8);
gt_obj_add_event_cb(btn8,btn8_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL);
//btn9
btn9=gt_btn_create(screen_home);
gt_obj_set_pos(btn9,494,240);
gt_obj_set_size(btn9,160,43);
gt_btn_set_font_color(btn9,gt_color_hex(0x000000));
gt_btn_set_font_size(btn9,24);
gt_btn_set_font_family_cn(btn9,80);
gt_btn_set_font_family_en(btn9,75);
gt_btn_set_font_align(btn9,GT_ALIGN_CENTER_MID);
gt_btn_set_space(btn9,0,0);
gt_btn_set_font_thick_en(btn9,30);
gt_btn_set_font_thick_cn(btn9,30);
gt_btn_set_font_gray(btn9,4);
gt_btn_set_text(btn9,"阿拉伯文");
gt_btn_set_color_background(btn9,gt_color_hex(0xddeeff));
gt_btn_set_radius(btn9,8);
gt_obj_add_event_cb(btn9,btn9_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL);
//btn10
btn10=gt_btn_create(screen_home);
gt_obj_set_pos(btn10,495,160);
gt_obj_set_size(btn10,160,43);
gt_btn_set_font_color(btn10,gt_color_hex(0x000000));
gt_btn_set_font_size(btn10,24);
gt_btn_set_font_family_cn(btn10,80);
gt_btn_set_font_family_en(btn10,60);
gt_btn_set_font_align(btn10,GT_ALIGN_CENTER_MID);
gt_btn_set_space(btn10,0,0);
gt_btn_set_font_thick_en(btn10,30);
gt_btn_set_font_thick_cn(btn10,30);
gt_btn_set_font_gray(btn10,4);
gt_btn_set_text(btn10,"韩文黑体");
gt_btn_set_color_background(btn10,gt_color_hex(0xddeeff));
gt_btn_set_radius(btn10,8);
gt_obj_add_event_cb(btn10,btn10_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL);
gt_disp_load_scr_anim(screen_home,GT_SCR_ANIM_TYPE_NONE,500,0,true);
}
幻灯片示例动画
#include"gt_ui.h"
//screen_home
gt_obj_st*screen_home=NULL;
staticgt_obj_st*lab1=NULL;
staticgt_obj_st*img1=NULL;
staticgt_obj_st*player1=NULL;
staticgt_obj_st*svg1=NULL;
staticgt_obj_st*svg2=NULL;
staticvoidsvg1_0_cb(gt_event_st*e){
gt_player_turn_prev(player1);
}
staticvoidsvg2_0_cb(gt_event_st*e){
gt_player_turn_next(player1);
}
voidgt_init_screen_home(void)
{
screen_home=gt_obj_create(NULL);
gt_screen_set_bgcolor(screen_home,gt_color_hex(0xFFFFFF));
//lab1
lab1=gt_label_create(screen_home);
gt_obj_set_pos(lab1,223,71);
gt_obj_set_size(lab1,96,51);
gt_label_set_font_color(lab1,gt_color_hex(0x6e6e6e));
gt_label_set_font_size(lab1,32);
gt_label_set_font_family_cn(lab1,19);
gt_label_set_font_align(lab1,GT_ALIGN_LEFT);
gt_label_set_text(lab1,"风速");
//img1
img1=gt_img_create(screen_home);
gt_obj_set_pos(img1,157,75);
gt_obj_set_size(img1,42,40);
gt_img_set_src(img1,"f:img_42x40_9.png");
//player1
player1=gt_player_create(screen_home);
gt_obj_set_pos(player1,153,136);
gt_obj_set_size(player1,161,66);
gt_player_add_item(player1,"f:img_161x66_4.png",sizeof("f:img_161x66_4.png"));
gt_player_add_item(player1,"f:img_161x66_5.png",sizeof("f:img_161x66_5.png"));
gt_player_add_item(player1,"f:img_161x66_6.png",sizeof("f:img_161x66_6.png"));
gt_player_add_item(player1,"f:img_161x66_7.png",sizeof("f:img_161x66_7.png"));
gt_player_add_item(player1,"f:img_161x66_8.png",sizeof("f:img_161x66_8.png"));
gt_player_set_type(player1,GT_PLAYER_TYPE_IMG);
gt_player_set_mode(player1,GT_PLAYER_MODE_LOOP);
/svg1
svg1=gt_img_create(screen_home);
gt_obj_set_pos(svg1,76,149);
gt_obj_set_size(svg1,48,48);
gt_img_set_src(svg1,"f:img_48x48_minus_0_3.png");
gt_obj_add_event_cb(svg1,svg1_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL);
//svg2
svg2=gt_img_create(screen_home);
gt_obj_set_pos(svg2,341,148);
gt_obj_set_size(svg2,48,48);
gt_img_set_src(svg2,"f:img_48x48_plus_0_4.png");
gt_obj_add_event_cb(svg2,svg2_0_cb,GT_EVENT_TYPE_INPUT_RELEASED,NULL);
gt_disp_load_scr_anim(screen_home,GT_SCR_ANIM_TYPE_NONE,500,0,true);
}
键盘控件示例动画
#include"gt_ui.h"
//screen_home
gt_obj_st*screen_home=NULL;
staticgt_obj_st*input1=NULL;
staticgt_obj_st*keyboard1=NULL;
voidgt_init_screen_home(void)
{
screen_home=gt_obj_create(NULL);
gt_screen_set_bgcolor(screen_home,gt_color_hex(0xFFFFFF));
//input1
input1=gt_input_create(screen_home);
gt_obj_set_pos(input1,117,38);
gt_obj_set_size(input1,249,84);
gt_input_set_font_color(input1,gt_color_hex(0x000000));
gt_input_set_font_size(input1,16);
gt_input_set_font_family_cn(input1,3);
gt_input_set_font_family_en(input1,39);
gt_input_set_font_align(input1,GT_ALIGN_LEFT);
gt_input_set_placeholder(input1,"placeholder");
gt_input_set_bg_color(input1,gt_color_hex(0xffffff));
//keyboard1
keyboard1=gt_keypad_create(screen_home);
gt_obj_set_pos(keyboard1,89,138);
gt_obj_set_size(keyboard1,309,170);
gt_keypad_set_font_color(keyboard1,gt_color_hex(0xffffff));
gt_keypad_set_font_size(keyboard1,16);
gt_keypad_set_font_align(keyboard1,GT_ALIGN_CENTER_MID);
gt_keypad_set_color_background(keyboard1,gt_color_hex(0x242424));
gt_keypad_set_target(keyboard1,input1);
gt_disp_load_scr_anim(screen_home,GT_SCR_ANIM_TYPE_NONE,500,0,true);
}
图片按钮控件示例动画
#include"gt_ui.h"
/**screen_home*/
gt_obj_st*screen_home=NULL;
staticgt_obj_st*imgbtn1=NULL;
voidgt_init_screen_home(void)
{
screen_home=gt_obj_create(NULL);
gt_screen_set_bgcolor(screen_home,gt_color_hex(0xFFFFFF));
/**imgbtn1*/
imgbtn1=gt_imgbtn_create(screen_home);
gt_obj_set_pos(imgbtn1,142,136);
gt_obj_set_size(imgbtn1,185,50);
gt_imgbtn_set_src(imgbtn1,"f:img_185x50_10.png");
gt_imgbtn_set_src_press(imgbtn1,"f:img_185x50_3.png");
gt_disp_load_scr_anim(screen_home,GT_SCR_ANIM_TYPE_NONE,500,0,true);
}
-
嵌入式
+关注
关注
5082文章
19108浏览量
304836 -
开源
+关注
关注
3文章
3322浏览量
42473 -
GUI
+关注
关注
3文章
659浏览量
39657
原文标题:分享一款GUI开发神器
文章出处:【微信号:strongerHuang,微信公众号:strongerHuang】欢迎添加关注!文章转载请注明出处。
发布评论请先 登录
相关推荐
共模电容:又一款EMC滤波神器?|深圳比创达电子(上)
开发了一款车灯驱动神器
【OK210申请】智能家电(厨房神器之帮厨机器人)开发
分享一款2016好评如潮的diy设计神器!
如何开发一款自己的App
如何设计一款基于STM32的多功能GUI电路
功能更加强大的GUI神器
GUI Guider新版本发布,嵌入式GUI开发体验升级

分享一款GUI开发神器
评论