CreateWindow函数详解
在注册完窗口类后就需要进行窗口的创建,用到的函数理所当然就是CreateWindow(), 而这个函数是基于窗口类的,所以还需要指定几个参数来制定特定的窗口。而且像一些不带边框的窗口是怎么创建的也是具有相当的技巧的,就是创建的是不带标题和边框的窗口,然后自己在客户区绘制程序的内容,能够制作个性化的应用程序。
API解释
该函数创建一个重叠式窗口、弹出式窗口或子窗口。它指定窗口类,窗口标题,窗口风格,以及窗口的初始位置及大小(可选的)。函数也指该窗口的父窗口或所属窗口(如果存在的话),及窗口的菜单。
若要使用除 CreateWindow 函数支持的风格外的扩展风格,则使用 CreateWindowEx 函数代替 CreateWindow 函数。
API 函数原型:
HWND WINAPI CreateWindow(
_In_opt_ LPCTSTR lpClassName, // 窗口类名称
_In_opt_ LPCTSTR lpWindowName, // 窗口标题
_In_ DWORD dwStyle, // 窗口风格,或称窗口格式
_In_ int x, // 初始 x 坐标
_In_ int y, // 初始 y 坐标
_In_ int nWidth, // 初始 x 方向尺寸
_In_ int nHeight, // 初始 y 方向尺寸
_In_opt_ HWND hWndParent, // 父窗口句柄
_In_opt_ HMENU hMenu, // 窗口菜单句柄
_In_opt_ HINSTANCE hInstance, // 程序实例句柄
_In_opt_ LPVOID lpParam // 创建参数
);
注:_In_ 说明该参数是输入的,_opt_ 说明该参数是可选参数(不是说没有参数,而是可以利用宏搭配参数)。
参数解析:
参数 |
含义 |
lpClassName |
1. 窗口类名称,可以是一个指向 NULL 结束的字符串或一个整型数值 |
lpWindowName |
1. 窗口标题,一个指向 NULL 结束的字符串指针 |
dwStyle |
指定创建窗口的风格(详见下方↓) |
x |
1. 指定窗口的初始水平位置(x 坐标) |
y |
1. 指定窗口的初始垂直位置(y 坐标) |
nWidth |
1. 以设备单元指明窗口的宽度 |
nHeight |
1. 以设备单元指明窗口的高度 |
hWndParent |
1. 指向被创建窗口的父窗口或所有者窗口的句柄 |
hMenu |
1. 指向窗口菜单句柄,或依据窗口风格指明一个子窗口标识 |
hInstance |
与窗口相关联的模块实例的句柄 |
lpParam |
1. 指向一个值的指针,该值传递给窗口 WM_CREATE 消息。该值通过在 IParam 参数中的 CREATESTRUCT 结构传递 |
dwStyle 窗口风格解析
窗口风格 |
含义 |
WS_BORDER |
创建一个带边框的窗口 |
WS_CAPTION |
创建一个有标题框的窗口(包含了 WS_BODER 风格) |
WS_CHILD |
创建一个子窗口,这个风格的窗口不能拥有菜单也不能与 WS_POPUP 风格合用 |
WS_CHILDWINDOW |
与 WS_CHILD 相同 |
WS_CLIPCHILDREN |
当在父窗口内绘图时,排除子窗口区域,在创建父窗口时使用这个风格 |
WS_CLIPSIBLINGS |
1. 排除子窗口之间的相对区域,也就是,当一个特定的窗口接收到 WM_PAINT 消息时,WS_CLIPSIBLINGS 风格将所有层叠窗口排除在绘图之外,只重绘指定的子窗口 |
WS_DISABLED |
1. 创建一个初始状态为禁止的子窗口,一个禁止状态的窗口不能接受来自用户的输入信息 |
WS_DLGFRAME |
创建一个带对话框边框风格的窗口,这种风格的窗口不能带标题条 |
WS_GROUP |
1. 指定一组“控制窗口”的第一个“控制窗口” |
WS_HSCROLL |
创建一个有水平滚动条的窗口 |
WS_ICONIC |
创建一个初始状态为最小化状态的窗口,与 WS_MINIMIZE 风格相同 |
WS_MAXIMIZE |
创建一个初始状态为最大化状态的窗口 |
WS_MAXIMIZEBOX |
创建一个具有最大化按钮的窗口,该风格不能与 WS_EX_CONTEXTHELP 风格同时出现,同时必须指定 WS_SYSMENU 风格 |
WS_MINIMIZE |
创建一个初始状态为最小化状态的窗口,与 WS_ICONIC 风格相同 |
WS_MINIMIZEBOX |
创建一个具有最小化按钮的窗口,该风格不能与 WS_EX_CONTEXTHELP 风格同时出现,同时必须指定 WS_SYSMENU 风格 |
WS_OVERLAPPED |
产生一个层叠的窗口,一个层叠的窗口有一个标题条和一个边框,与 WS_TILED 风格相同 |
WS_OVERLAPPEDWINDOW |
相当于(WS_OVERLAPPED | WS_CAPTION | WS_SYSMENU | WS_THICKFRAME | WS_MINIMIZEBOX | WS_MAXIMIZEBOX),与 WS_TILEDWINDOW 风格相同 |
WS_POPUP |
创建一个弹出式窗口,该风格不能与 WS_CHILD 风格同时使用。 |
WS_POPUPWINDOW |
相当于(WS_POPUP | WS_BORDER | WS_SYSMENU),但 WS_CAPTION 和 WS_POPUPWINDOW 必须同时设定才能使窗口某单可见 |
WS_SIZEBOX |
创建一个可调边框的窗口,与 WS_THICKFRAME 风格相同 |
WS_SYSMENU |
创建一个在标题条上带有窗口菜单的窗口,必须同时设定 WS_CAPTION 风格 |
WS_TABSTOP |
1. 创建一个“控制窗口”,在用户按下 Tab 键时可以获得键盘焦点。 |
WS_THICKFRAME |
创建一个具有可调边框的窗口,与 WS_SIZEBOX 风格相同 |
WS_TILED |
产生一个层叠的窗口,一个层叠的窗口有一个标题和一个边框,与 WS_OVERLAPPED 风格相同 |
WS_TILEDWINDOW |
相当于(WS_OVERLAPPED | WS_CAPTION | WS_SYSMENU | WS_THICKFRAME | WS_MINIMIZEBOX | WS_MAXIMIZEBOX),与 WS_OVERLAPPEDWINDOW 风格相同 |
WS_VISIBLE |
创建一个初始状态为可见的窗口 |
WS_VSCROLL |
创建一个有垂直滚动条的窗口 |
返回值:
1. 如果函数成功,返回值为新窗口的句柄。
2. 如果函数失败,返回值为 NULL。
应用举例
一 创建带垂直滚动条和水平滚动条的窗口程序
hwnd = CreateWindow(szAppName,
TEXT("垂直和水平滚动条"),
WS_OVERLAPPEDWINDOW | WS_HSCROLL | WS_VSCROLL, // | 上两参数即可
CW_USEDEFAULT,
CW_USEDEFAULT,
CW_USEDEFAULT,
CW_USEDEFAULT,
NULL,
NULL,
hInstance,
NULL);
二 创建用户不可操作的win32程序
hwnd = CreateWindow(szAppName,
TEXT("垂直和水平滚动条"),
WS_DISABLED, // 修改为失能参数
CW_USEDEFAULT,
CW_USEDEFAULT,
CW_USEDEFAULT,
CW_USEDEFAULT,
NULL,
NULL,
hInstance,
NULL);
三 使用弹出式窗口创建不带边框和标题栏的窗口
hwnd = CreateWindow(szAppName,
TEXT("垂直和水平滚动条"),
WS_POPUP, // 弹出式窗口,并且要修改长宽
CW_USEDEFAULT,
CW_USEDEFAULT,
CW_USEDEFAULT,
CW_USEDEFAULT,
NULL,
NULL,
hInstance,
NULL);
四 带边框的弹出式窗口
hwnd = CreateWindow(szAppName,
TEXT("垂直和水平滚动条"),
WS_POPUP | WS_SIZEBOX, // 弹出式窗口,并且要修改长宽
CW_USEDEFAULT,
CW_USEDEFAULT,
CW_USEDEFAULT,
CW_USEDEFAULT,
NULL,
NULL,
hInstance,
NULL);