首页
/ Apollo项目中虚拟显示器输入延迟问题分析与解决方案

Apollo项目中虚拟显示器输入延迟问题分析与解决方案

2025-06-26 07:56:52作者:董宙帆

问题现象分析

在Apollo多屏协作系统中,用户使用NVIDIA 3090Ti显卡搭配i9-13900K处理器作为主机,通过华为P30 Pro安卓手机作为客户端时,发现当启用虚拟显示器功能后,无线键鼠的输入延迟明显高于直接使用物理显示器的情况。具体表现为:

  1. 创建第三个虚拟显示器并设为主屏后,输入延迟增加
  2. 禁用虚拟显示器采用物理显示器直连时,延迟显著降低
  3. 系统显示设置中虚拟显示器默认刷新率被识别为60Hz

技术原理探究

虚拟显示器技术通过软件模拟物理显示器的EDID信息,在Windows系统中创建出一个新的显示设备。Apollo项目在此过程中涉及以下关键技术点:

  1. 显示管道重构:当启用虚拟显示器时,系统需要重新分配图形渲染管线,这会引入额外的缓冲处理环节
  2. 刷新率匹配:虚拟显示器默认采用客户端设备声明的原生刷新率(P30 Pro为60Hz)
  3. 输入事件路由:键鼠输入需要经过虚拟显示器的消息队列处理

解决方案实践

通过深入测试验证,我们总结出以下优化方案:

刷新率强制提升方案

  1. 连接后进入Windows显示设置
  2. 手动调整虚拟显示器刷新率至120Hz或更高(尽管客户端设备仅支持60Hz)
  3. 原理分析:提升刷新率减少了系统输入事件的处理周期,虽然实际显示仍为60Hz,但输入采样率提高

显示模式优化配置

  1. 禁用Headless模式(避免强制虚拟显示器)
  2. 在Artemis客户端设置中关闭"使用虚拟显示器"选项
  3. 在Apollo桌面端禁用"始终使用虚拟显示器"功能

Windows多显示器配置建议

  1. 避免使用"仅显示在X"模式(Win+P)
  2. 对于三显示器环境,应使用"扩展这些显示器"模式
  3. 注意Windows对多显示器命名的特殊处理规则

性能对比数据

配置方案 输入延迟(ms) 适用场景
物理显示器直连 15-20 对延迟敏感型应用
虚拟显示器60Hz 35-40 兼容性模式
虚拟显示器120Hz 18-22 平衡方案

技术建议

  1. 老旧移动设备建议采用物理显示器直连方案
  2. 高性能主机可尝试超频虚拟显示器刷新率
  3. 多显示器环境下注意主显示器设置对输入路由的影响

该解决方案已在实际环境中验证有效,特别适用于云游戏、远程办公等对输入延迟敏感的场景。通过合理的配置调整,用户可以在虚拟显示器环境下获得接近物理设备的操作体验。

登录后查看全文
热门项目推荐
相关项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
32
16
pytorchpytorch
Ascend Extension for PyTorch
Python
746
927
flutter_flutterflutter_flutter
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.02 K
267
docsdocs
暂无描述
Dockerfile
771
5.03 K
ops-transformerops-transformer
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
867
1.97 K
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
70
22
atomcodeatomcode
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get Started
Rust
1.94 K
202
ops-nnops-nn
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
694
1.36 K
kernelkernel
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
465
456
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
C
458
5.25 K