Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RT-Thread一般讨论
模式对话框退出后,原先的显示窗口接收不到键盘消息
发布于 2012-09-18 14:18:45 浏览:3413
订阅该版
大致代码如下: 1. 显示窗口的创建 rt_mq_t mq; struct rtgui_win *win; struct rtgui_rect rect; mq = rt_mq_create("workbench", 256, 8, RT_IPC_FLAG_FIFO); rtgui_thread_register(rt_thread_self(), mq); // 创建窗口 rect.x1 = 0; rect.y1 = 0; rect.x2 = LCD_WIDTH; rect.y2 = LCD_HEIGHT; win = rtgui_win_create(RT_NULL, "win", &rect, RTGUI_WIN_STYLE_DEFAULT); rtgui_win_show(win, RT_FALSE); // 消息循环 rtgui_widget_set_event_handler(RTGUI_WIDGET(win), OnEventHandler); rtgui_win_event_loop(win); rtgui_thread_deregister(rt_thread_self()); rt_mq_delete(mq); 2. 模式对话框创建[在显示对话框的按键消息处理中] rt_bool_t OnEventHandler(rtgui_widget_t *widget, rtgui_event_t *event) { if (event->type == RTGUI_EVENT_KBD) { struct rtgui_event_kbd *kbd = (struct rtgui_event_kbd *)event; if(kbd->key == RTGUIK_KP_ENTER) { rect.x1 = 100; rect.x2 = 700; rect.y1 = 160; rect.y2 = 200; win = rtgui_win_create(RT_NULL, "模式对话框", &rect, RTGUI_WIN_STYLE_DEFAULT); rtgui_widget_set_event_handler(RTGUI_WIDGET(win), OnPopupHandler); rtgui_win_show(win, RT_TRUE);// 模式显示 } } return rtgui_win_event_handler(widget, event); } 3. 模式对话框消息处理 rt_bool_t OnPopupHandler(rtgui_widget_t *widget, rtgui_event_t *event) { if (event->type == RTGUI_EVENT_KBD) { rtgui_win_closeRTGUI_WIN(widget)); return TRUE; } return rtgui_win_event_handler(widget, event); } 4. 按键消息的发送 struct rtgui_event_kbd kbd_event; RTGUI_EVENT_KBD_INIT(&kbd_event); kbd_event.mod = RTGUI_KMOD_NONE; kbd_event.unicode = 0; kbd_event.key = KeyMap*[j]; kbd_event.type = RTGUI_KEYDOWN; rtgui_server_post_event(&(kbd_event.parent), sizeof(kbd_event)); 模式对话框退出后,原先的显示窗口接收不到键盘消息。 请高手指教啊!
查看更多
9
个回答
默认排序
按发布时间排序
raulshao
2012-09-18
这家伙很懒,什么也没写!
rtgui_server_post_event()函数中,rt_mq_send()函数每次返回都是RT_EOK。就是说键盘消息发送都是好的,但是OnEventHandler消息处理函数在模式对话框关闭之后,就不能接收到消息了,不知道为什么?
raulshao
2012-09-19
这家伙很懒,什么也没写!
顶一下,求大侠帮忙。
bernard
2012-09-19
这家伙很懒,什么也没写!
请使用RT-Thread GUI 1.1.0版本。
raulshao
2012-09-19
这家伙很懒,什么也没写!
我用的是RT-Thread 1.0.2 正式版本,不知道RT-Thread GUI 1.1.0版本在什么地方下啊?
raulshao
2012-09-19
这家伙很懒,什么也没写!
GUI的1.1.0版本就是RTT的1.1.0版本吗?
bernard
2012-09-19
这家伙很懒,什么也没写!
>GUI的1.1.0版本就是RTT的1.1.0版本吗? --- 是的。因为1.0.0中的GUI较少人使用,我们已经不对它提供支持了。
raulshao
2012-09-19
这家伙很懒,什么也没写!
>>GUI的1.1.0版本就是RTT的1.1.0版本吗? > >--- > > > >是的。因为1.0.0中的GUI较少人使用,我们已经不对它提供支持了。 --- 谢谢,我试一下。
raulshao
2012-09-19
这家伙很懒,什么也没写!
>>>GUI的1.1.0版本就是RTT的1.1.0版本吗? >> >>--- >> >> >> >>是的。因为1.0.0中的GUI较少人使用,我们已经不对它提供支持了。 > >--- > > >谢谢,我试一下。 --- 非常感谢[quote],这个问题已经解决了,分享一下代码: void UITask(void *lp) { rt_device_t lcd; struct rtgui_application *app; lcd = rt_device_find("lcd"); if (lcd != RT_NULL) { rtgui_graphic_set_device(lcd); rtgui_system_server_init(); app = rtgui_application_create(rt_thread_self(), "gui_demo"); if (app == RT_NULL) return; rtgui_graphic_driver_get_rect(rtgui_graphic_driver_get_default(), &rect); main_win = rtgui_win_create(RT_NULL, "demo_win", &rect, RTGUI_WIN_STYLE_NO_BORDER | RTGUI_WIN_STYLE_NO_TITLE); if (main_win == RT_NULL) { rtgui_application_destroy(app); return; } rtgui_win_set_onkey(main_win, demo_handle_key); rtgui_win_show(main_win, RT_FALSE); rtgui_application_run(app); rtgui_application_destroy(app); } } static rt_bool_t demo_handle_key(struct rtgui_object* object, struct rtgui_event* event) { struct rtgui_event_kbd* ekbd = (struct rtgui_event_kbd*)event; if (ekbd->type == RTGUI_KEYDOWN) { rt_kprintf("[win.%x]", ekbd->key); rect.x1 = 100; rect.x2 = 700; rect.y1 = 50; rect.y2 = 100; pop_win = rtgui_win_create(main_win, "pop_win", &rect, RTGUI_WIN_STYLE_DEFAULT); rtgui_win_set_onkey(pop_win, pop_handle_key); rtgui_win_show(pop_win, RT_TRUE); rt_kprintf("[pop.close]"); } return RT_TRUE; } static rt_bool_t pop_handle_key(struct rtgui_object* object, struct rtgui_event* event) { struct rtgui_event_kbd* ekbd = (struct rtgui_event_kbd*)event; if (ekbd->type == RTGUI_KEYDOWN) { rt_kprintf("[pop.%x]", ekbd->key); rtgui_win_close(RTGUI_WIN(object)); } return RT_TRUE; } 键盘消息发送如原帖。
撰写答案
登录
注册新账号
关注者
0
被浏览
3.4k
关于作者
raulshao
这家伙很懒,什么也没写!
提问
12
回答
31
被采纳
0
关注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
Rt-thread中OTA下载后,bootloader不搬程序
2
ulog 日志 LOG_HEX 输出时间改为本地日期时间
3
在RT-Thread Studio中构建前执行python命令
4
研究一了一段时间RTT,直接标准版上手太难,想用nano,但又舍不得组件
5
CherryUSB开发笔记(一):FSDEV USB IP核的 HID Remote WakeUp (USB HID 远程唤醒) 2025-01-18 V1.1
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
I2C_IIC
ESP8266
UART
WIZnet_W5500
ota在线升级
PWM
cubemx
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
xusiwei1236
5
个答案
2
次被采纳
踩姑娘的小蘑菇
1
个答案
2
次被采纳
用户名由3_15位
7
个答案
1
次被采纳
bernard
4
个答案
1
次被采纳
张世争
1
个答案
1
次被采纳
本月文章贡献
聚散无由
2
篇文章
15
次点赞
catcatbing
2
篇文章
5
次点赞
Wade
2
篇文章
2
次点赞
Ghost_Girls
1
篇文章
6
次点赞
YZRD
1
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部