Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RT-Thread一般讨论
关于RTGUI_EVENT_COMMAND
发布于 2012-05-08 22:20:39 浏览:3632
订阅该版
使用RT-Thread 1.0.0,参照EFM32分支下的程序代码,成功在STM32F103VET6上以8位数据FSMC方式驱动了LCD屏,但在应用RTGUI_EVENT_COMMAND应用时遇到困难,系统响应不到发出的RTGUI_EVENT_COMMAND事件。 在application.c的代码如下: ``` struct label_event { rtgui_event_t parent; rt_uint8_t* lbl_str; }; static rt_bool_t lbl_ld_volt_event_handler(rtgui_widget_t* widget, rtgui_event_t *event) { rt_kprintf("lable event %x ", event->type); if (event->type == RTGUI_EVENT_COMMAND) { struct label_event *lbl = (struct label_event *)event; rtgui_label_set_text((rtgui_label_t *)widget, lbl->lbl_str); } return rtgui_label_event_handler(widget,event); } static void main_wb_entry(void* parameter) { rt_mq_t mq; rtgui_view_t *view; rtgui_workbench_t *workbench; rtgui_rect_t rect; /* Create message queue for self */ mq = rt_mq_create("mq_main_wb", 256, 4, RT_IPC_FLAG_FIFO); if(mq == RT_NULL) { rt_kprintf("Create mq failed! "); return; } rtgui_thread_register(rt_thread_self(), mq); /* Create workbench */ workbench = rtgui_workbench_create("main", "ftld_wb"); if(workbench == RT_NULL) { rt_kprintf("Create ftld_wb failed! "); return; } /* Create a view */ view = rtgui_view_create("ftld_view"); if(view == RT_NULL) { rt_kprintf("Create view failed! "); return; } RTGUI_WIDGET_BACKGROUND(RTGUI_WIDGET(view)) = Black; RTGUI_WIDGET_FOREGROUND(RTGUI_WIDGET(view)) = Yellow; rtgui_widget_set_event_handler(RTGUI_WIDGET(view), ftld_view_event_handler); /* Create a lable */ { rtgui_label_t *lbl_ld_volt = rtgui_label_create(" 0.0 V"); rect.x1 = 85; rect.y1 = 68; rect.x2 = 165; rect.y2 = 88; rtgui_widget_set_rect(RTGUI_WIDGET(lbl_ld_volt), &rect); rtgui_widget_set_event_handler(RTGUI_WIDGET(lbl_ld_volt), lbl_ld_volt_event_handler); rtgui_container_add_child(RTGUI_CONTAINER(view), RTGUI_WIDGET(lbl_ld_volt)); } /* Add view to workbench */ rtgui_workbench_add_view(workbench, view); /* this view can be focused */ //RTGUI_WIDGET(view)->flag |= RTGUI_WIDGET_FLAG_FOCUSABLE; /* set widget focus */ //rtgui_widget_focus(RTGUI_WIDGET(view)); /* Show view */ rtgui_view_show(view, RT_FALSE); /* Workbench loop */ rtgui_workbench_event_loop(workbench); /* Prepare for exit */ rtgui_thread_deregister(rt_thread_self()); rt_mq_delete(mq); } void main_wb_init(void) { static rt_bool_t inited = RT_FALSE; if(inited == RT_FALSE) { rt_thread_t tid; tid = rt_thread_create("main_wb", main_wb_entry,RT_NULL, 2048,25,10); if(tid != RT_NULL) rt_thread_startup(tid); inited = RT_TRUE; } } void rt_init_thread_entry(void* parameter) { rt_uint8_t test_cnt = 0; rt_uint8_t str[10]; struct label_event event; #ifdef RT_USING_RTGUI { extern void rt_hw_lcd_init(); rt_device_t lcd; struct rt_device_graphic_info lcd_info; rtgui_rect_t rect; rt_thread_t wb_tid; rt_kprintf("LCD Init... "); /* init lcd */ rt_hw_lcd_init(); /* re-init device driver */ //rt_device_init_all(); /* find lcd device */ lcd = rt_device_find("FSMCLcd"); if(lcd == RT_NULL) { rt_kprintf("May be no lcd! "); } lcd->control(lcd,RTGRAPHIC_CTRL_GET_INFO, (void *)&lcd_info); rt_kprintf("Lcd size:%dX%d ", lcd_info.width, lcd_info.height); /* register panels */ rtgui_system_server_init(); rect.x1 = 0; rect.y1 = 0; //25 rect.x2 = lcd_info.width - 1; rect.y2 = lcd_info.height - 1; rtgui_panel_register("main", &rect); rtgui_panel_set_default_focused("main"); main_wb_init(); } #endif /* #ifdef RT_USING_RTGUI */ rt_hw_keys_init(); rt_thread_sleep(100); { event.parent.type = RTGUI_EVENT_COMMAND; event.parent.user = sizeof(struct label_event); event.parent.sender = RT_NULL; event.parent.ack = RT_NULL; while(test_cnt < 255) { rt_sprintf(str,"%d",test_cnt); event.lbl_str = str; rtgui_server_post_event(&event.parent, sizeof(event)); //发送RTGUI_EVENT_COMMAND事件 rt_thread_sleep(RT_TICK_PER_SECOND); test_cnt++; } } } ``` 在调试跟踪中发现程序在server.c的rtgui_server_entry()进程中是提取到了RTGUI_EVENT_COMMAND事件,但未做处理,事件也未传递至toplevel。是否需要自己添加这部分代码?
查看更多
6
个回答
默认排序
按发布时间排序
rtt-fans
2012-05-09
这家伙很懒,什么也没写!
你应该给"main_wb"线程发消息,而不是给"server"线程发, 使用函数: rt_err_t rtgui_thread_send(rt_thread_t tid, rtgui_event_t* event, rt_size_t event_size);
eastboy
2012-05-10
这家伙很懒,什么也没写!
谢谢!发线程消息是可以的,sever中消息处理函数最终也是给线程传递消息,但RT-thread 1.1.0中bsp中的EFM32下的例程application.c中也是给sever发的消息来更新label,他是怎么做的呢? photo_event结构定义: ``` struct photo_event { struct rtgui_event parent; rt_uint32_t cmd; rt_uint8_t* path; rt_uint8_t* format; }; ``` void rt_demo_thread_entry(void* parameter)中的代码: ``` /* start display photos */ DIR* dir = opendir("/photo"); struct photo_event event; struct dirent* dirent; rt_uint8_t path[100]; const rt_uint8_t bmp[] = "bmp"; const rt_uint8_t jpeg[] = "jpeg"; event.parent.type = RTGUI_EVENT_COMMAND; //////// event.parent.user = sizeof(struct photo_event); event.parent.sender = RT_NULL; event.parent.ack = RT_NULL; event.cmd = APP_CMD_PHOTO_FRAME; event.path = path; rt_thread_sleep(100); do { /* get a photo */ dirent = readdir(dir); if (dirent == RT_NULL) { break; } if ((strcmp(dirent->d_name, ".") == 0) || (strcmp(dirent->d_name, "..") == 0)) { continue; } rt_sprintf(path, "%s%c%s", "/photo", PATH_SEPARATOR, dirent->d_name); /* display it */ if ((rt_strstr(path, ".bmp") != RT_NULL) || (rt_strstr(path, ".BMP") != RT_NULL)) { event.format = &bmp[0]; rt_kprintf("bmp: %s ", path); } else if ((rt_strstr(path, ".jpg") != RT_NULL) || (rt_strstr(path, ".JPG") != RT_NULL)) { event.format = &jpeg[0]; rt_kprintf("jpeg: %s ", path); } else { rt_kprintf("skip: %s ", path); continue; } rtgui_server_post_event((&event.parent), sizeof(event)); //^^^^^^^^^^^^^^^^^^^^^这里也是给sever发EVENT_COMMAND?? rt_thread_sleep(1000); } while (dirent != RT_NULL); ```
onelife
2012-05-18
这家伙很懒,什么也没写!
>谢谢!发线程消息是可以的,sever中消息处理函数最终也是给线程传递消息,但RT-thread 1.1.0中bsp中的EFM32下的例程application.c中也是给sever发的消息来更新label,他是怎么做的呢? --- 好象是改了 server 那边的代码。不过由于 RTGUI 更新了,EFM32 分支的例程也刚刚更新了。不用改 server 的代码了,可以再去看看。 [s:157]
xiao苦
2012-05-18
这家伙很懒,什么也没写!
rtgui是事件原理是其实是通过toplevel遍历里面的控件然后派发事件,每个控件都会得到这个事件,控件的事件处理函数用的switch判断事件值,触发功能直到得到一个 RT_TRUE,所以啊,如果你想用这个事件,在switch里面判断这个事件并处理就好, 不用,那就不要判断是不是这个事件,直接返回RT_FALSE就好了。
eastboy
2012-06-09
这家伙很懒,什么也没写!
谢谢onelife,我看了最新的代码,是给application也就是新的GUI的线程发消息了。 也谢谢小苦。
撰写答案
登录
注册新账号
关注者
0
被浏览
3.6k
关于作者
eastboy
这家伙很懒,什么也没写!
提问
1
回答
3
被采纳
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
ulog 日志 LOG_HEX 输出时间改为本地日期时间
2
在RT-Thread Studio中构建前执行python命令
3
研究一了一段时间RTT,直接标准版上手太难,想用nano,但又舍不得组件
4
CherryUSB开发笔记(一):FSDEV USB IP核的 HID Remote WakeUp (USB HID 远程唤醒) 2025-01-18 V1.1
5
RT-thread 缩写字典
热门标签
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
本月问答贡献
踩姑娘的小蘑菇
1
个答案
2
次被采纳
用户名由3_15位
7
个答案
1
次被采纳
xusiwei1236
5
个答案
1
次被采纳
bernard
4
个答案
1
次被采纳
张世争
1
个答案
1
次被采纳
本月文章贡献
聚散无由
2
篇文章
15
次点赞
catcatbing
2
篇文章
5
次点赞
Wade
2
篇文章
2
次点赞
Ghost_Girls
1
篇文章
6
次点赞
YZRD
1
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部