MFC之控件

静态文本框:

dwStyle:


CStatic类的主要成员函数:



注意的是:CStatic是由CWind的派生类。


静态文本框:

CEdit类成员函数: 

GetWindowText和SetWindowText,GetWindowTextLength。

int LineFromChar(int nIndex = –1) const;
返回多行编辑框中指定索引的字符所在行的行号(从零开始),只适用于多行编辑框。nIndex等于-1则返回所选择正文的第一个字符所在行的索引。如果没有选择正文,则返回当前行的行号。


int LineIndex(int nLine = –1) const;
返回由nLine指定行的起始字符在编辑框的整个字符串中的索引,只适用于多行编辑框。如果指定行超过编辑框的最大行数,则返回-1,而如果nLine为-1,则返回当前插入符所在行的起始字符的索引。


void GetSel(int& nStartChar,int& nEndChar) const;
获取选择正文的索引范围。nStartChar返回被选择正文的起始索引,nEndChar返回被选择正文的终止索引(不包括在选择范围内)。如果没有选择正文,则两者均为当前插入符的索引。


void SetSel(int nStartChar,int nEndChar,BOOL bNoScroll=FALSE);
选择编辑框中的正文。nStartChar为选择开始处的索引,nEndChar为选择结束处的索引。如果nStartChar为0并且nEndChar为-1,则选择所有正文,而如果nStartChar为-1则取消所有选择。bNoScroll为FALSE时滚动插入符并使之可见,为TRUE时不滚动。


void ReplaceSel(LPCTSTR lpszNewText,BOOL bCanUndo = FALSE);
用lpszNewText指向的字符串来替换选择的正文。如果bCanUndo为TRUE则替换可以被撤销。


int GetLineCount() const;
获取正文的行数,只适用于多行编辑框。如果编辑框没有正文则返回1。


int LineLength( int nLine = –1 ) const;
获取指定字符索引所在行的字节长度(行尾的回车和换行符不计算在内),参数nLine 说明了为字符索引。如果nLine 的值为-1,则函数返回当前行的长度(假如没有正文被选择),或选择正文占据的行的字符总数减去选择正文的字符数(假如有正文被选择)。若用于单行编辑框,则函数返回整个正文的长度。


int GetLine( int nIndex, LPTSTR lpszBuffer ) const;
int GetLine( int nIndex, LPTSTR lpszBuffer, int nMaxLength ) const;
用来获得指定行的正文(不包括行尾的回车和换行符),只适用于多行编辑框。参数nIndex 是行号,lpszBuffer 指向存放正文的缓冲区,nMaxLength 规定了拷贝的最大字节数。若指定的行号小于编辑框的实际行数,函数返回实际拷贝的字节数,若指定的行号大于编辑框的实际行数,则函数返回0。需要注意的是,GetLine 函数不会在缓冲区中字符串的末尾添加字符串结束符(NULL)。 


UINT GetLimitText( ) const;
获取编辑框能够接受的正文的最大字节数。


void LimitText(int nChars = 0);
设置用户在编辑框中可以输入的正文的最大长度(字节数)。如果nChars为0,则最大长度为UINT_MAX个字节。

<span style="font-size:18px;">  m_editMultiLine.SetWindowText(_T("正文的雷人预期"));  // 设置编辑框正文为“<span style="font-family: Arial, Helvetica, sans-serif;">正文的雷人预期</span>”   
  m_editMultiLine.SetSel(5, 7);                            // 选择起始索引为5,终止索引为7,选择的正文,即“前五个字”   
  m_editMultiLine.ReplaceSel(_T("\r\nwww.zhibo8.cc"));  // 将选择的“博客”替换为“\r\nwww.zhibo8.cc”   
</span>
结果为:正文的雷人

             www.zhibo8.cc


按钮控件:

Button、Radio Button、Check Box

注意的是:控件有3种状态: 选择、未选择、不确定

CButton类成员函数:

HBITMAP SetBitmap(HBITMAP hBitmap);
设置要在按钮中显示的位图。参数hBitmap为位图的句柄。返回值为按钮原来位图的句柄。


HBITMAP GetBitmap( ) const;
获取之前由SetBitmap函数设置的按钮位图的句柄。


void SetButtonStyle(UINT nStyle,BOOL bRedraw = TRUE);
设置按钮的风格。参数nStyle指定按钮的风格,bRedraw指定按钮是否重绘,为TRUE则重绘,否则不重绘,默认为重绘。 


UINT GetButtonStyle( ) const;
获取按钮控件的风格。


void SetCheck(int nCheck);
设置按钮的选择状态。参数nCheck为0表示未选中状态,1表示选中状态,2表示不确定状态(仅用于复选框)。

int GetCheck( ) const;
获取按钮的选择状态。返回值的意义同SetCheck函数的nCheck参数。


HCURSOR SetCursor(HCURSOR hCursor);
设置要显示到按钮上的光标图。参数hCursor指定了光标的句柄。返回值为按钮原来光标的句柄。


HCURSOR GetCursor( );
获取之前由SetCursor设置的光标的句柄。


HICON SetIcon(HICON hIcon);
设置要在按钮上显示的图标。参数hIcon指定了图标的句柄。返回值为按钮原来图标的句柄。


HICON GetIcon( ) const;
获取之前由SetIcon设置的图标的句柄。


void SetState(BOOL bHighlight);
设置按钮的高亮状态。参数bHighlight指定按钮是否高亮显示,非0则高亮显示,否则取消高亮显示状态。


UINT GetState( ) const;
获取按钮控件的选择状态、高亮状态和焦点状态。我们可以通过将返回值与各个掩码相与来获得各种状态值,掩码与对应的相与结果说明如下:
掩码0x0003:用来获取单选按钮或复选框的状态。相与结果为0表示未选中,1表示被选中,2表示不确定状态(仅用于复选框)。
掩码0x0004:用来判断按钮是否是高亮显示。相与结果为非0值表示按钮是高亮显示的。当单击按钮并按住鼠标左键时,按钮会呈高亮显示。
掩码0x0008:相与结果为非零值表示按钮拥有输入焦点。

void CheckDlgButton(int nIDButton,UINT nCheck);
用来设置按钮的选择状态。参数nIDButton指定了按钮的ID。nCheck的值为0表示按钮未被选择,为1表示按钮被选择,为2表示按钮处于不确定状态(仅用于复选框)。


UINT IsDlgButtonChecked(int nIDButton) const;
返回复选框或单选按钮的选择状态。返回值为0表示按钮未被选择,为1表示按钮被选择,为2表示按钮处于不确定状态(仅用于复选框)。


void CheckRadioButton(int nIDFirstButton,int nIDLastButton,int nIDCheckButton);
用来选择组中的一个单选按钮。参数nIDFirstButton指定了组中第一个按钮的ID,nIDLastButton指定了组中最后一个按钮的ID,nIDCheckButton指定了要选择的按钮的ID。


int GetCheckedRadioButton(int nIDFirstButton, int nIDLastButton);
用来获得一组单选按钮中被选中按钮的ID。参数nIDFirstButton 说明了组中第一个按钮的ID,nIDLastButton 说明了组中最后一个按钮的ID。


CWnd类的成员函数GetWindowText()、SetWindowText()等也可以用来获取或设置按钮中显示的文本。

列表框控件(ListBox):

listBox成员函数:

int GetCount( ) const;
返回值:返回列表框中列表项的数目,如果发生错误则返回LB_ERR

int GetSel(intnIndex) const;
参数:nIndex指定某个列表项的索引。
返回值:返回nIndex指定列表项的状态。如果此列表项被选择了则返回一个正值,否则返回0,若发生错误则返回LB_ERR

int SetSel(int nIndex,BOOLbSelect = TRUE);
此函数只用于多选列表框,使用它可以选择或取消选择指定的列表项。
参数:nIndex指定某个列表项的索引,若为-1则相当于指定了所有列表项。bSelectTRUE时选择指定列表项,否则取消选择指定列表项。
返回值:如果发生错误则返回LB_ERR

intAddString(LPCTSTR lpszItem);
此函数用来向列表框中添加字符串。如果列表框指定了LBS_SORT风格,字符串就被以排序顺序插入到列表框中,如果没有指定LBS_SORT风格,字符串就被添加到列表框的结尾。
参数:lpszItem指定了要添加的字符串。
返回值:返回字符串在列表框中添加的位置。如果发生错误则返回LB_ERR,内存不够则返回LB_ERRSPACE

intInsertString(int nIndex, LPCTSTR lpszItem);
该函数用来在列表框中的指定位置插入字符串。与AddString函数不同的是,InsertString函数不会导致LBS_SORT风格的列表框重新排序。不要在具有LBS_SORT风格的列表框中使用InsertString函数,以免破坏列表项的次序。
参数:。参数nIndex给出了插入位置(索引),如果值为-1,则字符串将被添加到列表的末尾。参数lpszItem指定了要插入的字符串。
返回值:返回实际的插入位置,若发生错误,会返回LB_ERRLB_ERRSPACE

intDeleteString(UINT nIndex);
该函数用于删除指定的列表项。
参数:nIndex 指定了要删除项的索引。
返回值:函数的返回值为剩下的列表项数目,如果nIndex超过了实际的表项总数,则返回LB_ERR

voidResetContent();
该函数用于清除所有列表项。

int GetText(intnIndex,LPTSTR lpszBuffer) const;
void GetText(intnIndex,CString& rString) const;
这两个成员函数用于获取指定列表项的字符串。参数nIndex指定了列表项的索引。参数lpszBuffer指向一个接收字符串的缓冲区。引用参数rString则指定了接收字符串的CString对象。第一个版本的函数会返回获得的字符串的长度,若出错,则返回LB_ERR;第二个版本的函数则不会。

int GetTextLen(intnIndex) const;
该函数返回指定列表项的字符串的字节长度。
参数:nIndex 指定了列表项的索引。
返回值:若出错则返回LB_ERR

int GetCurSel()const;
该函数仅适用于单选列表框,用来返回当前被选择项的索引,如果没有列表项被选择或有错误发生,则函数返回LB_ERR

intSetCurSel(int nSelect);
该函数仅适用于单选列表框,用来选择指定的列表项。该函数会滚动列表框以使选择项可见。参数nIndex指定了列表项的索引,若为-1,那么将清除列表框中的选择。若出错函数返回LB_ERR

int GetSelCount()const;
该函数仅用于多重选择列表框,它返回选择项的数目,若出错函数返回LB_ERR

int FindString(intnStartAfter,LPCTSTR lpszItem) const;
该函数用于对列表项进行与大小写无关的搜索。参数nStartAfter指定了开始搜索的位置,合理指定nStartAfter可以加快搜索速度,若nStartAfter-1,则从头开始搜索整个列表。参数lpszItem指定了要搜索的字符串。函数返回与lpszItem指定的字符串相匹配的列表项的索引,若没有找到匹配项或发生了错误,则会返回LB_ERRFindString函数先从nStartAfter指定的位置开始搜索,若没有找到匹配项,则会从头开始搜索列表。只有找到匹配项,或对整个列表搜索完一遍后,搜索过程才会停止,所以不必担心会漏掉要搜索的列表项。

intSelectString(int nStartAfter,LPCTSTR lpszItem);
该函数仅适用于单选列表框,用来选择与指定字符串相匹配的列表项。该函数会滚动列表框以使选择项可见。参数的意义及搜索的方法与函数FindString类似。如果找到了匹配的项,函数返回该项的索引,如果没有匹配的项,函数返回LB_ERR并且当前的选择不被改变。


组合框控件ComboBox

分三种:Simple、Dropdown、Drop List

组合框被操作时会向父窗口发送通知消息,这些通知消息及其含义如下:

CBN_CLOSEUP:组合框的列表框组件被关闭,简易组合框不会发送该通知消息
CBN_DBLCLK
:用户在某列表项上双击鼠标,只有简易组合框才会发送该通知消息
CBN_DROPDOWN
:组合框的列表框组件下拉,简易式组合框不会发送该通知消息
CBN_EDITUPDATE
:在编辑框准备显示改变了的正文时发送该消息,下拉列表式组合框不会发送该消息
CBN_EDITCHANGE
:编辑框的内容被用户改变了,与CBN_EDITUPDATE不同,该消息是在编辑框显示的正文被刷新后才发出的,下拉列表式组合框不会发送该消息
CBN_ERRSPACE
:组合框无法申请足够的内存来容纳列表项
CBN_SELENDCANCEL
:表明用户的选择应该取消,当用户在列表框中选择了一项,然后又在组合框控件外单击鼠标时就会导致该消息的发送
CBN_SELENDOK
:用户选择了一项,然后按了回车键或单击了下滚箭头,该消息表明用户确认了自己所作的选择
CBN_KILLFOCUS
:组合框失去了输入焦点
CBN_SELCHANGE
:用户通过单击或移动箭头键改变了列表的选择
CBN_SETFOCUS
:组合框获得了输入焦点


CComboBox成员函数:

int GetCount( ) const;
获取组合框控件的列表框中列表项的数量。

int GetCurSel() const;
获取组合框控件的列表框中选中项的索引,如果没有选中任何项,该函数返回CB_ERR

int SetCurSel(int nSelect);
在组合框控件的列表框中选择某项。nSelect参数指定了要选择的列表项的索引,如果为-1则列表框中当前选择项被取消选中,编辑框也被清空。

DWORD GetEditSel( ) const;
获取组合框控件的编辑框中当前选择范围的起始和终止字符的位置。该函数返回一个32位数,低16位存放起始位置,高16位存放选择范围后第一个非选择字符的位置。如果该函数用于下拉列表式组合框时,会返回CB_ERR

BOOLSetEditSel(int nStartChar,int nEndChar);
用于在组合框控件的编辑框中选择字符。nStartChar参数指定起始位置,nEndChar参数指定终止位置。

DWORD_PTRGetItemData(int nIndex) const;
获取组合框中指定项所关联的32位数据。nIndex参数指定组合框控件的列表框某项的索引(从0开始)。

int SetItemData(intnIndex,DWORD_PTR dwItemData);
为某个指定的组合框列表项设置一个关联的32位数。nIndex参数指定要进行设置的列表项索引。dwItemData参数指定要关联的新值。

void GetLBText(intnIndex,CString& rString) const;
从组合框控件的列表框中获取某项的字符串。nIndex参数指定要获取字符串的列表项的索引,CString参数用于接收取到的字符串。

int GetLBTextLen(int nIndex) const;
获取组合框控件的列表框中某项的字符串长度。nIndex参数指定要获取字符串长度的列表项的索引。  

int GetTopIndex( )const;
获取组合框控件的列表框中第一个可见项的索引。

int SetTopIndex(intnIndex);
将组合框控件的列表框中某个指定项设置为可见的。nIndex参数指定了该列表项的索引。该函数成功则返回0,有错误发生则返回CB_ERR

BOOL LimitText(intnMaxChars);
用于限制用户在组合框控件的编辑框中能够输入的最大字节长度。nMaxChars参数指定了用户能够输入文字的最大字节长度,如果为0则长度被限制为65535个字节。

int AddString(LPCTSTR lpszString);
为组合框控件中的列表框添加新的列表项。lpszString参数是指向要添加的字符串的指针。该函数的返回值如果大于等于0,那么它就是新列表项的索引,而如果有错误发生则会返回CB_ERR,如果没有足够的内存存放新字符串则返回CB_ERRSPACE

int DeleteString(UINT nIndex);
删除组合框中某指定位置的列表项。nIndex参数指定了要删除的列表项的索引。该函数的返回值如果大于等于0,那么它就是组合框中剩余列表项的数量。如果nIndex指定的索引超出了列表项的数量则返回CB_ERR

int FindString(intnStartAfter,LPCTSTR lpszString) const;
在组合框控件的列表框中查找但不选中第一个包含指定前缀的列表项。nStartAfter参数指定了第一个要查找的列表项之前的那个列表项的索引。lpszString指向包含要查找的前缀的字符串。该函数的返回值如果大于等于0,那么它是匹配列表项的索引,如果查找失败则返回CB_ERR

int InsertString(int nIndex,LPCTSTR lpszString);
向组合框控件的列表框中插入一个列表项。nIndex参数指定了要插入列表项的位置,lpszString参数则指定了要插入的字符串。该函数返回字符串被插入的位置,如果有错误发生则会返回CB_ERR,如果没有足够的内存存放新字符串则返回CB_ERRSPACE

int SelectString(int nStartAfter,LPCTSTR lpszString);
在组合框控件的列表框中查找一个字符串,如果查找到则选中它,并将其显示到编辑框中。参数同FindString。如果字符串被查找到则返回此列表项的索引,如果查找失败则返回CB_ERR,并且当前选择项不改变


滚动条控件(Scroll Bar)

分为:水平滚动条(Horizontal)和垂直滚动条(Vertical Scroll Bar)

从滚动条的创建形式来分,有标准滚动条和滚动条控件两种。像列表框和组合框设置了WS_HSCROLLWS_VSCROLL风格以后出现的滚动条,不是一个独立的窗口,而是这些窗口的一部分,这就是标准滚动条。而滚动条控件是一个独立的窗口,它可以获得焦点,响应某些操作。

CScrollBar成员函数:

BOOL GetScrollInfo(LPSCROLLINFO lpScrollInfo, UINT nMask =SIF_ALL);

获取的滚动条的参数信息,该信息为SCROLLINFO结构体的形式。参数lpScrollInfo为指向SCROLLINFO结构体变量的指针。

<span style="font-size:18px;">	typedef struct tagSCROLLINFO {    
	    UINT cbSize;         // 结构的尺寸(字节为单位)   
	    UINT fMask;          // 说明结构中的哪些参数是有效的,可以是屏蔽值的组合,如SIF_POS|SIF_PAGE,若为SIF_ALL则整个结构都有效   
	    int  nMin;           // 滚动范围最小值,当fMask 中包含SIF_RANGE 时有效   
	    int  nMax;           // 滚动范围最大值,当fMask 中包含SIF_RANGE 时有效   
	    UINT nPage;          // 页尺寸,用来确定比例滚动框的大小,当fMask中包含SIF_PAGE时有效   
	    int  nPos;           // 滚动框的位置,当fMask 中包含SIF_POS 有效   
	    int  nTrackPos;      // 滚动时滚动框的位置,当fMask 中包含SIF_TRACKPOS 时有效,该参数只能查询,不能设置,最好不要用该参数来查询拖动时滚                                  //动框的位置   
	}   SCROLLINFO, *LPSCROLLINFO;    
	typedef SCROLLINFO CONST *LPCSCROLLINFO;
</span>

 BOOLSetScrollInfo(LPSCROLLINFO lpScrollInfo, BOOL bRedraw = TRUE);

用于设置滚动条的各种参数信息。参数lpScrollInfo为指向SCROLLINFO结构体变量的指针,参数bRedraw表示是否需要重绘滚动条,如果为TRUE,则重绘。该函数操作成功则返回TRUE,否则返回FALSE

int GetScrollPos( )const;

获取滚动块的当前位置。如果失败则返回0

int SetScrollPos(int nPos, BOOL bRedraw = TRUE);

将滚动块移动到指定位置。参数nPos指定了滚动块的新位置,参数bRedraw表示是否需要重绘滚动条,如果为TRUE,则重绘。函数返回滚动框原来的位置,若操作失败则返回0

void GetScrollRange(LPINT lpMinPos, LPINT lpMaxPos) const;

获取滚动条的滚动范围。参数lpMinPos指向滚动条滚动范围的最小值,参数lpMaxPos指向滚动条滚动范围的最大值。

void SetScrollRange(int nMinPos, int nMaxPos, BOOL bRedraw = TRUE);

用于指定滚动条的滚动范围。参数nMinPosnMaxPos分别指定了滚动范围的最小值和最大值,两者的差不得超过32767。当两者都为0时,滚动条将被隐藏。参数bRedraw表示是否需要重绘滚动条,如果为TRUE,则重绘。

OnHScroll()与OnVScroll()函数

无论是标准滚动条,还是滚动条控件,滚动条的通知消息都是用WM_HSCROLL 和WM_VSCROLL消息发送出去的。对这两个消息的默认处理函数是CWnd::OnHScroll和CWnd::OnVScroll,一般需要在派生类中对这两个函数进行重载,以实现滚动功能。也就是说,假设在一个对话框中放入了一个水平滚动条,我们可以在对话框类中重载OnHScroll函数,并在OnHScroll函数中实现滚动功能。

这两个函数的声明如下:

       afx_msg void OnHScroll(UINTnSBCode,UINT nPos,CScrollBar* pScrollBar);
       afx_msg void OnVScroll(UINT nSBCode,UINTnPos,CScrollBar* pScrollBar);

参数nSBCode是通知消息码,主要通知码及含义的介绍下面已列出。nPos是滚动框的位置,只有在nSBCodeSB_THUMBPOSITIONSB_THUMBTRACK时,该参数才有意义。如果通知消息是滚动条控件发来的,那么pScrollBar是指向该控件的指针,如果是标准滚动条发来的,则pScrollBarNULL

       SB_BOTTOM/SB_RIGHT:滚动到底端(右端)
       SB_TOP/SB_LEFT
:滚动到顶端(左端)
       SB_LINEDOWN/SB_LINERIGHT
:向下(向右)滚动一行(列)
       SB_LINEUP/SB_LINELEFT
:向上(向左)滚动一行(列)
       SB_PAGEDOWN/SB_PAGERIGHT
:向下(向右)滚动一页
       SB_PAGEUP/SB_PAGELEFT
:向上(向左)滚动一页
       SB_THUMBPOSITION
:滚动到指定位置
       SB_THUMBTRACK
:滚动框被拖动。可利用该消息来跟踪对滚动框的拖动
       SB_ENDSCROLL
:滚动结束

注:SB_PAGEUP和SB_PAGEDOWN就表示上一页和下一页了所以要计算出一页有多少行,用cyClient/cyChar来计算一页中有多少行(即客户区纵向尺寸与字符高度的比值)。


图片控件(Picture Control)

分为:图片控件静态和动态加载图片

静态:

图片控件属性中Type属性,有8中类型:

Frame:显示一个无填充的矩形框,边框颜色可以通过Color属性的下拉列表设定

Etched Horz:显示一条横分割线

Etched Vert:显示一条竖分割线

Rectangle:显示一个填充的矩形框,矩形颜色可通过Color属性的下拉列表设定

Icon:显示一个图标(Icon),图标通过Image下拉列表来设置图标资源ID

Bitmap:显示一个位图(Bitmap),位图通过Image下拉列表来设置位图资源ID

Enhanced Metafile:显示一个加强的元数据文件(Metafile

Owner Draw:自绘


动态:

<span style="font-size:18px;">	void OnBnClickedLoadPicButton()   
	{   
	    // TODO: Add your control notification handler code here   
	    CBitmap bitmap;  // CBitmap对象,用于加载位图   
	    HBITMAP hBmp;    // 保存CBitmap加载的位图的句柄   
	  
	    bitmap.LoadBitmap(IDB_BITMAP1);  // 将位图IDB_BITMAP1加载到bitmap   
	    hBmp = (HBITMAP)bitmap.GetSafeHandle();  // 获取bitmap加载位图的句柄   
	    m_Picture.SetBitmap(hBmp);    // 设置图片控件m_jzmPicture的位图图片为IDB_BITMAP1   
	}  
</span>


列表视图控件(List Control)

列表视图控件的列表项一般有图标(Icon)和标签(Label)两部分。

列表视图控件有4种风格:IconSmallIconListReport

特点如下:

Icon大图标风格:列表项的图标通常为32×32像素,在图标的下面显示标签。

Small Icon小图标风格:列表项的图标通常为16×16像素,在图标的右面显示标签。

List列表风格:与小图标风格类似,图标和文字的对齐方式不同。

Report报表风格:列表视图控件可以包含一个列表头来描述各列的含义。每行显示一个列表项,通常可以包含多个列表子项。最左边的列表子项的标签左边可以添加一个图标,而它右边的所有子项则只能显示文字。这种风格的列表视图控件很适合做各种报表。

可以参考window资源管理器中的视图模式。

NMHDR structure:消息通知信息的结构体

<span style="font-size:18px;">	typedef struct tagNMHDR {   
	    HWND hwndFrom;     // 控件窗口的句柄   
	     UINT_PTR idFrom;   // 控件ID   
	    UINT code;         // 控件的通知消息码   
	} NMHDR;  
</span>


NMITEMACTIVATE structure:

<span style="font-size:18px;">	typedef struct tagNMITEMACTIVATE {   
	    NMHDR hdr;   
	    int iItem;   
	    int iSubItem;   
	    UINT uNewState;   
	    UINT uOldState;   
	    UINT uChanged;   
	    POINT ptAction;   
	    LPARAM lParam;   
	    UINT uKeyFlags;   
	} NMITEMACTIVATE, *LPNMITEMACTIVATE;  
</span>

LVITEM structure:包含列表项或列表子项的各种属性

<span style="font-size:18px;">	typedef struct _LVITEM {    
	    UINT mask;           // 掩码位的组合(下面有对应掩码的元素都已在括号中标出掩码),表明哪些元素是有效的   
	    int iItem;           // 列表项的索引   
	    int iSubItem;        // 列表子项的索引   
	    UINT state;          // 状态,下面会列出。(LVIF_STATE)   
	    UINT stateMask;      // 状态掩码,用来说明要获取或设置哪些状态。下面会列出   
	    LPTSTR pszText;      // 指向列表项或列表子项的标签字符串。(LVIF_TEXT)   
	    int cchTextMax;      // pszText指向缓冲区的字符的个数,包括字符串结束符。(LVIF_TEXT)   
	    int iImage;          // 图标的索引。(LVIF_IMAGE)   
	    LPARAM lParam;       // 32位的附加数据。(LVIF_PARAM)   
	#if (_WIN32_IE >= 0x0300)   
	    int iIndent;   
	#endif   
	#if (_WIN32_WINNT >= 0x501)   
	    int iGroupId;   
	    UINT cColumns; // tile view columns   
	    PUINT puColumns;   
	#endif   
	#if (_WIN32_WINNT >= 0x0600)   
	    int* piColFmt;   
	    int iGroup;   
	#endif   
	} LVITEM, *LPLVITEM; 
</span>

下面是statestateMask的取值及含义:

        状态                    对应的状态掩码                 含义
       LVIS_CUT                    
同左                列表项或列表子项被选择用来进行剪切和粘贴操作
        LVIS_DROPHILITED     
同左                 列表项或列表子项成为拖动操作的目标
        LVIS_FOCUSED           
同左                列表项或列表子项具有输入焦点
       LVIS_SELECTED          
同左                列表项或列表子项被选中


LVCOLUMN structure:

该结构体仅适用于Report报表式列表视图控件。在向列表控件中插入一列时需要用到此结构体。

<span style="font-size:18px;">	typedef struct _LVCOLUMN {    
	    UINT mask;              // 掩码位的组合(下面有对应掩码的元素都已在括号中标出掩码),表明哪些元素是有效的   
	    int fmt;                    // 该列的表头和列表子项的标签正文显示格式,可以是LVCFMT_CENTER、LVCFMT_LEFT或LVCFMT_RIGHT。(LVCF_FMT)   
	    int cx;                     // 以像素为单位的列的宽度。(LVCF_FMT)   
	    LPTSTR pszText;    // 指向列表头标题正文的字符串。(LVCF_TEXT)   
	    int cchTextMax;     // pszText指向缓冲区的字符的个数,包括字符串结束符。(LVCF_TEXT)   
	    int iSubItem;          // 该列的索引。(LVCF_SUBITEM)   
	#if (_WIN32_IE >= 0x0300)   
	    int iImage;   
	    int iOrder;   
	#endif   
	#if (_WIN32_WINNT >= 0x0600)   
	    int cxMin;   
	    int cxDefault;   
	    int cxIdeal;   
	#endif   
	} LVCOLUMN, *LPLVCOLUMN;  
</span>

NMLISTVIEW structure: 该结构体存放了列表视图控件通知消息的相关信息。

<span style="font-size:18px;">	typedef struct tagNMLISTVIEW {   
	    NMHDR hdr;       // 标准的NMHDR 结构   
	     int iItem;       // 列表项的索引       可以看成行
	     int iSubItem;    // 列表子项的索引     可以看成列
	     UINT uNewState;  // 列表项或列表子项的新状态   
	     UINT uOldState;  // 列表项或列表子项原来的状态   
	     UINT uChanged;   // 取值与LVITEM的mask成员相同,用来表明哪些状态发生了变化   
	     POINT ptAction;  // 事件发生时鼠标的客户区坐标   
	     LPARAM lParam;   //32位的附加数据   
	} NMLISTVIEW, *LPNMLISTVIEW;  
</span>

CListCtrl类的成员函数:

 UINT GetSelectedCount( ) const;

 该函数返回列表视图控件中被选择列表项的数量。

POSITION GetFirstSelectedItemPosition( ) const;

获取列表视图控件中第一个被选择项的位置。返回的POSITION值可以用来迭代来获取其他选择项,可以当作参数传入下面的GetNextSelectedItem函数来获得选择项的索引。如果没有被选择项则返回NULL

int GetNextSelectedItem(POSITION& pos) const;

该函数获取由pos指定的列表项的索引,然后将pos设置为下一个位置的POSITION值。参数pos为之前调用GetNextSelectedItemGetFirstSelectedItemPosition得到的POSITION值的引用。返回值就是pos指定列表项的索引。

int GetItemCount( )const;

获取列表视图控件中列表项的数量。

int InsertColumn(int nCol,const LVCOLUMN* pColumn );
int InsertColumn(int nCol,LPCTSTRlpszColumnHeading,int nFormat = LVCFMT_LEFT,int nWidth = -1,int nSubItem = -1);

这两个函数用于在报表式列表视图控件中插入列。第一个函数中,nCol参数为插入列的索引,pColumn参数指向LVCOLUMN结构,其中包含了插入列的属性。第二个函数中,nCol参数也是插入列的索引,lpszColumnHeading参数为列标题字符串,nFormat参数为列中文本的对齐方式,可以是LVCFMT_LEFTLVCFMT_RIGHTLVCFMT_CENTERnWidth参数为列宽,nSubItem为插入列对应列表子项的索引。两个函数在成功时都返回新列的索引,失败都返回-1

BOOL DeleteColumn(int nCol);

该函数用于删除列表视图控件中的某列。参数nCol为删除列的索引。删除成功则返回TRUE,失败返回FALSE

int InsertItem(intnItem,LPCTSTR lpszItem);

向列表视图控件中插入新的列表项。参数nItem为要插入项的索引,参数lpszItem为要插入项的标签字符串。如果插入成功则返回新列表项的索引,否则返回-1

BOOL DeleteItem(intnItem);

从列表视图控件中删除某个列表项。参数nItem指定了要删除的列表项的索引。删除成功则返回TRUE,否则返回FALSE

CString GetItemText(int nItem,int nSubItem) const;

获取指定列表项或列表子项的显示文本。参数nItem指定了列表项的索引,参数nSubItem指定了列表子项的索引。 

BOOL SetItemText(int nItem,int nSubItem,LPCTSTR lpszText);

设置指定列表项或列表子项的显示文本。参数nItemnSubItemGetItemText。参数lpszText为要设置的显示文本字符串。如果设置成功则返回TRUE,否则返回FALSE

DWORD_PTR GetItemData(int nItem) const;

该函数用于获取指定列表项的附加32位数据。参数nItem为列表项的索引。返回值就是由nItem指定列表项的附加32位数据。

BOOLSetItemData(int nItem,DWORD_PTR dwData);

该函数用于为指定列表项设置附加32位是数据。参数nItem为列表项的索引,参数dwData为列表项的附加32位数据。


树形控件(Tree Control)

树形控件特有的通知消息中比较常用几个:

TVN_SELCHANGINGTVN_SELCHANGED:在用户改变了对树节点的选择时,控件会发送这两个消息。消息会附带一个指向NMTREEVIEW结构的指针,程序可从该结构中获得必要的信息。两个消息都会在该结构的itemOld成员中包含原来的选择项信息,在itemNew成员中包含新选择项的信息,在action成员中表明是用户的什么行为触发了该通知消息(若是TVC_BYKEYBOARD则表明是键盘,若是TVC_BYMOUSE则表明是鼠标,若是TVC_UNKNOWN则表示未知)。两个消息的不同之处在于,如果TVN_SELCHANGING的消息处理函数返回TRUE,那么就阻止选择的改变,如果返回FALSE,则允许改变。

TVN_KEYDOWN:该消息表明了一个键盘事件。消息会附带一个指向NMTVKEYDOWN结构的指针,通过该结构程序可以获得按键的信息。

TVN_BEGINLABELEDITTVN_ENDLABELEDIT:分别在用户开始编辑和结束编辑节点的标签时发送。消息会附带一个指向NMTVDISPINFO结构的指针,程序可从该结构中获得必要的信息。在前者的消息处理函数中,可以调用GetEditControl()成员函数返回一个指向用于编辑标题的编辑框的指针。如果处理函数返回FALSE,则允许编辑,如果返回TRUE,则禁止编辑。在后者的消息处理函数中,NMTVDISPINFO结构中的item.pszText指向编辑后的新标题,如果pszTextNULL,那么说明用户放弃了编辑,否则,程序应负责更新节点的标签,这可以由SetItem()SetItemText()函数来完成。

树形控件的相关数据结构

HTREEITEM句柄:树形控件中的每个节点都可以由一个HTREEITEM类型的句柄表示。我们通过CTreeCtrl类的成员函数对树进行访问和操作时,很多时候都要用到HTREEITEM句柄。

TVITEM结构体:

<span style="font-size:18px;">	typedef struct tagTVITEM {   
	    UINT mask;       // 包含一些掩码位(下面的括号中列出)的组合,用来表明结构的哪些成员是有效的   
	    HTREEITEM hItem; // 树节点的句柄(TVIF_HANDLE)   
	    UINT state;      // 树节点的状态(TVIF_STATE)   
	    UINT stateMask;  // 状态的掩码组合(TVIF_STATE)   
	    LPTSTR pszText;  // 树节点的标签文本(TVIF_TEXT)   
	    int cchTextMax;  // 标签文本缓冲区的大小(TVIF_TEXT)   
	    int iImage;      // 树节点的图像索引(TVIF_IMAGE)   
	    int iSelectedImage;  // 选中项的图像索引(TVIF_SELECTEDIMAGE)   
	    int cChildren;   // 表明节点是否有子节点,为1则有,为0则没有(TVIF_CHILDREN)   
	    LPARAM lParam;   // 一个32 位的附加数据(TVIF_PARAM)   
	} TVITEM, *LPTVITEM; 
</span>

树形控件节点需要显示图标时,就要为树形控件关联一个图像序列,上面的iImage成员就代表了该结构体对应的树节点的图标在图像序列中的索引,iSelectedImage则代表该树节点被选中时显示的图标在图像序列中的索引。

stateMask用来说明要获取或设置树节点的哪些状态。下面是statestateMask的一些常用值及含义:

         state                           对应的stateMask                      含义         
      TVIS_CUT                         TVIS_CUT                       
节点被选择用来进行剪切和粘贴操作
      TVIS_DROPHILITED          TVIS_DROPHILITED        
节点成为拖动操作的目标
      TVIS_EXPANDED               TVIS_EXPANDED             
节点的子节点被展开
      TVIS_EXPANDEDONCE     TVIS_EXPANDEDONCE    
节点的子节点曾经被展开过
      TVIS_SELECTED               TVIS_SELECTED              
节点被选中

IParam在实际开发中常用来存放与树节点有关的附加数据。


NMTREEVIEW结构体:

<span style="font-size:18px;">	typedef struct tagNMTREEVIEW {   
	    NMHDR hdr;      // 标准的NMHDR结构   
	    UINT action;    // 表明是用户的什么行为触发了该通知消息   
	    TVITEM itemOld; // 原节点的属性   
	    TVITEM itemNew; // 新节点的属性   
	    POINT ptDrag;   // 事件发生时鼠标的客户区坐标   
	} NMTREEVIEW, *LPNMTREEVIEW;  
</span>


TVINSERTSTRUCT结构体:

<span style="font-size:18px;">	typedef struct tagTVINSERTSTRUCT {   
	    HTREEITEM hParent;      // 父节点的句柄   
	    HTREEITEM hInsertAfter; // 指明插入到同层中哪一项的后面   
	#if (_WIN32_IE >= 0x0400)   
	    union  
	    {   
	        TVITEMEX itemex;   
	        TVITEM item;   
	    } DUMMYUNIONNAME;   
	#else   
	    TVITEM item;            // 要添加的新节点的属性   
	#endif   
	} TVINSERTSTRUCT, *LPTVINSERTSTRUCT;  
</span>
hParent成员为TVI_ROOTNULL,那么新节点将被作为树的根节点插入。hInsertAfter除了可以是某个节点的句柄,还可以有四种取值:TVI_FIRST(插入到树形控件的最前面)、TVI_LAST(插入到树形控件的最后面)、TVI_ROOT(作为根节点插入)和TVI_SORT(按字母顺序插入)。


NMTVDISPINFO结构体:

NMTVDISPINFO结构体中包含了与树节点的显示有关的信息。

<span style="font-size:18px;">	typedef struct tagNMTVDISPINFO {   
	    NMHDR hdr;   
	    TVITEM item;   
	} NMTVDISPINFO, *LPNMTVDISPINFO;  
</span>


CTreeCtrl类的成员函数:

CImageList* SetImageList(CImageList * pImageList,intnImageListType);

如果树节点需要显示图标时,则必须先创建一个CImageList类的对象,并为其添加多个图像组成一个图像序列,然后调用SetImageList函数为树形控件设置图像序列,在用InsertItem插入节点时传入所需图像在图像序列中的索引即可。参数pImageList为指向图像序列类CImageList的对象的指针,若为NULL则删除树形控件的所有图像。参数nImageListType指定图像序列的类型,可以是TVSIL_NORMAL(普通图像序列)或TVSIL_STATE(状态图像序列,用图像表示节点的状态)。

UINT GetCount( )const;

获取树形控件中节点的数量。

DWORD_PTR GetItemData(HTREEITEM hItem) const;

获取树形控件中某个指定节点的附加32位数据。参数hItem为指定的树节点的句柄。

BOOL SetItemData(HTREEITEM hItem,DWORD_PTR dwData);

为树形控件中某个指定节点设置附加的32位数据。参数hItem同上,dwData为要设置的32位数据。

CString GetItemText(HTREEITEM hItem) const;

获取树形控件中某个指定节点的标签文本。参数hItem同上。返回值是包含标签文本的字符串。

BOOL SetItemText(HTREEITEM hItem,LPCTSTR lpszItem);

为树形控件中某个指定节点设置标签文本。参数hItem同上,lpszItem为包含标签文本的字符串的指针。

HTREEITEM GetNextSiblingItem(HTREEITEM hItem) const;

获取树形控件中某个指定节点的下一个兄弟节点。参数hItem同上。返回值是下一个兄弟节点的句柄。

HTREEITEM GetPrevSiblingItem(HTREEITEM hItem) const;

获取树形控件中某个指定节点的上一个兄弟节点。参数hItem同上。返回值是上一个兄弟节点的句柄。

HTREEITEM GetParentItem(HTREEITEM hItem) const;

获取树形控件中某个指定节点的父节点。参数hItem同上。返回值是父节点的句柄。

HTREEITEM GetRootItem( ) const;

获取树形控件根节点的句柄。

HTREEITEM GetSelectedItem( ) const;

获取树形控件当前选中节点的句柄。

BOOL DeleteAllItems( );

删除树形控件中的所有节点。删除成功则返回TRUE,否则返回FALSE

BOOL DeleteItem(HTREEITEM hItem);

删除树形控件中的某个节点。参数hItem为要删除的节点的句柄。删除成功则返回TRUE,否则返回FALSE。

HTREEITEM InsertItem(LPCTSTRlpszItem,int nImage,int nSelectedImage,HTREEITEM hParent = TVI_ROOT,HTREEITEMhInsertAfter = TVI_LAST);

在树形控件中插入一个新节点。参数lpszItem为新节点的标签文本字符串的指针,参数nImage为新节点的图标在树形控件图像序列中的索引,参数nSelectedImage为新节点被选中时的图标在图像序列中的索引,参数hParent为插入节点的父节点的句柄,参数hInsertAfter为新节点的前一个节点的句柄,即新节点将被插入到hInsertAfter节点之后。

BOOLSelectItem(HTREEITEM hItem);

选中指定的树节点。参数hItem为要选择的节点的句柄。若成功则返回TRUE,否则返回FALSE

标签控件(Tab Control)

标签控件相当于是一个页面的容器,可以容纳多个对话框,而且一般也只容纳对话框,所以我们不能直接在标签控件上添加其他控件,必须先将其他控件放到对话框中,再将对话框添加到标签控件中。最终我们点击标签切换页面时,切换的不是控件的组合,而是对话框。

标签控件的通知消息

       TCN_SELCHANGE:通知父窗口控件的标签选择项已经改变
       TCN_SELCHANGING
通知父窗口控件的标签选择项正在改变
       TCN_KEYDOWN
:通知父窗口在控件范围内键盘被按下
       TCN_GETOBJECT
:具有TCS_EX_REGISTERDROP扩展特性并且对象被拖动时的通知消息
       TCN_FOCUSCHANGE
:通知父窗口控件的按钮聚焦已经改变
       NM_CLICK
:通知父窗口用户在控件区域范围内点击了鼠标左键
       NM_RCLICK
:通知父窗口用户在控件区域范围内点击了鼠标右键
       NM_RELEASEDCAPTURE
:通知父窗口在控件区域范围内释放鼠标捕获消息


标签控件的相关结构体:

TCITEMHEADER结构体: 该结构体用来指定或获取标签控件本身的属性。用在TCM_INSERTITEMTCM_GETITEMTCM_SETITEM消息中。

<span style="font-size:18px;">	typedef struct tagTCITEMHEADER {      
	    UINT mask;   // 掩码,可以为TCIF_IMAGE(iImage成员有效)、TCIF_RTLREADING、TCIF_TEXT(pszText成员有效)   
	    UINT lpReserved1;   // 预留   
	    UINT lpReserved2;   // 预留   
	    LPTSTR pszText;     // 标签文本字符串   
	    int cchTextMax;      
	    int iImage;         // 图标在标签控件图像序列中的索引   
	} TCITEMHEADER, *LPTCITEMHEADER;   
</span>

TCITEM结构体: 该结构体用来指定或获取标签页的属性。用在TCM_INSERTITEMTCM_GETITEMTCM_SETITEM消息中。

<span style="font-size:18px;">	typedef struct tagTCITEM {     
	    UINT mask;  // 掩码,可以是TCIF_IMAGE(iImage成员有效)、TCIF_PARAM(lParam成员有效)、TCIF_RTLREADING、TCIF_STATE、TCIF_TEXT(pszText成员有效)   
	#if (_WIN32_IE >= 0x0300)   
	    DWORD dwState;   
	    DWORD dwStateMask;   
	#else   
	    UINT lpReserved1;   
	    UINT lpReserved2;   
	#endif   
	    LPTSTR pszText;   
	    int cchTextMax;   
	    int iImage;   
	    LPARAM lParam;     // 与标签页关联的32位数据   
	} TCITEM, *LPTCITEM;  
</span>

TCHITTESTINFO结构体: 结构体包含了鼠标单击测试的信息.

<span style="font-size:18px;">	typedef struct tagTCHITTESTINFO {   
	    POINT pt;  // 鼠标点击测试的客户区坐标   
	    UINT flags; // 接收点击测试的结果。有以下几种:TCHT_NOWHERE(坐标点不在标签上)、TCHT_ONITEM(坐标点在标签上但不在标签文本或图标上)、TCHT_ONITEMICON(坐标点在标签图标上)、TCHT_ONITEMLABEL(坐标点在标签文本上)   
	} TCHITTESTINFO, *LPTCHITTESTINFO;  
</span>

NMTCKEYDOWN结构体: 结构体包含了标签控件中键盘按下的相关信息.

<span style="font-size:18px;">	typedef struct tagNMTCKEYDOWN {   
	    NMHDR hdr;   
	    WORD wVKey;   
	    UINT flags;   
	} NMTCKEYDOWN;
</span>

CTabCtrl类成员函数:

int GetCurSel( ) const;

获取标签控件中当前选择标签的索引。如果成功则返回选择标签的索引,否则返回-1

BOOL GetItem(intnItem,TCITEM* pTabCtrlItem) const;

获取标签控件中某个标签的信息。参数nItem为标签索引,pTabCtrlItem为指向TCITEM结构体的指针,用来接收标签信息。若获取成功返回TRUE,否则返回FALSE

int GetItemCount( )const;

获取标签控件中标签的数量。

int SetCurSel(intnItem);

在标签控件中选择某标签。参数nItem为要选择的标签的索引。如果成功则返回之前选择标签的索引,否则返回-1

BOOL SetItem(intnItem,TCITEM* pTabCtrlItem);

设置某标签的所有或部分属性。参数nItem为标签的索引,pTabCtrlItem为指向TCITEM结构体的指针,包含了新的标签属性。成功则返回TRUE,否则返回FALSE

BOOL DeleteAllItems( );

删除标签控件中所有标签。

BOOL DeleteItem(intnItem);

删除标签控件中的某个标签。参数nItem为要删除标签的索引。

LONG InsertItem(intnItem,LPCTSTR lpszItem);

在标签控件中插入新的标签。参数nItem为新标签的索引,lpszItem为标签文本字符串。如果插入成功则返回新标签的索引,否则返回-1



MFC获取各种指针的放法

1、获取应用程序指针
  CMyApp* pApp=(CMyApp*)AfxGetApp();

2、获取主框架指针
  CWinApp 中的公有成员变量 m_pMainWnd 就是主框架的指针
  CMainFrame* pMainFrame = (CMainFrame*)(AfxGetApp()->m_pMainWnd);
  或者
  CMainFrame* pMainFrame = (CMainFrame*)AfxGetMainWnd();

3、获取菜单指针
  CMenu* pMenu = AfxGetMainWnd()->GetMenu();

4、获取工具栏、状态栏指针
  主框架中可以直接使用m_wndToolBar、m_wndStatusBar
  其他:
  CToolBar* pToolBar = (CToolBar*)AfxGetMainWnd()->GetDescendantWindow(AFX_IDW_TOOLBAR);
  CStatusBar* pStatusBar = (CStatusBar*)AfxGetMainWnd()->GetDescendantWindow(AFX_IDW_STATUS_BAR);

5、获取控件指针
  先用 GetDlgItem() 再转换,如:
  CButton* pButton = (CButton*)GetDlgItem(IDC_MYBUTTON);

6、获取文档、视图指针

SDI:
CMainFrame* pMainFrame = (CMainFrame*)AfxGetMainWnd();
CYourDoc* pDoc = (CYourDoc*)pMainFrame->GetActiveDocument();
CYourView* pView = (CYourView*)pMainFrame->GetActiveView();

MDI:
CMainFrame* pMainFrame = (CMainFrame*)AfxGetMainWnd();
CChildFrame* pChildFrame = (CChildFrame*)pMainFrame->GetActiveFrame();
CYourDoc* pDoc = (CYourDoc*)pChildFrame->GetActiveDocument();
CYourView* pView = (CYourView*)pChildFrame->GetActiveView();

7、文档、视图

从视图获取文档指针:
CYourDoc* pDoc = GetDocument();

从文档获取视图指针:
利用成员函数 GetFirstViewPosition() 和 GetNextView() 遍历
virtual POSITION GetFirstViewPosition() const;
virtual CView* GetNextView(POSITION& rPosition) const;

SDI:
CYourView* pView;
POSITION pos = GetFirstViewPosition();
pView = GetNextView(pos);

MDI:
定义函数
CView* CYourDoc::GetView(CRuntimeClass* pClass)
{
CView* pView;
POSITION pos=GetFirstViewPosition();
while(pos!=NULL)
{
pView=GetNextView(pos);
if(!pView->IsKindOf(pClass))
break;
}
if(!pView->IsKindOf(pClass))
{
AfxMessageBox("Connt Locate the View.");
return NULL;
}
return pView;
}
使用如下:
CYourView* pView=(CYourView*)GetView(RUNTIME_CLASS(CYourView));

8、文档模版、文档

从文档获取文档模版指针:
CDocTemplate* GetDocTemplate() const;

从文档模版获取文档指针:
viaual POSITION GetFirstDocPosition( ) const = 0;
visual CDocument* GetNextDoc(POSITION & rPos) const = 0;

9、获取分割视图中各个视图的指针

主框架中定义:CSplitterWnd m_wndSplitter;

定义两个View类:CView1、CView2

框架类中重载:
BOOL CMainFrame::OnCreateClient(LPCREATESTRUCT, CCreateContext* pContext)
{
VERIFY(m_splitter.CreateStatic(this,2,1)); //分割成两行一列
VERIFY(m_splitter.CreateView(0,0,RUNTIME_CLASS(CView1),CSize(100,100),pContext));
VERIFY(m_splitter.CreateView(1,0,RUNTIME_CLASS(CView2),CSize(100,100),pContext));
return TRUE;
}

获取分割视图指针
CView1* pView1 = (CView1*)m_wndSplitter.GetPane(0,0);
CView2* pView2 = (CView2*)m_wndSplitter.GetPane(1,0);

10、通过鼠标获得子窗口指针

CWnd* ChildWindowFromPoint(POINT point) const;
CWnd* ChildWindowFromPoint(POINT point,UINT nFlags) const;
用于确定包含指定点的子窗口
如果指定点在客户区之外,函数返回NULL;
如果指定点在客户区内,但是不属于任何一个子窗口,函数返回该CWnd的指针;
如果有多个子窗口包含指定点,则返回第一个子窗口的指针。
还要注意的是,该函数返回的是一个伪窗口指针,不能将它保存起来供以后使用。
对于第二个参数nFlags有几个含义:
CWP_ALL file://不忽略任何子窗口
CWP_SKIPNIVSIBLE file://忽略不可见子窗口
CWP_SKIPDISABLED file://忽略禁止的子窗口
CWP_SKIPRANSPARENT file://忽略透明子窗口

附注:获得窗口句柄三种方法

1.HWND FindWindow(LPCTSTR lpClassName, LPCTSTR lpWindowName)

HWND FindWindowEx(HWND hwndParent, HWND hwndChildAfter,LPCTSTR lpClassName, LPCTSTR lpWindowName)

2.HWND WindowFromPoint(POINT& Point)//获得当前鼠标光标位置的窗口HWND

3.BOOL CALLBACK EnumChildProc(HWND hwnd,LPARAM lParam)

BOOL CALLBACK EnumChildWindows(HWND hWndParent, WNDENUMPROC lpEnumFunc,LPARAM lParam) 
BOOL CALLBACK EnumWindows(WNDENUMPROC lpEnumFunc, LPARAM lParam) 
BOOL CALLBACK EnumWindowsProc(HWND hwnd, LPARAM lParam)

指针 句柄之间的转换

a.由指针获得句柄 
CWnd * pWnd; 
CWnd HWnd; 
HWnd = pWnd->GetSafeHWnd();

b.由句柄得到指针:
CWnd* pWnd=FromeHandle(hMyHandle); 
pWnd->SetWindowText("Hello World!"); 
or CWnd* pWnd; pWnd->Attach(hMyHandle);

MFC类中有的还提供了标准方法,比如Window 句柄 : 
static CWnd* PASCAL FromHandle( HWND hWnd ); 
HWND GetSafeHwnd( ) const;

对于位图: 
static CBitmap* PASCAL FromHandle( HBITMAP hBitmap ); 
static CGdiObject* PASCAL FromHandle( HGDIOBJ hObject ); 
HGDIOBJ GetSafeHandle( ) const;



详细请查看:点击打开链接









你可能感兴趣的:(MFC之控件)