1.3 Writing the Window Procedure(编写窗口过程)
2021-03-27 02:23
标签:自己 处理鼠标 col bottle 签名 switch sof 应该 windows DispatchMessage函数调用作为消息目标窗口的窗口过程。窗口过程具有以下签名(signature)。 C++ 4个参数: LRESULT是你的程序返回给Windows的一个整数值。它包含程序对特定消息的响应。这个值的含义取决于消息代码。CALLBACK是函数的调用约定。 一个典型的窗口过程就是一个大型的switch语句,它会打开消息代码。为要处理的每个消息添加case。 C++ 消息的其他数据包含在lParam和wParam参数中。这两个参数都是指针宽度(32位或64位)大小的整数值。它们的含义取决于消息代码(uMsg)。对于每个消息,您需要在MSDN上查找消息代码,并将参数转换为正确的数据类型。通常数据要么是数值,要么是指向结构的指针。有些消息没有任何数据。 例如, WM_SIZE消息的文档表明: 一个典型的窗口过程(window procedure)处理几十条消息,因此它可以长得相当长。使代码更模块化的一种方法是将处理每个消息的逻辑放在一个单独的函数中。在窗口过程中,将wParam和lParam参数转换为正确的数据类型,并将这些值传递给函数。例如,要处理WM_SIZE消息,窗口过程如下所示: C++ LOWORD 和HIWORD 宏从lParam获得16位的宽度和高度值。(您可以在MSDN文档中查找每个消息代码的详细信息)。窗口过程提取宽度和高度,然后将这些值传递给自己编写的OnSize函数。 如果不处理窗口过程中的特定消息,则将消息参数直接传递给DefWindowProc函数。此函数执行消息的默认操作,该操作因消息类型而异。 C++ 在执行窗口过程时,它会阻止(block)在同一线程上创建的窗口的任何其他消息。因此,避免在窗口过程中进行冗长的处理。例如,假设您的程序打开一个TCP连接并无限期地等待服务器响应。如果您在窗口过程中这样做,那么在请求完成之前,您的UI将不会响应。在此期间,窗口无法处理鼠标或键盘输入、重新绘制自身,甚至无法关闭。 相反,您应该将工作转移到另一个线程,使用Windows内置的多任务处理设施之一: 1.3 Writing the Window Procedure(编写窗口过程) 标签:自己 处理鼠标 col bottle 签名 switch sof 应该 windows 原文地址:https://www.cnblogs.com/wainzhang/p/9370917.html编写窗口过程(Writing the Window Procedure)
LRESULT CALLBACK WindowProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam);
switch (uMsg)
{
case WM_SIZE: // Handle window resizing
// etc
}
LRESULT CALLBACK WindowProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
{
switch (uMsg)
{
case WM_SIZE:
{
int width = LOWORD(lParam); // Macro to get the low-order word.
int height = HIWORD(lParam); // Macro to get the high-order word.
// Respond to the message:
OnSize(hwnd, (UINT)wParam, width, height);
}
break;
}
}
void OnSize(HWND hwnd, UINT flag, int width, int height)
{
// Handle resizing
}
默认消息处理(Default Message Handling)
return DefWindowProc(hwnd, uMsg, wParam, lParam);
避免窗口过程中的瓶颈(Avoiding Bottlenecks in Your Window Procedure)
下一篇:Ramda 的一些API
文章标题:1.3 Writing the Window Procedure(编写窗口过程)
文章链接:http://soscw.com/essay/68370.html