使用 C++ 和 Win32 API 创建 GUI 窗口应用程序:从零构建 Windows 桌面界面
文章目录
引言
在本系列 Win32 API 教程 中,我们将带你从零开始,使用 C++ Win32 窗口示例 构建最基础的 Windows GUI 编程 应用。无需任何面向对象特性,只要你掌握 C 或 C++ 就能轻松上手。即使你以前使用过 WinForms、WPF 或 Qt,本教程也会帮助你深入理解更底层的 Win32 API。
开发环境与工具

-
IDE:Code::Blocks(亦可选用 Visual C++ 或其他 IDE)。
-
编译器:GCC(MinGW)或 Microsoft VC++(MSVC)。
-
项目类型:
- Win32 GUI 项目:含模板代码,自动链接所需库。
- Console 项目:需手动包含
<windows.h > f,适合理解底层调用。
-
包含头文件与入口函数(WinMain 详解)
在源文件顶部添加 注册窗口类 所需的头:
#include
Win32 GUI 程序的入口函数不是 main,而是:
int WINAPI WinMain(
HINSTANCE hInstance, // 应用实例句柄
HINSTANCE hPrevInstance, // 上一个实例(忽略)
LPSTR lpCmdLine, // 命令行参数
int nShowCmd // 窗口显示方式
);
-
WINAPI:调用约定(
__stdcall)。 -
四个参数分别提供应用实例、旧实例、命令行字符串和启动时窗口状态。
-
测试 Win32 API 可用性(MessageBox 使用方法)
在 WinMain 中插入以下代码,验证 Win32 API 教程 环境是否就绪:
MessageBox(
nullptr, // 无父窗口
"Hello, Win32!", // 消息文本
"First GUI", // 窗口标题
MB_OK // OK 按钮
);
return 0;
编译并运行后,你将看到一个带 “OK” 按钮的对话框。
注册窗口类(RegisterClass 示例)
要创建真正的窗口,需先定义并注册一个 窗口类(WNDCLASSEXW):
-
初始化结构体
WNDCLASSEXW wc = {0}; -
设置必要成员
wc.cbSize = sizeof(WNDCLASSEXW); wc.style = CS_HREDRAW | CS_VREDRAW; wc.lpfnWndProc = WndProc; // 窗口过程 wc.hInstance = hInstance; // 应用实例 wc.hCursor = LoadCursor(nullptr, IDC_ARROW); // 默认箭头光标 wc.hbrBackground = GetSysColorBrush(COLOR_WINDOW); // 默认背景色 wc.lpszClassName = L"MyWindowClass"; // 类名 -
注册窗口类
if (!RegisterClassExW(&wc)) { MessageBox(nullptr, "注册窗口类失败!", "Error", MB_ICONERROR); return -1; }
创建窗口(CreateWindow 示例)
注册成功后,使用 CreateWindowW 创建一个可见的 Windows GUI 编程 窗口:
HWND hwnd = CreateWindowW(
L"MyWindowClass", // 窗口类名
L"My First Window", // 窗口标题
WS_OVERLAPPEDWINDOW | WS_VISIBLE, // 窗口样式
100, 100, 500, 500, // 位置与大小
nullptr, nullptr, nullptr, nullptr
);
if (!hwnd) {
MessageBox(nullptr, "创建窗口失败!", "Error", MB_ICONERROR);
return -1;
}
消息循环(Message Loop)
窗口创建后必须进入 消息循环,否则程序会立即退出:
MSG msg;
while (GetMessage(&msg, nullptr, 0, 0)) { // 获取消息
TranslateMessage(&msg); // 翻译键盘消息
DispatchMessage(&msg); // 派发给窗口过程
}
-
GetMessage:获取消息,返回
FALSE时退出循环。 -
TranslateMessage & DispatchMessage:确保消息正确处理。
-
窗口过程(DefWindowProc 默认消息处理)
定义 WndProc 回调,实现 __WM_DESTROY 处理__ 等:
LRESULT CALLBACK WndProc(
HWND hwnd,
UINT uMsg,
WPARAM wParam,
LPARAM lParam
) {
switch (uMsg) {
case WM_DESTROY:
PostQuitMessage(0); // 退出消息循环
return 0;
default:
return DefWindowProcW(hwnd, uMsg, wParam, lParam);
}
}
-
PostQuitMessage:让
GetMessage返回FALSE,结束程序。 -
DefWindowProc:默认处理所有未自定义的消息。
-
编译与运行
- 修复可能的编译错误(如逗号、括号错误)。
- 重新编译并运行后,你将看到一个可以 调整大小、最小化、关闭 的基础窗口。
总结与下一步
- 完成了从包含
< windows.h >、WinMain 详解、MessageBox 使用方法 到 注册窗口类、CreateWindow 示例、消息循环、DefWindowProc 默认消息处理 的完整流程。
本文选自YouTube视频:https://www.youtube.com/watch?v=8GCvZs55mEM
最新文章
- 金融科技API:揭秘金融领域快速增长的秘密
- DEX 撮合引擎多云灰度发布 API:6 天实战经验
- 通过 Python 使用 Pexels图片库 API 打造个性化壁纸应用
- 用 AWS Smithy 构建下一代 API 服务
- 20位SEO专家分享他们从Google API泄露事件中的关键见解
- OpenAPI vs RAML vs API Blueprint,谁是最后的赢家?
- API设计模式秘诀:构建强大的API所需了解的内容
- 如何使用RedditAPI进行数据抓取
- API性能监控的关键指标 | APItoolkit
- 深入探索Java反射API:全面指南 – Aeon Tanvir
- 如何获取 tianqiip 开放平台 API Key 密钥(分步指南)
- Python实现表情识别:利用稠密关键点API分析面部情绪