Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RT-Thread一般讨论
RT-Thread RTOS组件:RTGUI教程 Hello World
发布于 2009-10-21 09:09:11 浏览:4848
订阅该版
这是RTGUI的一份系列教程 第一篇:GUI的Hello World RTGUI设计得与其他GUI是不相类似的,所以很有必要建立一些基本概念。RTGUI内部是完全线程化的,显示一个UI必须依赖于一个线程的上下文,因为后台存在一个GUI Server的服务端进行辅助的服务。这个GUI Server必须要知道,它服务的客户端位于哪个线程中。 接下来的例子中会在屏幕上显示一个窗口,窗口内部显示“Hello World“的文本字符。 例子代码: void msg(void) { /* UI依赖于一定的线程环境,具体的,它依赖于一个消息队列,这个消息队列会接收来自GUI Server的请求信息 */ rt_mq_t mq; /* mq即这个消息队列 */ rt_thread_t tid; rt_uint32_t user_data; struct rtgui_win* msgbox; /* 显示一个消息窗口,这里是它相应的窗口指针 */ struct rtgui_rect rect = {50, 50, 200, 200}; /* 窗口的显示位置 */ /* UI中,消息是在线程间传递的,所以接收消息的消息队列需要紧贴到线程中去,RT-Thread中用到了线程的私有字段:user_data */ tid = rt_thread_self(); if (tid == RT_NULL) return; /* 获得当前线程,如果当前线程是空,即调度器未启动,UI不能使用,直接返回 */ user_data = tid->user_data; /* 先保存老的user_data */ /* 创建一个256 x 4的消息队列 */ mq = rt_mq_create("msgbox", 256, 4, RT_IPC_FLAG_FIFO); /* 注册消息队列mq到当前线程上 */ rtgui_thread_register(tid, mq); /* 创建窗口,参数包含父控件,窗口标题、窗口位置(注意窗口的标题、边框是由GUI Server维护的,所以实际上大小要大上一圈),风格参数 */ msgbox = rtgui_win_create(RT_NULL, "Information", &rect, RTGUI_WIN_STYLE_DEFAULT); if (msgbox != RT_NULL) { /* box是个盒子,更是一个布局的引擎,内部的空间不需要指定位置,可以由box自动布局 */ struct rtgui_box* box = rtgui_box_create(RTGUI_VERTICAL, RT_NULL); struct rtgui_label* label = rtgui_label_create("Hello World"); /* 创建Hello World的标签 */ rtgui_win_set_box(msgbox, box); /* 设置窗口的布局盒子 */ RTGUI_WIDGET(label)->align = RTGUI_ALIGN_CENTER_HORIZONTAL | RTGUI_ALIGN_CENTER_VERTICAL; /* 标签的布局风格,垂直、水平居中 */ rtgui_widget_set_miniwidth(RTGUI_WIDGET(label),130); /* 设置标签的最小长度 */ rtgui_box_append(box, RTGUI_WIDGET(label)); /* 添加标签到盒子中 */ rtgui_box_layout(box); /* 当所有控件添加完时,显式调用layout做盒子的自动布局 */ rtgui_win_show(msgbox); /* 显示这个窗口 */ } rtgui_win_event_loop(msgbox); /* 执行窗口的事件循环 */ /* 能够走到这步,就意味着,这个窗口已经关闭了 */ rtgui_thread_deregister(tid); /* 去注册当前线程 */ /* 删除相应的消息队列 */ rt_mq_delete(mq); /* 恢复用户数据 */ tid->user_data = user_data; } FINSH_FUNCTION_EXPORT(msg, msg on gui); 执行这个函数,UI截图: [attach]0[/attach] 在finsh下执行这个函数,有个非常明显的特点,即执行后,finsh就不再响应命令,因为finsh shell的线程已经作为UI线程来使用。有时,UI可能也会有那种自动弹出对话框的提示,显示一段时间后,自动关闭。看看这个在RTGUI中应该如何来实现的: /* 因为要跨函数访问,所以把下面这些作为全局变量 */ static struct rtgui_timer *timer; static struct rtgui_label* label; static struct rtgui_win* msgbox; static rt_uint8_t label_text[80]; static int cnt = 5; /* 显示对话框后的定时器超时回调函数,和RT-Thread中的timer不相同,这个超时函数的执行上下文是显示对话框线程的上下文 */ void diag_close(struct rtgui_timer* timer, void* parameter) { rt_sprintf(label_text, "closed then %d second!", cnt); /* 重新设置标签文本 */ rtgui_label_set_text(label, label_text); /* 调用update函数更新显示 */ rtgui_widget_update(RTGUI_WIDGET(label)); if (cnt == 0) { /* 当cnt减到零时,删除对话框 */ rtgui_win_destroy(msgbox); rtgui_timer_stop(timer); /* 删除定时器 */ rtgui_timer_destory(timer); } cnt --; } void msg() { rt_mq_t mq; rt_thread_t tid; rt_uint32_t user_data; struct rtgui_rect rect = {50, 50, 200, 200}; tid = rt_thread_self(); if (tid == RT_NULL) return; /* can't use in none-scheduler environement */ user_data = tid->user_data; /* create gui message queue */ mq = rt_mq_create("msgbox", 256, 4, RT_IPC_FLAG_FIFO); /* register message queue on current thread */ rtgui_thread_register(rt_thread_self(), mq); msgbox = rtgui_win_create(RT_NULL, "Information", &rect, RTGUI_WIN_STYLE_DEFAULT); if (msgbox != RT_NULL) { struct rtgui_box* box = rtgui_box_create(RTGUI_VERTICAL, RT_NULL); cnt = 5; rt_sprintf(label_text, "closed then %d second!", cnt); label = rtgui_label_create(label_text); rtgui_win_set_box(msgbox, box); RTGUI_WIDGET(label)->align = RTGUI_ALIGN_CENTER_HORIZONTAL | RTGUI_ALIGN_CENTER_VERTICAL; rtgui_widget_set_miniwidth(RTGUI_WIDGET(label),130); rtgui_box_append(box, RTGUI_WIDGET(label)); rtgui_box_layout(box); rtgui_win_show(msgbox); } /* 多了个定时创建的动作,超时时执行的是diag_close函数 */ timer = rtgui_timer_create(200, RT_TIMER_FLAG_PERIODIC, diag_close, RT_NULL); rtgui_timer_start(timer); rtgui_win_event_loop(msgbox); rtgui_thread_deregister(rt_thread_self()); /* remove RTGUI message queue */ rt_mq_delete(mq); /* recover user data */ tid->user_data = user_data; } FINSH_FUNCTION_EXPORT(msg, msg on gui)  
查看更多
2
个回答
默认排序
按发布时间排序
aozima
2009-10-22
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
照片也弄个漂亮点的嘛.... ....不过觉得那布满雪花的更有个性...... [s:179] [s:179] [attach]215[/attach]
撰写答案
登录
注册新账号
关注者
0
被浏览
4.8k
关于作者
bernard
这家伙很懒,什么也没写!
提问
414
回答
5949
被采纳
77
关注TA
发私信
相关问题
1
有关动态模块加载的一篇论文
2
最近的调程序总结
3
晕掉了,这么久都不见layer2的踪影啊
4
继续K9ii的历程
5
[GUI相关] FreeType 2
6
[GUI相关]嵌入式系统中文输入法的设计
7
20081101 RT-Thread开发者聚会总结
8
嵌入式系统基础
9
linux2.4.19在at91rm9200 上的寄存器设置
10
[转]基于嵌入式Linux的通用触摸屏校准程序
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
ART-Pi2快速上手--点灯
2
ART-Pi2移植CMSIS-DAP(基于CherryUSB协议栈)
3
RT-thred的stm32h723对应bsp包CubeMX添加其他外设报错
4
RT-Thread中的time溢出问题,时间戳溢出,解决方法
5
ART-PI使用env驱动ETH网卡,pc和板子可以ping通
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
DMA
USB
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
rt-smart
FAL
I2C_IIC
UART
ESP8266
cubemx
WIZnet_W5500
ota在线升级
PWM
BSP
flash
freemodbus
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
keil_MDK
ulog
SFUD
msh
C++_cpp
MicroPython
本月问答贡献
RTT_逍遥
9
个答案
2
次被采纳
xiaorui
3
个答案
2
次被采纳
winfeng
2
个答案
2
次被采纳
三世执戟
8
个答案
1
次被采纳
KunYi
8
个答案
1
次被采纳
本月文章贡献
lizimu
2
篇文章
6
次点赞
catcatbing
2
篇文章
5
次点赞
swet123
1
篇文章
4
次点赞
Days
1
篇文章
4
次点赞
YZRD
1
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部