g: H9 X& Z& K2 X- d3 o1 F / r3 u' S) h8 T7 J& d6 }# h" a. `7 s( L4 K" L
UINT CSampleDialog : : OnNcHitTest (Cpoint point ) + ] ?8 l9 S5 O$ r, k {. y. R# L8 M6 _, z/ [9 V9 d& O
UINT nHitTest =Cdialog: : OnNcHitTest (point ) & E9 |# H: i, L k( R+ b3 H6 z8 ] return (nHitTest = =HTCLIENT)? HTCAPTION : nHitTest! {6 p$ d$ u/ V5 g; i/ e/ d# _9 ?
}, k: L' Z# h* i
) ~/ |! i' H6 U" p, Q6 c% m, F& U 上述技术有两点不利之处, 6 \+ O/ g- A; L6 w1 g. r 其一是在窗口的客户区域双击时,窗口将极大; * h% a) c2 Y; _9 n0 s+ C- f$ ?* ^ 其二, 它不适合包含几个视窗的主框窗口。, T, ]. l0 ~) O
还有一种方法,当用户按下鼠标左键使主框窗口认为鼠标在其窗口标题上,使用ClassWizard在视窗中处理WM_LBUTTODOWN信息并向主框窗口发送一个WM_NCLBUTTONDOWN信息和一个单击测试HTCAPTION。 : c7 q) B4 B4 m" W " u% D* x* Y* g $ G! t' k, W( d! H& B/ R0 E0 L0 Y8 k, ~9 a: z
" O8 G" l- n5 ^$ G0 i4 p: s void CSampleView : : OnLButtonDown (UINT nFlags , Cpoint point & R! k) `; ?6 I2 Z. r ) ' f( z( r; ]5 ?$ P/ { {) t* Q# n. x0 D$ O X
CView : : OnLButtonDow (nFlags , pont ) C% w7 e0 H( C+ h! r
2 B3 h# T! j' A, ~/ P1 _$ |4 }# f( R4 u
//Fool frame window into thinking somene clicked % W) b- b O; y. X9 W on# C% U, A0 }( G2 P. f [
its caption bar .1 r7 X' H% K {# r3 _ C) B# i* J: Q
GetParentFrame ( ) —> PostMessage (% s9 R6 I0 C) ^8 Y9 ]& g7 T7 A
WM_NCLBUTTONDOWN ,0 Z5 p n6 k$ E$ v* C
HTCAPTION , MAKELPARAM (poitn .x , point .y) )- h0 d. h' j- y. Y
* p5 [ U9 G7 h3 S* C! e
} 3 l- t0 X! `' U& @* \+ w" T6 {5 o o( a }+ l8 O
0 o3 z# [7 `9 } i 该技术也适用于对话框和基于对的应用程序,只是不必调用 0 B0 y! J3 H* s+ a* @ ) R( M9 K& a3 i! h) V ( }, ?+ U! T* ~" \8 p7 M/ _+ I4 d1 [" q. g- |6 u' ~' d$ X) [, |* h
. S( \1 W I8 j+ e
CWnd: :GetParentFrame 。7 e' L8 S# [8 t, w3 o1 Z. J: m
void CSampleDialog : : OnLbuttonDown (UINT nFlags, Cpoint point ); ^3 k3 s6 H7 x9 j5 ~7 k3 Z
{- U# o# f, `$ V- D9 E* |% L( l! j9 p
Cdialog : : OnLButtonDow (nFlags, goint )5 H& y+ H1 F w" j0 \6 Y
//Fool dialog into thinking simeone clicked on its6 Q' m7 l. G% m# A$ T$ m* M3 R
caption bar .9 Q! {( W$ x9 R) e) R" A5 ]' S
PostMessage (WM_NCLBUTTONDOWN , HTCAPTION , MAKELPARM (point.x 9 p @2 ~: `' s4 h) l , point. y : d8 N" D4 t' A0 g2 {+ g* y ) ) - G& t6 Q4 v4 J+ ^ }2 k" g, a7 Z4 l
" g& @( y k2 `. O; }1 \
(18) 如何改变视窗的背景颜色0 U2 q4 a: V6 R
Windows向窗口发送一个WM_ERASEBKGND消息通知该窗口擦除背景,可以使用ClassWizard重载该消息的缺省处理程序来擦除背景(实际是画),并返回TRUE以防止Windows擦除窗口。; w; }- o1 I" w9 P% K8 t# U' H- M
5 ~7 p% {5 e+ U4 a# v
0 G8 i' E4 U% q$ w$ ?
& b6 j- ~( `) f3 U7 n5 Y+ O2 q2 A
//Paint area that needs to be erased.4 k+ U$ B$ G9 g
BOOL CSampleView : : OnEraseBkgnd (CDC* pDC) : a$ v# W6 s6 L { & M) e( l: E: D# W4 S // Create a pruple brush. 3 r2 ~: `( I, T ]1 k) ] CBrush Brush (RGB (128 , 0 , 128) )7 m/ w+ ^; s$ X! h% v/ z* y
3 z/ f; m$ F* s" X' y // Select the brush into the device context .6 L0 i5 F2 M8 m; l+ |# I
CBrush* pOldBrush = pDC—>SelcetObject (&brush) + U! H: F# H# } ) c2 u) M& r3 C7 s e6 U // Get the area that needs to be erased . * {+ J% D ]4 Z% k7 K. ~; Q2 G CRect reClip- S/ R' S; u4 w' m- w% T1 f7 ~9 g
pDC—>GetCilpBox (&rcClip); x2 f8 |. V1 v! }
//Paint the area. ' ^8 ? D. r. ?: P pDC—> PatBlt (rcClip.left , rcClip.top , rcClip.Width ( ) , rcClip.Height( ) , PATCOPY ) ! ?* R+ \+ B# _+ \/ x6 n $ L P& ?. C! @( ] //Unselect brush out of device context .. w# I! z r+ } H
pDC—>SelectObject (pOldBrush ) . z. w1 C8 a( R) [ / h: U; ~' J+ T) {- h* W2 u8 ~/ {4 R // Return nonzero to half fruther processing .3 ^. q# E+ ^! l4 ^
return TRUE4 I7 z& o& b1 a3 h9 O6 ^, ?
} * {, s! `3 `: g2 K- n5 K + W+ O0 _" q4 L3 O) N" w# S19) 如何改变窗口标题' k. |0 u% s, ?1 e
调用CWnd : : SetWindowText可以改变任何窗口(包括控件)的标题。9 W9 y, V( l- `* G" _7 A
8 E0 w: ?5 T8 P. u7 r# a3 o& W , L5 g$ o& Q/ P& @, k - i! t% A9 }# h' ~* Z / [& x$ B }( r //Set title for application's main frame window ." v8 ]9 T* r x
AfxGetMainWnd ( ) —> SetWindowText (_T("Application title") )% h# r! i1 a7 L' [
$ [+ f* l( @/ k& i% t% N% \0 R$ y //Set title for View's MDI child frame window . , `1 @' i( t, }3 j& K0 G GetParentFrame ( ) —> SetWindowText ("_T ("MDI Child Frame new title")8 u, J8 ]) F9 Z* V" W0 Y4 F. I4 Q
) ! j% h8 r9 f5 Z! ~0 a0 t' g& b& ]6 d' E# [
//Set title for dialog's push button control. / b5 c: h1 k) V* E/ ?# n GetDigitem (IDC_BUTTON) —> SetWindowText (_T ("Button new title ") )0 L5 @/ g: T- }: E& H# ^3 [
# V$ Z% g( F' S* _0 B* ^ & \8 I; X' X" U! M8 @5 t9 H+ Z 如果需要经常修改窗口的标题(注:控件也是窗口),应该考虑使用半文档化的函数AfxSetWindowText。该函数在AFXPRIV.H中说明,在WINUTIL.CPP中实现,在联机帮助中找不到它,它在AFXPRIV.H中半文档化, 在以后发行的MFC中将文档化。7 \1 t) [+ c4 q! u. v% `# W9 I
AfxSetWindowText的实现如下: ' Y: q, A. a" q8 G( r: i 5 L5 _ j, q$ q* a ( V/ [8 [) D' r' T6 H) L/ U2 C" n7 r, C
/ q- d. ?- u, K1 W0 u voik AFXAPI AfxSetWindowText (HWND hWndCtrl , LPCTSTR IpszNew )( f, h' F6 v% B
{ ) Q5 m5 V" @" j. L" x/ {9 |' L6 }* I itn nNewLen= Istrlen (Ipaznew) - k+ e* U& D5 W8 B/ x9 Z4 {: V. j TCHAR szOld [256] - _" o& X5 k( C1 V" `3 n //fast check to see if text really changes (reduces ( |1 c3 Q1 @# D# Q; u0 [ ` flash in the ! K; {: G8 F; y- w7 M controls ) , d0 B) }7 D* n; @2 v6 M; Y if (nNewLen >_contof (szOld) 5 @3 ~% d8 n1 a: T6 c" e- v || : : GetWindowText (hWndCrtl, szOld , _countof (szOld) !=nNewLen " @& q- V; Z6 e! y || Istrcmp (szOld , IpszNew)! = 03 l# z9 S- R' o- l; g- g
{ , n8 N- k* \, ~# ^% s y( B/ ? //change it( a5 I. H2 M* Y9 P
: : SetWindowText(hWndCtrl , IpszNew ) $ h! a3 N6 E- E8 U2 {3 N } z' @% D8 Z5 ]/ i
} Q1 S3 _4 c& w- a2 N2 y: k
) b. K* E; S' i" ~2 h
(20) 如何防止主框窗口在其说明中显示活动的文档名 2 M+ k) E; a- q8 s5 S) K+ q 创建主框窗口和MDI子窗口进通常具有FWS_ADDTOTITLE风格位,如果不希望在说明中自动添加文档名, 必须禁止该风格位, 可以使用ClassWizard重置 / ^2 y v8 H& t% F5 T- L0 | CWnd: : PreCreateWindow并关闭FWS_ADDTOTITLE风格。7 @8 h+ i* }. p* k+ E6 t5 r
! I/ m* l2 I4 A" H; G( L8 _
! j3 Q# Y* r; N- [* m : {' v8 u `8 d4 R; P! L1 z ! P. V" ]$ e) `' d BOOL CMainFrame : : PreCreateWindow (CREATESTRUCT&cs)' Z) _! L# [, v3 W, c5 z
{0 G: p" G* }6 I3 o
//Turn off FWS_ADDTOTITLE in main frame . ! v8 p0 O. F6 m4 P cs.styel & = ~FWS_ADDTOTITLE & i6 `$ C& y4 W( m) G2 ~
return CMDIFrameWnd : : PreCreateWindow (cs ) ; Y6 S; O1 `3 W }* d: F& B5 v: R5 O ?' M6 G+ p0 F
+ s1 V( |( r! i; V4 w
, ~; v& n0 N1 h# k( Q8 W, \6 e
关闭MDI子窗口的FWS _ADDTOTITLE风格将创建一个具有空标题的窗口,可以调用CWnd: : SetWindowText来设置标题。记住自己设置标题时要遵循接口风格指南。. O8 ?( ], L( K
- m& B o c- O& J
(21) 如何获取有关窗口正在处理的当前消息的信息 . w$ U/ G) @/ A9 V# Y 调用CWnd: : GetCurrentMessage可以获取一个MSG指针。例如,可以使用ClassWizard将几个菜单项处理程序映射到一个函数中,然后调用GetCurrentMessage来确定所选中的菜单项。8 M6 X/ @% p8 I, x- f; b8 q
N4 L' q; b" \3 J- [/ V) h0 x7 ?! c3 B ; G8 }; a/ ^& \0 ^ ( @- J2 q' i6 h/ h& ] 0 L8 s1 ~7 G! Y# @3 q7 X7 ~ ]5 S viod CMainFrame : : OnCommmonMenuHandler ( )7 [ v" C6 R( j6 I# ]# j
{: S+ U! l4 Q2 C$ k( a2 m+ I
//Display selected menu item in debug window . 8 w( I1 l. o& F9 L: ]& w1 k4 g) c- N TRACE ("Menu item %u was selected . /n" ,% B Q w8 a7 _. I
1 L1 y$ X- G% X7 G u. D4 {1 g7 q* T* _
//Get pointer to status bar .* c1 `0 _# J7 r. E1 b
CStatusBar * pStatusBar = (CStatusBar *) AfxGetMainWnd ( ) * q9 u/ C" Z$ G C —> GetDescendantWindow(AFX_IDW_STUTUS_BAR)# N: a7 `2 c, z2 E; `
0 c! t# D: v2 R5 [2 o
//Get pointer to toolbar .$ w/ Y" l+ u# |5 z# {
CToolBar * pToolBar = (CToolBar * ) AfxGetMainWnd ( ); i6 ~) Z- [% w) {/ R# @
—> GetDescendantWindow(AFX_IDW_TOOLBAR)3 U- i B3 c' j8 i
- K& F# ~4 d2 Q' s6 d
(23) 如何使能和禁止工具条的工具提示2 D% E8 M4 H6 }7 {: U- J4 w
如果设置了CBRS_TOOLTIPS风格位,工具条将显示工具提示,要使能或者禁止工具提示,需要设置或者清除该风格位。下例通过调用CControlBar : : GetBarStyle和CControlBar : : SetBarStyle建立一个完成此功能的成员函数: 0 D! l( M5 v5 x: Q/ K! S- j; k$ @( s4 B: r0 F
0 o: i7 U. j5 ^% Q% Z Z
) r% X1 m8 ^' Y5 X! a6 g6 b$ M- e1 |% g. K+ }. J
void CMainFrame : : EnableToolTips ( BOOL bDisplayTips ) ' K2 [7 p' ~. R. |% z! M! r {+ R- W) T& B5 [$ ^* a f
ASSERT_VALID (m_wndToolBar) $ S. L& y- \+ I2 f& J9 w& P ( [% A0 Q& X% P' z% ] V$ o DWORD dwStyle = m _wndToolBar.GetBarStyle ( )3 n: r$ p' _5 Q* q7 O+ l
1 ~8 s/ ]' @5 D, J2 G, p$ x
if (bDisplayTips) dwStyle |=CBRS_TOOLTIPS2 H, g6 h8 C- T; S% @+ A& e1 W E
( d( G) z, v( H' y* m( P# @ else9 q4 F5 Y5 t+ V8 u& k- N
dwStyle & = ~CBRS_TOOLTIPS `* H' _* q" A 1 H3 D% D" [. y( f m_wndToolBar.SetBarStyle (dwStyle ) ! U, S4 c$ j: e& z. G }; m8 a0 U. F- W( r
" b/ h$ ?7 K$ ^9 F- P! k& ?/ t8 g
(24) 如何创建一个不规则形状的窗口/ h+ o- z0 J: l( a+ Y5 }, @+ q
可以使用新的SDK函数SetWindowRgn。该函数将绘画和鼠标消息限定在窗口的一个指定的区域,实际上使窗口成为指定的不规则形状。 使用AppWizard创建一个基于对的应用程序并使用资源编辑器从主对话资源中删除所在的缺省控件、标题以及边界。2 \/ Q6 X' z' X: i& `- y
给对话类增加一个CRgn数据成员,以后要使用该数据成员建立窗口区域。" F S2 v$ x2 V* l6 Q# F
7 w. p, x/ p! v: O 7 P$ {( ~2 p V7 Q- T) _4 v7 S& n2 i4 u: Z' X
& u, s' X2 B- E! u Class CRoundDlg : public CDialog : U, e9 H4 J; t- W/ n+ e! u9 C7 k {$ ?& D# C7 e5 B6 h% j. _
… 8 S: t! C: s1 t private : , @+ O |# k1 ~1 n Crgn m_rgn : // window region* z" h: h- R w/ n! S
…% I* J6 \% W& C- w5 I- i
} * [/ o$ _" @/ D6 P- v% h' k6 ] 修改OnInitDialog函数建立一个椭圆区域并调用SetWindowRgn将该区域分配给窗口: % Z9 H+ I7 T/ X0 ]3 ] BOOL CRoundDlg : : OnInitDialog ( )! s: v6 X8 u' G: E
{ : [& J* i* z$ \! b: N/ E# V0 j CDialog : : OnInitDialog ( ) & y. c+ f/ S' k% h+ b6 F $ W( y$ p$ k# a4 G1 ~- l/ i //Get size of dialog . $ a: F' H8 j$ j- K5 l4 K CRect rcDialog 2 O$ D& c$ k4 T I* Z0 s" u GetClientRect (rcDialog ) : v2 ?" T8 X1 _+ B1 p5 h . l% _+ n* E! ]+ f // Create region and assign to window . / r J$ }8 j- D3 x; T m_rgn . CreateEllipticRgn (0 , 0 , rcDialog.Width( ) , rcDialog.Height ( ) )3 x1 V& F5 m/ M& p6 R
SetWindowRgn (GetSafeHwnd ( ) , (HRGN) m_ rgn ,TRUE )3 U$ l$ G; q' X' D7 R
- x# ]! |/ a4 R" M0 D- w return TRUE# f* C9 L$ y; {8 I
} 3 B) \8 }: s, k: H. ` ' d* m" u- p! Y2 n9 \' v G 通过建立区域和调用SetWindowRgn,已经建立一个不规则形状的窗口,下面的例子程序是修改OnPaint函数使窗口形状看起来象一个球形体。 ; F% V1 \% h1 S, H+ ~2 u& S* @6 H ( \! |, ~9 g- H3 O7 l' h/ x4 T " k' w% [) z: n" B: K9 ]: Q : P' z, d! i% m ] z( T+ Y 9 ]1 N$ U5 y+ ~9 p5 C3 m1 V: \ voik CRoundDlg : : OnPaint ( )/ s/ c( M7 i# J: ]8 x: d
{ 1 U0 [" p3 d" p4 c( L/ ^( n CPaintDC de (this) // device context for painting 4 F/ B+ O0 {. o0 G0 B6 G1 ? .+ ?- b% e; l! T2 _" u7 t; l2 S9 [
//draw ellipse with out any border7 d& f, C$ g5 @7 z+ o$ J. \
dc. SelecStockObject (NULL_PEN)& |% F8 d3 g% {6 `7 o
//get the RGB colour components of the sphere color& n8 l. `1 R- E; Z, X
COLORREF color= RGB( 0 , 0 , 255)5 s) r# b9 \6 K6 x
BYTE byRed =GetRValue (color) ' ]: }; w7 b; z BYTE byGreen = GetGValue (color)# r; A- L+ o! Y; o0 _5 ~( b2 A) a: s
BYTE byBlue = GetBValue (color)7 ^- Z( {0 L D, {
- K0 Y3 h {, A7 M // get the size of the view window ! b j$ v: @: R6 a& k" b+ C! p Crect rect 1 O" e! S8 m7 s GetClientRect (rect) , E9 s, b; d) b6 h( H! Z 4 S; |! U. Y: W$ q$ C // get minimun number of units% s- R) `+ u: ~3 {3 q3 e ^- `+ g
int nUnits =min (rect.right , rect.bottom )( O7 _& |& T! {- y( ?
' E! f6 h, k( R+ V } //calculate he horiaontal and vertical step size 0 w/ o& z8 A. G3 P. d float fltStepHorz = (float) rect.right /nUnits 6 b9 T7 c$ k7 S' L float fltStepVert = (float) rect.bottom /nUnits & j7 c( C* @; g4 K% v/ V4 X' T+ b5 V- L. P H; X% B
) [, P6 I9 m! o int nEllipse = nUnits/3 // calculate how many to* \/ k. M* t; K9 m( Y& U# }3 @
draw . x/ H( H0 J# W2 j [ int nIndex % s, a: [* p* X# ]* y // current ellipse that is being draw 6 u. v! d, Q' ~9 W 0 k9 d9 T) }% }& Q3 u- [1 r CBrush brush 3 X; [% ?8 r; l2 J0 C // bursh used for ellipse fill color : J: T* P3 c l* M) e5 j9 |: b) n8 ? CBrush *pBrushOld // previous# G' }4 N& I# |, C
brush that was selected into dc 6 X7 s# g, R( [7 V) D3 J. ~! _8 L //draw ellipse , gradually moving towards upper-right7 q! N0 O$ D' X2 q0 b' Z- D' h
corner8 z8 @2 V2 B. m8 L
for (nIndex = 0 nIndes < + nEllipse nIndes++)0 m6 O4 u/ y$ ?+ `$ ?, V
{7 e# b- }* g6 K# W+ b
//creat solid brush ; F a* K0 e6 b0 m3 Z W- M+ _/ Z7 H brush . CreatSolidBrush (RGB ( ( (nIndex*byRed ) /nEllipse ).' o- R2 l- J0 T& v7 L. b5 N
( ( nIndex * byGreen ) /nEllipse ), ( (nIndex * byBlue)2 X, ~) W; {( G6 z8 o3 s4 ^- Q# ?
/nEllipse ) ) ), V. n4 O; g, g$ ~
- D' z/ I5 T. @! W
//select brush into dc9 h- m$ H+ N7 E7 A3 w2 @, L; I
pBrushOld= dc .SelectObject (&brhsh)$ O# B8 q' A; k, p
; ]$ ?# @+ ~- V, p //draw ellipse 2 [: W) h' W; R2 ` dc .Ellipse ( (int) fltStepHorz * 2, (int) fltStepVert * nIndex ,6 z& t+ V4 y& @6 j' G' V9 x
rect. right -( (int) fltStepHorz * nIndex )+ 1,* s+ c- d! { Z1 O) d
rect . bottom -( (int) fltStepVert * (nIndex *2) ) +1)" V4 R8 s/ }* H' Y" ^8 a" ]3 l
* `; I) I6 Z8 |7 o) Z* w' I
//delete the brush ) j: E+ [& c& ]) o+ s; X: S Z2 f; N brush.DelecteObject ( ) 6 h+ K2 X4 h, v/ ^/ j }, X" N7 \1 @6 C7 b* s1 |/ d) X
} 2 I! `% z2 _1 K5 ^' S7 c6 L8 N+ i- R T4 }" g) W
最后,处理WM_NCHITTEST消息,使当击打窗口的任何位置时能移动窗口。5 H3 [. x0 k5 g
! m# M9 @# C3 Z& t7 e
, b5 U2 V: L% x- a( \5 G & G# [% C; }, j. T- ` d6 y" q! L5 ?( e: U, g( H0 ]3 \
UINT CRoundDlg : : OnNchitTest (Cpoint point ) 0 O2 n9 B5 V3 A" [" @) k { ; X4 w8 i7 ?4 Q" D //Let user move window by clickign anywhere on thewindow .1 o3 D7 l, q/ n% z" p0 |
UINT nHitTest = CDialog : : OnNcHitTest (point) & c; b) y m7 I# e rerurn (nHitTest = = HTCLIENT)? HTCAPTION: nHitTest 3 d& I2 z7 z. v) y; Z) r n1 }, n1 R2 s# q) z
} 2 W8 m: c9 Z% m5 T( C, B+ t% I0 f( d! r" q. o8 s
(25) 如何获取应用程序的 实例句柄? & I: k2 L2 S, F; } 应用程序的实例句柄保存在CWinApp m_hInstance 中,可以这么调用AfxGetInstancdHandle获得句柄.# x, e2 _4 e# {3 J+ |6 e. z
. N' Q- N8 j$ f! @+ O7 t+ v; U
7 s ^" @2 A5 u7 m9 ^* d- O
3 x9 V% Y) G( B- c* }5 n2 }
9 j. V; B4 Z. N* _& B+ y" S! V3 q* N* Y
Example: HANDLE hInstance=AfxGetInstanceHandle() 4 D( m! S& @( e# ^2 J+ A; F9 v- ?8 j, |& V
(26) 如何编程结束应用程序? 1 {- A' |( k8 W 这是个很简单又是编程中经常要遇到的问题., a4 n# _# n% K; _; E0 m
向窗口发送 WM_CLOSE消息,调用 CWnd::OnClose成员函数.允许对用户提示是否保存修改过的数据.5 C4 ^% T- Q9 o# |% k/ n7 o
; q6 s7 N* z6 E. j5 P& d
[被屏蔽广告]$ v7 v6 n# S5 y* p1 B" M$ ?/ y* r/ `
) k* J+ |: I W# p 系列文章:VC实用小知识总结(一) " I9 \2 G% }0 a; v6 N3 M0 x% w* }! L J, h5 n
5 P1 }7 U5 b7 M+ d+ p5 Z7 B, _7 {
. O# _; \6 a1 s
D* ]& h# ^# l8 p3 D Example: AfxGetMainWindow()->SendMessage(WM_CLOSE) 3 U, |0 ]9 G- k, c1 ~$ t # E, q* L) b7 T& Q6 v 还可以创建一个自定义的函数 Terminate Window : Z; S5 K7 @9 H& h 9 w, e5 M! C8 N1 n/ O& c/ K3 i5 z1 q# r) e/ x
" n2 u. \' } P/ K # P" b. o6 E6 R0 K2 O# J void Terminate Window(LPCSTR pCaption)1 D* ?; ^# `4 z7 H1 O2 A" x
{ $ @9 V& [: s% X CWnd *pWnd=Cwnd::FindWindow(NULL,pCaption)& B) o9 L# X, E% ~. o6 Z! t5 C- N
% P1 ^* D2 F. x* q6 S3 ?, L
if (pWnd) ! g! y3 `$ ^: ^1 m) A8 t5 z0 Z' c( }, T : m8 i( l" R9 O6 F3 X: F pWnd ->SendMessage(WM_CLOSE) ) f& I& |4 D2 Q }0 Z/ \- W& ?' u U& e* ^
. J. G$ X1 R6 ^, h' k4 T- W
说明: FindWindow函数不是提倡的做法,因为它无法处理标题栏自动改变,比如我们要检测 Notepad是不是已运行而事先不知道Notepad的标题栏,这时FindWindow就无能为力了,可以通过枚举 windows任务列表的办法来实现。在机械出版社"Windows 95 API开发人员指南"一书有比较详细的介绍,这里就不再多说乐。4 ^) ?# @! w' u& }& r
( F) f V+ E/ n' } (27) 如何创建和使用无模式对话框8 ]9 h; k) m( s! a+ \
MFC将模式和无模式对话封装在同一个类中,但是使用无模式对话需要几个对话需要几个额处的步骤。首先,使用资源编辑器建立对话资源并使用ClassWizard创建一个CDialog的派生类。模式和无模式对话的中止是不一样的:模式对话通过调用CDialog : : EndDialog 来中止,无模式对话则是调用CWnd: : DestroyWindow来中止的,函数CDialog : : OnOK和CDialog : : OnCancel调用EndDialog ,所以需要调用DestroyWindow并重置无模式对话的函数。- w E5 [5 [, s/ p9 D. M
- [/ o% x4 }3 r& R
2 | d' J4 t B3 Z0 Z7 d# B3 F$ A/ y1 a
0 B/ W& P" r( m2 T, X- X5 T$ ? void CSampleDialog : : OnOK ( ) + e3 Q- [4 S3 U/ O; _ { h/ `' x" w, u$ n0 p // Retrieve and validate dialog data .6 f; a8 b. ~8 q
if (! UpdateData (TRUE) ) # K- m6 f! S- W! n3 [ {; V, }6 @+ y( u( l' I
// the UpdateData rountine + t2 g" _9 l8 Q, @) v will set focus to correct item TRACEO (" UpdateData failed during dialog termination ./n") ; f( L. H& r! W6 s; { return 5 j4 Z& p5 g! K+ |* w& u5 r* @ }9 _3 R7 | ]3 {, c5 E