`
gyht0808
  • 浏览: 116015 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

CreateWindow

阅读更多

CreateWindow
    函数功能:该函数创建一个重叠式窗口、弹出式窗口或子窗口。它指定窗口类,窗口标题,窗口风格,以及窗口的初始位置及大小(可选的)。该函数也指定该窗口的父窗口或所属窗口(如果存在的话),及窗口的菜单。若要使用除CreateWindow函数支持的风格外的扩展风格,则使用CreateWindowEx函数代替CreateWindow函数。
    函数原型:HWND CreateWindow(LPCTSTR lpClassName,LPCTSTR lpWindowName,DWORD dwStyle,int x,int y,int nWidth,int nHeight,HWND hWndParent,HMENU hMenu,HANDLE hlnstance,LPVOID lpParam);

    参数:
    lpClassName:指向一个空结束的字符串或整型数atom。如果该参数是一个整型量,它是由此前调用theGlobalAddAtom函数产生的全局量。这个小于0xC000的16位数必须是lpClassName参数字的低16位,该参数的高位必须是0。如果lpClassName是一个字符串,它指定了窗口的类名。这个类名可以是任何用函数RegisterClassEx注册的类名,或是任何预定义的控制类名。请看说明部分的列表。
    lpWindowName:指向一个指定窗口名的空结束的字符串指针。
    如果窗口风格指定了标题条,由lpWindowName指向的窗口标题将显示在标题条上。当使用Createwindow函数来创建控制例如按钮,选择框和静态控制时,可使用lpWindowName来指定控制文本。
    dwStyle:指定创建窗口的风格。该参数可以是下列窗口风格的组合再加上说明部分的控制风格。风格意义:

    WS_BORDER:创建一个单边框的窗口。
    WS_CAPTION:创建一个有标题框的窗口(包括WS_BORDER风格)。
    WS_CHILD:创建一个子窗口。这个风格不能与WS_POPUP风格合用。
    WS_CHILDWINDOW:与WS_CHILD相同。
    WS_CLIPCHILDREN:当在父窗口内绘图时,排除子窗口区域。在创建父窗口时使用这个风格。
    WS_CLIPSIBLINGS:排除子窗口之间的相对区域,也就是,当一个特定的窗口接收到WM_PAINT消息时,WS_CLIPSIBLINGS 风格将所有层叠窗口排除在绘图之外,只重绘指定的子窗口。如果未指定WS_CLIPSIBLINGS风格,并且子窗口是层叠的,则在重绘子窗口的客户区时,就会重绘邻近的子窗口。
    WS_DISABLED:创建一个初始状态为禁止的子窗口。一个禁止状态的窗不能接受来自用户的输人信息。
    WS_DLGFRAME:创建一个带对话框边框风格的窗口。这种风格的窗口不能带标题条。
    WS_GROUP:指定一组控制的第一个控制。这个控制组由第一个控制和随后定义的控制组成,自第二个控制开始每个控制,具有WS_GROUP风格,每个组的第一个控制带有WS_TABSTOP风格,从而使用户可以在组间移动。用户随后可以使用光标在组内的控制间改变键盘焦点。
    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_SYSMENUWS_THICKFRAME,WS_MINIMIZEBOX,WS_MAXMIZEBOX风格的层叠窗口,与WS_TILEDWINDOW风格相同。
    
WS_POPUP:创建一个弹出式窗口。该风格不能与WS_CHLD风格同时使用。
    WS_POPUWINDOW:创建一个具有WS_BORDER,WS_POPUP,WS_SYSMENU风格的窗口,WS_CAPTION和WS_POPUPWINDOW必须同时设定才能使窗口某单可见。
    WS_SIZEBOX:创建一个可调边框的窗口,与WS_THICKFRAME风格相同。
    WS_SYSMENU:创建一个在标题条上带有窗口菜单的窗口,必须同时设定WS_CAPTION风格。
    WS_TABSTOP:创建一个控制,这个控制在用户按下Tab键时可以获得键盘焦点。按下Tab键后使键盘焦点转移到下一具有WS_TABSTOP风格的控制。
    WS_THICKFRAME:创建一个具有可调边框的窗口,与WS_SIZEBOX风格相同。
    WS_TILED:产生一个层叠的窗口。一个层叠的窗口有一个标题和一个边框。与WS_OVERLAPPED风格相同。
    WS_TILEDWINDOW:创建一个具有WS_OVERLAPPED,WS_CAPTION,WS_SYSMENU MS_THICKFRAME.
    WS_MINIMIZEBOX,WS_MAXMIZEBOX风格的层叠窗口。与WS_OVERLAPPEDWINDOW风格相同。
    WS_VISIBLE:创建一个初始状态为可见的窗口。
    WS_VSCROLL:创建一个有垂直滚动条的窗口。


    X:指定窗口的初始水平位置。对一个层叠或弹出式窗口,X参数是屏幕坐标系的窗口的左上角的初始X坐标。对于子富口,x是子窗口左上角相对父窗口客户区左上角的初始X坐标。如果该参数被设为CW_USEDEFAULT则系统为窗口选择缺省的左上角坐标并忽略Y参数。CW_USEDEFAULT只对层叠窗口有效,如果为弹出式窗口或子窗口设定,则X和y参数被设为零。
    Y:指定窗口的初始垂直位置。对一个层叠或弹出式窗日,y参数是屏幕坐标系的窗口的左上角的初始y坐标。对于子窗口,y是子窗口左上角相对父窗口客户区左上角的初始y坐标。对于列表框,y是列表框客户区左上角相对父窗口客户区左上角的初始y坐标。如果层叠窗口是使用WS_VISIBLE风格位创建的并且X参数被设为CW_USEDEFAULT,则系统将忽略y参数。
    nWidth:以设备单元指明窗口的宽度。对于层叠窗口,nWidth或是屏幕坐标的窗口宽度或是CW_USEDEFAULT。若nWidth是CW_USEDEFAULT,则系统为窗口选择一个缺省的高度和宽度:缺省宽度为从初始X坐标开始到屏幕的右边界,缺省高度为从初始X坐标开始到目标区域的顶部。CW_USED
EFAULT只参层叠窗口有效;如果为弹出式窗口和子窗口设定CW_USEDEFAULT标志则nWidth和nHeight被设为零。
    nHeight:以设备单元指明窗口的高度。对于层叠窗口,nHeight是屏幕坐标的窗口宽度。若nWidth被设为CW_USEDEFAULT,则系统忽略nHeight参数。
    hWndParent:指向被创建窗口的父窗口或所有者窗口的旬柄。若要创建一个子窗口或一个被属窗口,需提供一个有效的窗口句柄。这个参数对弹出式窗日是可选的。Windows NT 5.0;创建一个消息窗口,可以提供HWND_MESSAGE或提供一个己存在的消息窗口的句柄。
    hMenu:菜单句柄,或依据窗口风格指明一个子窗口标识。对于层叠或弹出式窗口,hMenu指定窗口使用的菜单:如果使用了菜单类,则hMenu可以为NULL。对于子窗口,hMenu指定了该子窗口标识(一个整型量),一个对话框使用这个整型值将事件通知父类。应用程序确定子窗口标识,这个值对于相同父窗口的所有子窗口必须是唯一的。
    hInstance:与窗口相关联的模块事例的句柄。
    lpParam:指向一个值的指针,该值传递给窗口 WM_CREATE消息。该值通过在lParam参数中的CREATESTRUCT结构传递。如果应用程序调用CreateWindow创建一个MDI客户窗口,则lpParam必须指向一个CLIENTCREATESTRUCT结构。
    返回值:如果函数成功,返回值为新窗口的句柄:如果函数失败,返回值为NULL。若想获得更多错误信息,请调用GetLastError函数。
    备注:在返回前,CreateWindow给窗口过程发送一个WM_CREATE消息。对于层叠,弹出式和子窗口,CreateWindow给窗口发送WM_CREATE,WM_GETMINMAXINFO和WM_NCCREATE消息。消息WM_CREATE的lParam参数包含一个指向CREATESTRUCT结构的指针。如果指定了WS_VISIBLE风格,CreateWindow向窗口发送所有需要激活和显示窗口的消息。
    获取有关任务条是否为创建的窗口显示一个按钮的控制信息,参看Taskbar按钮的Visbility。
   
以下预定义的控制类可以在lpClassName参数中指定。注意在dwStyle参数中可以使用的相应的控制风格。

    BUTTON:按钮,是一个小矩形子窗口,用户可以点击来打开或关闭。按钮控制可以单独使用或包含在组中使用,可以为控制写标签或不写标签。当用户点击按钮控制时按钮的外观有明显的改变。请参看Button。查看dwStyle参数中指定的按钮风格表请参考Button Style。
    COMBOBOX:
组合框,由一个列表框和一个类似于编辑控制的选择域组成。在使用这个风格控制时,应用程序或者使列表框一直显示或者是作成一个下拉列表。如果列表框可见,则在编辑域中输入字符将使列表框中与字符一致的第一个域高亮。反之,在列表框中选择的项将显示在编辑域中。请参看Combo Boxes。
    查看dwStyle参数中指定的组合框风格表请参考Combo Boxes Style。
    EDIT:
编辑框,一个小的矩形子窗口,用户可以使用键盘向其中输入文本。用户可以通过点击或按Tab键来选中编辑框控制并且使控制获得焦点。当编辑框中显示一个闪烁的插入记号时,用户可以输入文本。使用鼠标移动光标,选择被替换的字符或设置插入字符的位置或使用回退键删除字符。请参看Edit controls。
    查看dwStyle参数中指定的编辑框风格的表格请参考Edit Control Style。
    LISTBOX:
列表框,字符串的列表。当应用程序必须显示名称的列表,例如文件名列表等,使用户可以从中选择时就可指定列表框。用户可以通过单击来选择名称。选择时,被选择名高亮,同时传递给父窗口一个通知消息。请参看LiSt Box Style。查看dwStyle参数中指定的列表风格表请参考List BOX Control Style。
    MDICLIENT:客户设计出MDI客户窗口。窗口接收控制MDI应用程序子窗口的消息。建议使用两种控制风格位:WS_CLIPCHILDREN和WS_CHILD。指定了WS_HSCROLL和WS_VSCROLL风格的MDI客户窗口允许用户将MDI子窗口滑动进入视窗。请参看MDI。
    RichEdit:设计一个Rich Editl.0版的控制。该控制使用户可以以字符和段落格式测览和编辑文本,并且可以包含嵌入的COM对象。请参看Rich Edit Controls。查看dwStyle参数中指定的RichEdit风格表请参考List Box Control Style。
    RICHEDIT_CLASS:设计一个Rich Edik2.0版的控制。该控制使用户可以以字符和段落格式测览和编辑文本,并且可以包含嵌入的COM对象。请参看RichEditControls。查看dwStyle参数中指定的RichEdit风格表请参考RichEditControIStyle。
    SCROLLBAR: 滚动条,设计的一个包含着一个滚动盒和两端有方向箭头的矩形。只要用户点击了控制,滚动条就给父窗口发送一个通知消息。如有必要,父窗口负责更新滚动条的位置。请参看ScrollBars。查看dwStyle参数中指定的滚动条风格表请参考Scroll Bars Style。
    STATIC:一个简单的静态文本域,文本盒或矩形用于给控制加标签,组合控制或将控制与其他控制分开。
    静态控制不提供输入和也不提供输出。请参看Static Control Styles。查看dwStyle参数中指定的静态文本风格表请参考Scroll Bars Style。

    Windows95:系统可以支持最大16,364个窗口句柄。

    备注:如果在链接应用程序时指明是Windows 4.x版本,除非应用程序的窗口有窗口某单,否则窗口控制没有标题控制。对Windows3.x版本没有这种要求。

    Windows CE:CreateWindow是以“宏”方式完成的。它被定义为CreateWindowEX,并且dwExStyle参数被置为长整数0。不支持菜单条控制,除非被声明为子窗口标志否则hMenu参数必须为NULL。不支持MDICLIENT窗口类。dwStyle参数可以是对话框(Dialogue Box),窗口(Windows),控制(Controls)文件中的窗口风格和控制风格的组合。
    下列dwStyle标志在窗口中不支持:
    WS_CHILDWINDOW;WS_ICONIC;WS_MAXIMIZE;WS_MAXIMIZEBOX;WS_MINIMIZE;WS_MINIMIZEBOX;
    WS_OVERLAPPEDWINDOW;WS_POPUPWINDOW;WS_SIZEBOX;WS_THICKFRAME;WS_TILED;WS_TILEDWINDOW
    下列dwStyle标志在控制和对话框中不支持:
    不支持的按钮风格和静态控制风格:
    BS_LEFTTEXT;BS_MULTILINE;BS_TEXT;BS_USERBUTTON;
   
不支持的静态控制风格:SS_BLACKFRAME;SS_GRAYFRAME;SS_METAPICT; SS_SIMPLE;SS_WHITERECT;SS_BLACKRECT;SS_GRAYRECT;SS_RIGHTIMAGE;SS_WHITEFRAME
    不支持组合框风格。
    CBS_OWNERDRAWFIXED;CBS_OWNWEDRAWVARIABLE;CBS_SIMPLE
    不支持列表框控制风格。
    LBS_NODATA;
LBS_OWNERDRAWFIXED;LBS_OWNERDRAWVARIABLE;LBS_STANDARD
    不支持的对话框风格:
     DS_ABSALIGN;DS_CENTERMOUSE;DS_CONTEXTHELP;
DS_FIXEDSYS;DS_NOFAILCREATE;DS_NOIDLEMSG;DS_SYSMODAL;
    不支持滚动条的风格
    SBS_BOTTOMALIGN SBS_RIGHTALIGN;SBS_SlZEBOXBOTT0MRIHTALIGN;SBS_SIZEGRIP
    可使用BS_OWNERDRAW风格来代替BS_USERBUTTON风格。
    可使用SS_LEFT或SS_LEFTNOWORDWRAP风格来代替静态控制的SS_SIMPLE风格。
    不支持MDICLIENT窗口类。
    所有窗口都隐含WS_CLIPSIBLINGS和 WS_CLIPCHILDREN风格。
    Windows CE1.0版除对话框外不支持被属窗口。如果hwndParent参数不为NULL,则窗口隐含给出WS_CHILD风格。Windows CE1.0不支持菜单条。

    速查: Windows NT:3.1以上版本;Windows:95以上版本;Windows CE:1.0以上版本;头文件:winuser.h;库文件:user32.lib; Unicode:在Windows NT上实现为Unicode和ANSI两种版本。

分享到:
评论

相关推荐

    CreateWindow函数详解.doc )

    ### CreateWindow函数详解 #### 一、概述 `CreateWindow`函数是Windows编程中的核心API之一,用于创建各种类型的窗口,如交叠窗口、弹出窗口或子窗口等。通过该函数,开发者能够指定窗口的各种属性,包括但不限于...

    CreateWindow创建按钮、创建编辑框、改变鼠标状态

    在Windows编程中,`CreateWindow`函数是核心API之一,用于动态地在窗口或对话框中创建各种控件,如按钮、编辑框等。本文将深入讲解如何利用`CreateWindow`来创建这些基本元素,并讨论如何改变鼠标的显示状态。 首先...

    CreateWindow创建窗口

    窗口中的文字如何刷新

    Opengl3.3_CreateWindow

    OpenGL 3.3_CreateWindow 知识点详解 在计算机图形学领域,OpenGL 是一个广泛使用的跨语言、跨平台的应用程序编程接口(API),用于渲染2D、3D矢量图形。OpenGL 3.3 是该接口的一个版本,它包含了众多的改进和新...

    NeHe-OpenGl-Qt5-Lesson01_CreateWindow_islinyoubiao.zip

    这个“NeHe-OpenGl-Qt5-Lesson01_CreateWindow_islinyoubiao.zip”压缩包包含了一个基于Qt5的OpenGL教程的第一课——创建窗口。 Lesson01_CreateWindow是初学者学习OpenGL编程的第一步,其主要目标是设置一个基本的...

    c#通过win32api方式创建窗体

    3. **创建窗体实例**:使用`CreateWindowEx`或`CreateWindow`函数创建窗体。这些函数返回一个句柄,代表了创建的窗口。 4. **消息循环**:窗体的事件处理是通过消息队列和消息循环来完成的。你需要创建一个消息循环...

    VC 创建WinExample和MFCExample窗口程序演示.rar

     hWnd = CreateWindow("HelloMsg",// 窗口类名  "我的窗口", // 窗口标题  WS_OVERLAPPEDWINDOW,// 窗口样式  CW_USEDEFAULT,// 窗口最初的x位置  CW_USEDEFAULT,// 窗口最初的y位置  CW_USEDEFAULT,// 窗口的...

    Windows编程_情人节拼图小游戏

    你可以使用`CreateWindow`函数创建窗口,并通过`SetWindowLong`和`GetWindowLong`等函数设置窗口类和风格。窗口中的控件,如按钮、菜单和图像控件,可以通过`CreateWindowEx`创建。 3. **图像处理**:游戏的核心是...

    VC++6[1].0入门【第七章_windows标准控件】.doc

    - **动态创建**:在运行时根据需求定义控件类对象,使用CreateWindow()或CreateWindowEx()函数创建,再通过ShowWindow()函数显示。 **控件的属性设置**: - 静态创建的控件可在对话框模板中直接设置属性,运行时则...

    改变窗口控制的背景颜色和字体颜色

    - `CreateWindow`或`CreateWindowEx`函数用于创建窗口,它们接受一个`WNDCLASS`结构作为参数,其中包含了窗口类的信息,包括背景刷(background brush)和字体(font)。背景刷定义了窗口的默认背景颜色,而字体则...

    SDK:用CreateWindowEx创建模态对话框

    ### SDK:用CreateWindowEx创建模态对话框 在Windows编程中,模态对话框是一种常用的用户界面元素,用于向用户提供必要的信息或者收集用户的输入。模态对话框阻止用户与程序中的其他窗口交互,直到该对话框被关闭...

    VC开发的简单的helloword

    这个过程涉及到的主要知识点是`CreateWindow`函数,这是Windows API中用于创建窗口的核心函数。 首先,让我们了解什么是Visual C++。VC++是微软公司开发的一个集成开发环境(IDE),它主要用于编写使用C++语言的...

    win32创建能拖动的窗口

    在Windows编程领域,Win32 API是开发原生Windows应用程序的核心接口。`CreateWindowEx`函数是其中的一个关键函数,用于创建窗口实例。这个过程涉及到了窗口类的定义、消息循环以及窗口过程的处理。...

    Python-Tkinter Text输入内容在界面显示的实例

    使用Tkinter(py2.7)text文本框中... self.createwindow() self.run() def createwindow(self): self.win.geometry('400x400') #label 1 self.label_text = tk.StringVar() self.label_text.set(----) sel

    Win32 Controls_Vc_

    总之,掌握Win32 API的控件创建和管理是Windows编程的基础,这包括理解各种窗口样式、消息机制以及如何使用`CreateWindow`和`CreateWindowEx`函数。通过学习这些,开发者能够更灵活地控制应用程序的用户界面,并且不...

    MFC 动态创建窗口与对话框

    下面将详细探讨如何使用`CreateWindow`和`CreateWindowEx`函数来实现这一目标。 `CreateWindow`和`CreateWindowEx`是Windows API中的两个关键函数,用于在运行时创建窗口和对话框。这两个函数允许开发者在程序执行...

    MFC基本控件使用详解

    - **动态创建控件**:除了在资源编辑器中创建控件外,还可以在运行时动态创建控件,这需要对`CreateWindow`函数有一定的了解。 - **控件样式**:每个控件都有自己的样式集,通过设置不同的样式可以改变控件的行为和...

    jmi.rar_visual c_winapi

    《Visual C++与WinAPI深度探索——从CreateWindow到消息调度》 在Windows程序开发中,Visual C++作为强大的编程工具,与WinAPI相结合,能够实现底层系统级别的交互,为开发者提供了广泛的功能。本示例"jmi.rar_...

    Win32编程常用函数

    HWND hWnd = CreateWindow( lpszClassName, // 窗口类名 lpszWindowName, // 窗口标题 dwStyle, // 窗口样式 x, y, // 初始位置 nWidth, nHeight, // 宽度和高度 hWndParent, // 父窗口句柄 hMenu, // 菜单...

Global site tag (gtag.js) - Google Analytics