源码

 #include<Windows.h>

 LRESULT CALLBACK WindProc(HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam);

 int WinMain(HINSTANCE hInst, HINSTANCE tmp, LPSTR szCmd, int nShow)
{
WNDCLASS WndClass;
TCHAR* ClassName = TEXT("MyClass");
HWND hwnd;
MSG msg; WndClass.cbClsExtra = ;
WndClass.cbWndExtra = ;
WndClass.hbrBackground = (HBRUSH)(COLOR_WINDOW + );
WndClass.hCursor = LoadCursor(NULL, IDC_ARROW);
WndClass.hIcon = LoadIcon(NULL, IDI_APPLICATION);
WndClass.hInstance = hInst;
WndClass.lpfnWndProc = WindProc;
WndClass.lpszClassName = ClassName;
WndClass.lpszMenuName = NULL;
WndClass.style = CS_VREDRAW | CS_HREDRAW; if (!RegisterClass(&WndClass))
{
MessageBox(NULL, TEXT("Gegister Class Fail!!"), TEXT("error"), MB_OK);
return ;
} hwnd = CreateWindow(ClassName, TEXT("Hello"), WS_OVERLAPPEDWINDOW, CW_USEDEFAULT, CW_USEDEFAULT, , , NULL, NULL, hInst, NULL);
if (hwnd == NULL)
{
MessageBox(NULL, TEXT("Create Window Fail!!"), TEXT("error"), MB_OK);
return ;
}
ShowWindow(hwnd, nShow);
UpdateWindow(hwnd); while (GetMessage(&msg,NULL,,))
{
TranslateMessage(&msg);
DispatchMessage(&msg);
} return ;
} LRESULT CALLBACK WindProc(HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam)
{
switch (message)
{
case WM_DESTROY:
PostQuitMessage();//发送WM_QUIT消息
return ;
default:
break;
} return DefWindowProc(hwnd, message, wParam, lParam);
}

LoadIcon

  载入图示供程式使用。
LoadCursor
  载入鼠标供程序使用。
GetStockObiect
  取得一个图形对象(在这个例子中,是取得绘制视窗背景的画刷物件)。
RegisterClass

  为程序视窗注册窗口类。

Create Window
  根据窗口类建立一个视窗。
ShowWindow

  在萤幕上显示窗口。

UpdateWindow
  更新窗口。
GetMessage
  从程序消息队列获取消息。
TranslateMessage
  将虚拟密钥消息转换为字符消息。字符消息被发布到调用线程的消息队列,以便在线程下次调用GetMessage或PeekMessage函数时读取。

DispatchMessage

  将消息发送到窗口过程。它通常用于分派由GetMessage函数检索的消息。

PostQuitMessage
  向系统指示线程已发出终止请求(退出)。它通常用于响应WM_DESTROY消息。

LoadCursor

从与应用程序实例关联的可执行文件(.EXE)加载指定的游标资源。
注意此函数已被LoadImage函数取代。

LoadIcon

从与应用程序实例关联的可执行文件(.EXE)加载指定的游标资源。
注意此函数已被LoadImage函数取代。

CreateWindow

HWND WINAPI CreateWindow(
_In_opt_ LPCTSTR lpClassName,
_In_opt_ LPCTSTR lpWindowName,
_In_ DWORD dwStyle,
_In_ int x,
_In_ int y,
_In_ int nWidth,
_In_ int nHeight,
_In_opt_ HWND hWndParent,
_In_opt_ HMENU hMenu,
_In_opt_ HINSTANCE hInstance,
_In_opt_ LPVOID lpParam
);

DispatchMessage这里调用的是我们自定义的消息处理函数WindProc

PostQuitMessage(0)发送WM_QUIT消息,使GetMessage函数返回值为零,从而退出while循环。

WIndows窗体程序的一生 ,大部分时间都在消息循环中度过。

下面代码创建一个空白窗口程序,没有关闭按钮,只能Alt+F4关闭

GetSystemMetrics是一个计算机函数,该函数只有一个参数,称之为「索引」,这个索引有75个标识符,通过设置不同的标识符就可以获取系统分辨率、窗体显示区域的宽度和高度、滚动条的宽度和高度。

 #include<Windows.h>

 LRESULT CALLBACK WindProc(HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam);

 int WinMain(HINSTANCE hInst, HINSTANCE tmp, LPSTR szCmd, int nShow)
{
WNDCLASS WndClass;
TCHAR* ClassName = TEXT("MyClass");
HWND hwnd;
MSG msg; WndClass.cbClsExtra = ;
WndClass.cbWndExtra = ;
WndClass.hbrBackground = (HBRUSH)(COLOR_WINDOW + );
WndClass.hCursor = LoadCursor(NULL, IDC_ARROW);
WndClass.hIcon = LoadIcon(NULL, IDI_APPLICATION);
WndClass.hInstance = hInst;
WndClass.lpfnWndProc = WindProc;
WndClass.lpszClassName = ClassName;
WndClass.lpszMenuName = NULL;
WndClass.style = CS_VREDRAW | CS_HREDRAW; if (!RegisterClass(&WndClass))
{
MessageBox(NULL, TEXT("Gegister Class Fail!!"), TEXT("error"), MB_OK);
return ;
} hwnd = CreateWindow(ClassName, TEXT("Hello"), WS_POPUP, , , GetSystemMetrics(SM_CXSCREEN), GetSystemMetrics(SM_CYSCREEN), NULL, NULL, hInst, NULL);
if (hwnd == NULL)
{
MessageBox(NULL, TEXT("Create Window Fail!!"), TEXT("error"), MB_OK);
return ;
}
ShowWindow(hwnd, nShow);
UpdateWindow(hwnd); while (GetMessage(&msg,NULL,,))
{
TranslateMessage(&msg);
DispatchMessage(&msg);
} return ;
} LRESULT CALLBACK WindProc(HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam)
{
switch (message)
{
case WM_DESTROY:
PostQuitMessage();//发送WM_QUIT消息
return ;
default:
break;
} return DefWindowProc(hwnd, message, wParam, lParam);
}

窗口过程

LRESULT CALLBACK WindProc(HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam);

LRESULT CALLBACK WindowProc(
_In_ HWND hwnd,
_In_ UINT uMsg,
_In_ WPARAM wParam,
_In_ LPARAM lParam
);

hwnd:窗口过程可以为基于同一窗口类创建的多个窗口处理消息。通过hwnd 参数,窗口过程就可获知到底是哪一个窗口正在接收消息。

message:具体某一Windows消息,例如VM_SIZE

wParam、lParam提供消息相关的附加参数。以message为VM_SIZE为例,

wParam 参数取值可为SIZE RESTORED、SIZE_MINIMIZED、SIZE MAXIMIZED、SIZE_MAXSHOW 或 SIZE MAXHIDE

IParam参数中包含该窗口的新尺寸,窗口的新宽度(一个16位的值)和新高度(也是一个16位的值)被组合在32位的IParam参数中。头文件WINDEFH中定义了一些宏便于从IParam中提取这两个值。

消息从何而来:

消息来自于用户的输入;消息来自于系统;

消息被存放在那里:

消息被存放在每个线程的消息队列中。

消息如何被线程取出:

GetMessage函数,PeekMessage.

GetMessage在取消息的时候,如果消息队列是空的。GetMessage函数将阻塞线程,知道消息队列有一个消息,GetMessage才返回

PeekMessage如果消息队列里面有消息,其行为和GetMessage一样。如果消息队列为空,PeekMessage立即返回

消息队列是否先进先出,Fl-FO

对大多数消息而言,是FIFO
但是消息队列会对特殊满息进行处理,例如WM_PAINT,WM_TIMER,WM_QUIT。

消息是否必须经过消息队列:

否,有些消息被直接发送给窗口,不经过消息队列,例如,激活窗口的消息。

命名约定

lpfn 指向函数的长指针

cb 字节数

lpsz 指向以零结束的字符串的长指针

最新文章

  1. W5200移植W5500驱动教程
  2. Android 高清加载巨图方案, 拒绝压缩图片
  3. Ajax解决IE浏览器兼容问题
  4. MySQL基础之第17章 MySQL日志
  5. 向linux内核版本号添加字符/为何有时会自动添加“+”号
  6. Ubuntu16.04.1 安装Redis-Cluster
  7. Handler处理长时间事件
  8. 理解Lambda表达式
  9. JQuery中的相反的地方
  10. 第54章 身份资源 - Identity Server 4 中文文档(v1.0.0)
  11. [C++ Primer Plus] 第9章、内存模型和名称空间(一)程序清单
  12. MVC架构介绍-框架分层
  13. android布局管理器
  14. 解决 Delphi XE5 写Android程序的No resource identifier found for attribute... 错误【转】
  15. 【Android】7.2 LinearLayout(线性布局)
  16. python 字典的合并
  17. java web作用域page request session application
  18. 我与ARM的那些事儿1初识ARM
  19. C语言的不完整类型和前置声明(转)
  20. PHP程序执行时间过长,超时了怎么办

热门文章

  1. 重新学习微信小程序
  2. TrippleDESCSPEncrypt 加密解密试试看
  3. 最新 美柚java校招面经 (含整理过的面试题大全)
  4. activate-power-mode安装与设置
  5. 在Ubuntu中安装了MongoDB后无法启动mongod的问题
  6. 《Mysql - 字符串索引应该如何建立?》
  7. Redis 常用命令学四:列表类型命令
  8. 把cgrep mgrep集成到bashrc
  9. Thinking In Java 4th Chap6 访问权限控制
  10. Linux 编译kernel有关Kconfig文件详解