news 2026/4/16 19:57:47

linux 使用Xcb监听键盘鼠标输入

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
linux 使用Xcb监听键盘鼠标输入

前言

在现代Linux桌面开发中,高效、低延迟的输入事件处理至关重要。XCB作为X11协议的现代化接口,不仅提供更优的性能,还通过其无状态、异步的设计为输入监听带来了革命性的改进。
本文将深入探讨如何使用XCB实现高性能的全局键盘鼠标输入监听,构建响应灵敏的桌面应用。

X11输入事件系统架构

基础键鼠事件监听

XCB原生事件同样不支持键盘鼠标的全局监听,因此,同样选择通过额外的扩展来实现监听。

2.1 键码解析

由于XCB库没有提供完整的键盘映射函数,而事件KeyCode和修饰符状态,与X11完全一样,因此直接使用X11的转换函数即可。

高级键鼠事件监听

3.1 XInput扩展
intmain(){xcb_connection_t*conn=xcb_connect(NULL,NULL);if(xcb_connection_has_error(conn)){fprintf(stderr,"XCB连接失败\n");return-1;}xcb_prefetch_extension_data(conn,&xcb_input_id);autorecord_ext=xcb_get_extension_data(conn,&xcb_input_id);if(!record_ext||!record_ext->present){fprintf(stderr,"XInput 扩展不可用\n");return-1;}autoroot=xcb_setup_roots_iterator(xcb_get_setup(conn)).data->root;structxcb_input_event_mask_extend{xcb_input_event_mask_t header;unsignedmask;}event_mask={XCB_INPUT_DEVICE_ALL,1,XCB_INPUT_XI_EVENT_MASK_KEY_PRESS|XCB_INPUT_XI_EVENT_MASK_BUTTON_PRESS};xcb_input_xi_select_events(conn,root,1,(constxcb_input_event_mask_t*)&event_mask);xcb_flush(conn);while(1){std::unique_ptr<xcb_generic_event_t>event(xcb_wait_for_event(conn));if(event->response_type!=XCB_GE_GENERIC){continue;}switch(((xcb_ge_generic_event_t*)event.get())->event_type){caseXCB_KEY_PRESS:{autokey_event=(xcb_input_key_press_event_t*)event.get();printf("=== Mouse Button Press ===\n");printf(" Button: %d\n",key_event->detail);printf(" Root Coordinates: (%f, %f)\n",key_event->root_x>>16,key_event->root_y>>16);}break;caseXCB_BUTTON_PRESS:{autobtn_event=(xcb_input_button_press_event_t*)event.get();printf("=== Key Press ===\n");printf(" Key: %d\n",btn_event->detail);printf(" Mask: %d\n",btn_event->mods.effective);}break;}}xcb_disconnect(conn);return0;}
3.2 Record扩展
intmain(){xcb_connection_t*connection=xcb_connect(NULL,NULL);if(xcb_connection_has_error(connection)){fprintf(stderr,"XCB连接失败\n");return-1;}xcb_prefetch_extension_data(connection,&xcb_record_id);constxcb_query_extension_reply_t*record_ext=xcb_get_extension_data(connection,&xcb_record_id);if(!record_ext||!record_ext->present){fprintf(stderr,"RECORD 扩展不可用\n");return-1;}xcb_record_client_spec_t clients=XCB_RECORD_CS_ALL_CLIENTS;xcb_record_context_t context=xcb_generate_id(connection);xcb_record_range_t range;memset(&range,0,sizeof(range));range.device_events.first=XCB_KEY_PRESS;range.device_events.last=XCB_BUTTON_PRESS;xcb_void_cookie_t create_cookie=xcb_record_create_context(connection,context,0,1,1,&clients,&range);xcb_flush(connection);xcb_record_enable_context_cookie_t enable_cookie=xcb_record_enable_context(connection,context);std::unique_ptr<xcb_record_enable_context_reply_t>reply;while(1){reply.reset(xcb_record_enable_context_reply(connection,enable_cookie,NULL));uint8_t*data=xcb_record_enable_context_data(reply.get());intlen=xcb_record_enable_context_data_length(reply.get());xcb_generic_event_t*event=(xcb_generic_event_t*)data;while((uint8_t*)event<data+len){switch(event->response_type&~0x80){caseXCB_BUTTON_PRESS:{autobtn_event=(xcb_button_press_event_t*)event;printf("=== Mouse Button Press ===\n");printf(" Button: %d\n",btn_event->detail);printf(" Root Coordinates: (%f, %f)\n",btn_event->root_x,btn_event->root_y);}break;caseXCB_KEY_PRESS:{autokey_event=(xcb_key_press_event_t*)event;printf("=== Key Press ===\n");printf(" Key: %d\n",key_event->detail);printf(" Mask: %d\n",key_event->state);}break;}event+=1;}}xcb_disconnect(connection);return0;}

结语

虽然XInput和Record都是同步阻塞的,但是XInput直接调用xcb_wait_for_event等待事件到来,而Record则依赖底层的xcb_wait_for_reply响应请求。
由于XInput可以通过xcb_send_event模拟事件来唤醒xcb_wait_for_event,而xcb_wait_for_reply目前暂未找到合适的方法,因此更推荐使用XInput。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 7:37:10

使用vue时的一些注意事项

1.vue2开发中一些注意事项 1.1数据响应式问题 // ❌ Bug&#xff1a;直接通过索引修改数组元素不会触发更新 this.items[0] new value// ❌ 修改数组长度不会触发更新 this.items.length 0解决方案&#xff1a; // ✅ 使用Vue.set或$set this.$set(this.items, 0, new value)…

作者头像 李华
网站建设 2026/4/16 7:35:40

拣货慢、错发多?1个策略,让东南亚海外仓一件代发效率翻倍!

做东南亚海外仓的同行都懂&#xff0c;最头疼的不是整箱入库&#xff0c;而是零散订单——Shopee、Lazada、TikTok Shop本土零售单、退货单&#xff0c;稍不注意就错发漏发、库存对账难&#xff0c;既耗人力又丢客户。行业数据显示&#xff0c;像一件代发这种拆零拣货占会整个仓…

作者头像 李华
网站建设 2026/4/16 7:37:09

大模型落地实践:97个精选案例助你掌握AI前沿应用技术

《大模型典型示范应用案例集》由阿里云携手99家合作伙伴共同发布&#xff0c;从数百个案例中精选97个优秀案例&#xff0c;分为行业赋能、智能应用和生态服务三类&#xff0c;覆盖医疗、金融、能源等多领域。报告显示上海成为大模型应用热土&#xff0c;大中型企业是主要试验场…

作者头像 李华
网站建设 2026/4/15 22:16:10

2026云+AI应用研究报告:行业大模型落地实战指南

行业大模型是产业智能化升级的关键引擎&#xff0c;云计算已跃升为AI创新核心支撑。AI行业云平台凭借数据基础、安全合规、应用生态等五大优势&#xff0c;成为行业AI应用最佳载体&#xff0c;提供高质量数据、安全机制并降低开发门槛。"AI大模型领地"知识星球提供1万…

作者头像 李华
网站建设 2026/4/16 9:06:42

Python+django基于小程序的民宿预订系统-web pc 手机端

文章目录 系统概述技术架构核心功能特色设计部署方案代码示例&#xff08;Django 模型&#xff09; 系统设计与实现的思路主要技术与实现手段源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01; 系统概述 PythonDjango 开发的民宿预订系统是…

作者头像 李华
网站建设 2026/4/16 9:09:05

大模型实战案例:运营商如何从“管道“到“智能服务商“的华丽转身

中国运营商借助5GAI技术&#xff0c;从管道提供商转型为智能服务商。文章通过黑龙江数字政府、辽宁12345热线、四川方言保护等20场景案例&#xff0c;展示大模型在政务、社会服务领域的应用成效&#xff0c;实现效率提升和成本降低。同时指出AI落地面临数据融合、高昂训练成本和…

作者头像 李华