Qt/E服务器到客户端的消息传递

简介: 前面提到的服务器最重要的功能就是对鼠标,键盘,屏幕等资源进行分配管理,尤其是要独占鼠标,键盘等设备,因此服务器要把各种底层设备消息通知到各个客户端进程,目前主流的GUI平台都无一例外采用事件驱动模型,这些消息正是其事件的主要来源,在其内部表示为QWSEvent,所有具体的消息(事件)都是其子类,下...

前面提到的服务器最重要的功能就是对鼠标,键盘,屏幕等资源进行分配管理,尤其是要独占鼠标,键盘等设备,因此服务器要把各种底层设备消息通知到各个客户端进程,目前主流的GUI平台都无一例外采用事件驱动模型,这些消息正是其事件的主要来源,在其内部表示为QWSEvent,所有具体的消息(事件)都是其子类,下图给出了所有的消息(事件):

img_cf10c368849a5e2ed443bf52d5cd9635.jpe

   

 这里面有很多事件是非常直观的,比如键盘事件,鼠标事件等,而有一些事件就不那么直观了,很难看明白,像QWSConnectedEventQWSPropertyReplyEvent等,他们有的是为了客户端和服务器之间通信的辅助性事件,比如QWSConnectedEvent,而像QWSPropertyReplyEvent,则是Qt内部管理的需要,与物理设备像鼠标,键盘,屏幕没有关系,在移植过程中也不会涉及,并且也很少直接与这些事件打交道,因此就不再深入分析了,但是这些事件的传递过程是一样的。

这里以鼠标事件QWSMouseEvent为例来讲解,事件如何从服务器传递到客户端。我们知道服务器和客户端的通信和网络通信是一样的,必须将数据串行化才能进行传递。服务器进程将QWSEvent串行化(具体过程见前一节分析),然后发送到客户端进程,而客户端进程则进行相反的工作,依据串行化的字节序列,建立起一个QWSEvent对象实例。QWSEvent的反串行化的过程,是典型的工厂模式的应用(Qt中有很多典型的设计模式的使用范例),具体流程如下:

img_26b56d1636542e03cef8237cac9d027b.jpe

Qt中有不少地方用到了工厂模式,这里使用的模式还是比较典型的,值得学习一下。

QWSEvent *QWSEvent::factory(int type)

{

    QWSEvent *event = 0;

switch (type) {

……

    case QWSEvent::Mouse:

        event = new QWSMouseEvent;

        break;

    default:

        qCritical("QWSEvent::factory() : Unknown event type %08x!", type);

    }

    return event;

}

 

 

目录
相关文章
|
25天前
|
存储 开发工具 git
[Git] 深入理解 Git 的客户端与服务器角色
Git 的核心设计理念是分布式,每个仓库既可以是客户端也可以是服务器。通过 GitHub 远程仓库和本地仓库的协作,Git 实现了高效的版本管理和代码协作。GitHub 作为远程裸仓库,存储项目的完整版本历史并支持多客户端协作;本地仓库则通过 `.git` 文件夹独立管理版本历史,可在离线状态下进行提交、回滚等操作,并通过 `git pull` 和 `git push` 与远程仓库同步。这种分布式特性使得 Git 在代码协作中具备强大的灵活性和可靠性。
51 18
[Git] 深入理解 Git 的客户端与服务器角色
|
2月前
|
存储 人工智能 自然语言处理
ChatMCP:基于 MCP 协议开发的 AI 聊天客户端,支持多语言和自动化安装 MCP 服务器
ChatMCP 是一款基于模型上下文协议(MCP)的 AI 聊天客户端,支持多语言和自动化安装。它能够与多种大型语言模型(LLM)如 OpenAI、Claude 和 OLLama 等进行交互,具备自动化安装 MCP 服务器、SSE 传输支持、自动选择服务器、聊天记录管理等功能。
278 15
ChatMCP:基于 MCP 协议开发的 AI 聊天客户端,支持多语言和自动化安装 MCP 服务器
|
3月前
|
开发框架 .NET C#
在 ASP.NET Core 中创建 gRPC 客户端和服务器
本文介绍了如何使用 gRPC 框架搭建一个简单的“Hello World”示例。首先创建了一个名为 GrpcDemo 的解决方案,其中包含一个 gRPC 服务端项目 GrpcServer 和一个客户端项目 GrpcClient。服务端通过定义 `greeter.proto` 文件中的服务和消息类型,实现了一个简单的问候服务 `GreeterService`。客户端则通过 gRPC 客户端库连接到服务端并调用其 `SayHello` 方法,展示了 gRPC 在 C# 中的基本使用方法。
64 5
在 ASP.NET Core 中创建 gRPC 客户端和服务器
|
6月前
|
网络协议
【qt】TCP客户端信息的接受和发送
【qt】TCP客户端信息的接受和发送
44 0
|
4月前
|
Python
Socket学习笔记(二):python通过socket实现客户端到服务器端的图片传输
使用Python的socket库实现客户端到服务器端的图片传输,包括客户端和服务器端的代码实现,以及传输结果的展示。
218 3
Socket学习笔记(二):python通过socket实现客户端到服务器端的图片传输
|
4月前
|
JSON 数据格式 Python
Socket学习笔记(一):python通过socket实现客户端到服务器端的文件传输
本文介绍了如何使用Python的socket模块实现客户端到服务器端的文件传输,包括客户端发送文件信息和内容,服务器端接收并保存文件的完整过程。
243 1
Socket学习笔记(一):python通过socket实现客户端到服务器端的文件传输
|
4月前
使用Netty实现文件传输的HTTP服务器和客户端
本文通过详细的代码示例,展示了如何使用Netty框架实现一个文件传输的HTTP服务器和客户端,包括服务端的文件处理和客户端的文件请求与接收。
121 1
使用Netty实现文件传输的HTTP服务器和客户端
|
4月前
|
网络协议 Unix Linux
一个.NET开源、快速、低延迟的异步套接字服务器和客户端库
一个.NET开源、快速、低延迟的异步套接字服务器和客户端库
124 4
|
4月前
|
存储 网络协议 Java
【网络】UDP回显服务器和客户端的构造,以及连接流程
【网络】UDP回显服务器和客户端的构造,以及连接流程
86 3
|
4月前
|
网络协议 Java API
【网络】TCP回显服务器和客户端的构造,以及相关bug解决方法
【网络】TCP回显服务器和客户端的构造,以及相关bug解决方法
90 2

热门文章

最新文章