// This is a part of the Microsoft Foundation Classes C++ library. // Copyright (C) 1992-1998 Microsoft Corporation // All rights reserved. // // This source code is only intended as a supplement to the // Microsoft Foundation Classes Reference and related // electronic documentation provided with the library. // See these sources for detailed information regarding the // Microsoft Foundation Classes product. // Note: This header file contains useful classes that are documented only // in the MFC Technical Notes. These classes may change from version to // version, so be prepared to change your code accordingly if you utilize // this header. In the future, commonly used portions of this header // may be moved and officially documented. #ifndef __AFXPRIV_H__ #define __AFXPRIV_H__ #ifndef __AFXADV_H__ #include #endif #ifndef _INC_MALLOC #include #endif #ifndef __AFXEXT_H__ #include #endif #ifdef _AFX_MINREBUILD #pragma component(minrebuild, off) #endif #ifndef _AFX_FULLTYPEINFO #pragma component(mintypeinfo, on) #endif #ifdef _AFX_PACKING #pragma pack(push, _AFX_PACKING) #endif ///////////////////////////////////////////////////////////////////////////// // AFXPRIV - MFC Private Classes // Implementation structures struct AFX_SIZEPARENTPARAMS; // Control bar implementation struct AFX_CMDHANDLERINFO; // Command routing implementation // Classes declared in this file //CDC class CPreviewDC; // Virtual DC for print preview //CCmdTarget //CWnd //CView class CPreviewView; // Print preview view //CFrameWnd class COleCntrFrameWnd; //CMiniFrameWnd class CMiniDockFrameWnd; class CDockContext; // for dragging control bars ///////////////////////////////////////////////////////////////////////////// #undef AFX_DATA #define AFX_DATA AFX_CORE_DATA ///////////////////////////////////////////////////////////////////////////// // Global ID ranges (see Technical note TN020 for more details) // 8000 -> FFFF command IDs (used for menu items, accelerators and controls) #define IS_COMMAND_ID(nID) ((nID) & 0x8000) // 8000 -> DFFF : user commands // E000 -> EFFF : AFX commands and other things // F000 -> FFFF : standard windows commands and other things etc // E000 -> E7FF standard commands // E800 -> E8FF control bars (first 32 are special) // E900 -> EEFF standard window controls/components // EF00 -> EFFF SC_ menu help // F000 -> FFFF standard strings #define ID_COMMAND_FROM_SC(sc) (((sc - 0xF000) >> 4) + AFX_IDS_SCFIRST) // 0000 -> 7FFF IDR range // 0000 -> 6FFF : user resources // 7000 -> 7FFF : AFX (and standard windows) resources // IDR ranges (NOTE: IDR_ values must be <32768) #define ASSERT_VALID_IDR(nIDR) ASSERT((nIDR) != 0 && (nIDR) < 0x8000) ///////////////////////////////////////////////////////////////////////////// // Context sensitive help support (see Technical note TN028 for more details) // Help ID bases #define HID_BASE_COMMAND 0x00010000UL // ID and IDM #define HID_BASE_RESOURCE 0x00020000UL // IDR and IDD #define HID_BASE_PROMPT 0x00030000UL // IDP #define HID_BASE_NCAREAS 0x00040000UL #define HID_BASE_CONTROL 0x00050000UL // IDC #define HID_BASE_DISPATCH 0x00060000UL // IDispatch help codes ///////////////////////////////////////////////////////////////////////////// // Internal AFX Windows messages (see Technical note TN024 for more details) // (0x0360 - 0x037F are reserved for MFC) #define WM_QUERYAFXWNDPROC 0x0360 // lResult = 1 if processed by AfxWndProc #define WM_SIZEPARENT 0x0361 // lParam = &AFX_SIZEPARENTPARAMS #define WM_SETMESSAGESTRING 0x0362 // wParam = nIDS (or 0), // lParam = lpszOther (or NULL) #define WM_IDLEUPDATECMDUI 0x0363 // wParam == bDisableIfNoHandler #define WM_INITIALUPDATE 0x0364 // (params unused) - sent to children #define WM_COMMANDHELP 0x0365 // lResult = TRUE/FALSE, // lParam = dwContext #define WM_HELPHITTEST 0x0366 // lResult = dwContext, // lParam = MAKELONG(x,y) #define WM_EXITHELPMODE 0x0367 // (params unused) #define WM_RECALCPARENT 0x0368 // force RecalcLayout on frame window // (only for inplace frame windows) #define WM_SIZECHILD 0x0369 // special notify from COleResizeBar // wParam = ID of child window // lParam = lpRectNew (new position/size) #define WM_KICKIDLE 0x036A // (params unused) causes idles to kick in #define WM_QUERYCENTERWND 0x036B // lParam = HWND to use as centering parent #define WM_DISABLEMODAL 0x036C // lResult = 0, disable during modal state // lResult = 1, don't disable #define WM_FLOATSTATUS 0x036D // wParam combination of FS_* flags below // WM_ACTIVATETOPLEVEL is like WM_ACTIVATEAPP but works with hierarchies // of mixed processes (as is the case with OLE in-place activation) #define WM_ACTIVATETOPLEVEL 0x036E // wParam = nState (like WM_ACTIVATE) // lParam = pointer to HWND[2] // lParam[0] = hWnd getting WM_ACTIVATE // lParam[1] = hWndOther #define WM_QUERY3DCONTROLS 0x036F // lResult != 0 if 3D controls wanted // Note: Messages 0x0370, 0x0371, and 0x372 were incorrectly used by // some versions of Windows. To remain compatible, MFC does not // use messages in that range. #define WM_RESERVED_0370 0x0370 #define WM_RESERVED_0371 0x0371 #define WM_RESERVED_0372 0x0372 // WM_SOCKET_NOTIFY and WM_SOCKET_DEAD are used internally by MFC's // Windows sockets implementation. For more information, see sockcore.cpp #define WM_SOCKET_NOTIFY 0x0373 #define WM_SOCKET_DEAD 0x0374 // same as WM_SETMESSAGESTRING except not popped if IsTracking() #define WM_POPMESSAGESTRING 0x0375 #if _MFC_VER >= 0x0600 // WM_HELPPROMPTADDR is used internally to get the address of // m_dwPromptContext from the associated frame window. This is used // during message boxes to setup for F1 help while that msg box is // displayed. lResult is the address of m_dwPromptContext. #define WM_HELPPROMPTADDR 0x0376 #endif // Constants used in DLGINIT resources for OLE control containers // NOTE: These are NOT real Windows messages they are simply tags // used in the control resource and are never used as 'messages' #define WM_OCC_LOADFROMSTREAM 0x0376 #define WM_OCC_LOADFROMSTORAGE 0x0377 #define WM_OCC_INITNEW 0x0378 #define WM_OCC_LOADFROMSTREAM_EX 0x037A #define WM_OCC_LOADFROMSTORAGE_EX 0x037B // Marker used while rearranging the message queue #define WM_QUEUE_SENTINEL 0x0379 // Note: Messages 0x037C - 0x37F reserved for future MFC use. #define WM_RESERVED_037C 0x037C #define WM_RESERVED_037D 0x037D #define WM_RESERVED_037E 0x037E #if _MFC_VER >= 0x0600 // WM_FORWARDMSG - used by ATL to forward a message to another window for processing // WPARAM - DWORD dwUserData - defined by user // LPARAM - LPMSG pMsg - a pointer to the MSG structure // return value - 0 if the message was not processed, nonzero if it was #define WM_FORWARDMSG 0x037F #else #define WM_RESERVED_037F 0x037F #endif // like ON_MESSAGE but no return value #define ON_MESSAGE_VOID(message, memberFxn) \ { message, 0, 0, 0, AfxSig_vv, \ (AFX_PMSG)(AFX_PMSGW)(void (AFX_MSG_CALL CWnd::*)(void))&memberFxn }, // special struct for WM_SIZEPARENT struct AFX_SIZEPARENTPARAMS { HDWP hDWP; // handle for DeferWindowPos RECT rect; // parent client rectangle (trim as appropriate) SIZE sizeTotal; // total size on each side as layout proceeds BOOL bStretch; // should stretch to fill all space }; // flags for wParam in the WM_FLOATSTATUS message enum { FS_SHOW = 0x01, FS_HIDE = 0x02, FS_ACTIVATE = 0x04, FS_DEACTIVATE = 0x08, FS_ENABLE = 0x10, FS_DISABLE = 0x20, FS_SYNCACTIVE = 0x40 }; void AFXAPI AfxRepositionWindow(AFX_SIZEPARENTPARAMS* lpLayout, HWND hWnd, LPCRECT lpRect); ///////////////////////////////////////////////////////////////////////////// // Implementation of command routing struct AFX_CMDHANDLERINFO { CCmdTarget* pTarget; void (AFX_MSG_CALL CCmdTarget::*pmf)(void); }; ///////////////////////////////////////////////////////////////////////////// // Robust file save support // opens a temp file if modeCreate specified and enough free space // renaming, etc occurs automatically if everything succeeds class CMirrorFile : public CFile { // Implementation public: virtual void Abort(); virtual void Close(); virtual BOOL Open(LPCTSTR lpszFileName, UINT nOpenFlags, CFileException* pError = NULL); #if _MFC_VER >= 0x0600 static CString GetTempName(LPCTSTR pstrOriginalFile, BOOL bCreate); #endif protected: CString m_strMirrorName; }; ///////////////////////////////////////////////////////////////////////////// // Implementation of PrintPreview class CPreviewDC : public CDC { DECLARE_DYNAMIC(CPreviewDC) public: virtual void SetAttribDC(HDC hDC); // Set the Attribute DC virtual void SetOutputDC(HDC hDC); virtual void ReleaseOutputDC(); // Constructors CPreviewDC(); // Implementation public: virtual ~CPreviewDC(); #ifdef _DEBUG virtual void AssertValid() const; virtual void Dump(CDumpContext& dc) const; #endif void SetScaleRatio(int nNumerator, int nDenominator); void SetTopLeftOffset(CSize TopLeft); void ClipToPage(); // These conversion functions can be used without an output DC void PrinterDPtoScreenDP(LPPOINT lpPoint) const; // Device-Context Functions virtual int SaveDC(); virtual BOOL RestoreDC(int nSavedDC); public: virtual CGdiObject* SelectStockObject(int nIndex); virtual CFont* SelectObject(CFont* pFont); // Drawing-Attribute Functions virtual COLORREF SetBkColor(COLORREF crColor); virtual COLORREF SetTextColor(COLORREF crColor); // Mapping Functions virtual int SetMapMode(int nMapMode); virtual CPoint SetViewportOrg(int x, int y); virtual CPoint OffsetViewportOrg(int nWidth, int nHeight); virtual CSize SetViewportExt(int x, int y); virtual CSize ScaleViewportExt(int xNum, int xDenom, int yNum, int yDenom); virtual CSize SetWindowExt(int x, int y); virtual CSize ScaleWindowExt(int xNum, int xDenom, int yNum, int yDenom); // Text Functions virtual BOOL TextOut(int x, int y, LPCTSTR lpszString, int nCount); virtual BOOL ExtTextOut(int x, int y, UINT nOptions, LPCRECT lpRect, LPCTSTR lpszString, UINT nCount, LPINT lpDxWidths); virtual CSize TabbedTextOut(int x, int y, LPCTSTR lpszString, int nCount, int nTabPositions, LPINT lpnTabStopPositions, int nTabOrigin); virtual int DrawText(LPCTSTR lpszString, int nCount, LPRECT lpRect, UINT nFormat); virtual BOOL GrayString(CBrush* pBrush, BOOL (CALLBACK* lpfnOutput)(HDC, LPARAM, int), LPARAM lpData, int nCount, int x, int y, int nWidth, int nHeight); // Printer Escape Functions virtual int Escape(int nEscape, int nCount, LPCSTR lpszInData, LPVOID lpOutData); // Implementation protected: void MirrorMappingMode(BOOL bCompute); void MirrorViewportOrg(); void MirrorFont(); void MirrorAttributes(); CSize ComputeDeltas(int& x, LPCTSTR lpszString, UINT& nCount, BOOL bTabbed, UINT nTabStops, LPINT lpnTabStops, int nTabOrigin, LPTSTR lpszOutputString, int* pnDxWidths, int& nRightFixup); protected: int m_nScaleNum; // Scale ratio Numerator int m_nScaleDen; // Scale ratio Denominator int m_nSaveDCIndex; // DC Save index when Screen DC Attached int m_nSaveDCDelta; // delta between Attrib and output restore indices CSize m_sizeTopLeft;// Offset for top left corner of page HFONT m_hFont; // Font selected into the screen DC (NULL if none) HFONT m_hPrinterFont; // Font selected into the print DC CSize m_sizeWinExt; // cached window extents computed for screen CSize m_sizeVpExt; // cached viewport extents computed for screen }; ///////////////////////////////////////////////////////////////////////////// // CPreviewView class CDialogBar; class CPreviewView : public CScrollView { DECLARE_DYNCREATE(CPreviewView) // Constructors public: CPreviewView(); BOOL SetPrintView(CView* pPrintView); // Attributes protected: CView* m_pOrigView; CView* m_pPrintView; CPreviewDC* m_pPreviewDC; // Output and attrib DCs Set, not created CDC m_dcPrint; // Actual printer DC // Operations void SetZoomState(UINT nNewState, UINT nPage, CPoint point); void SetCurrentPage(UINT nPage, BOOL bClearRatios); // Returns TRUE if in a page rect. Returns the page index // in nPage and the point converted to 1:1 screen device coordinates BOOL FindPageRect(CPoint& point, UINT& nPage); // Overridables virtual void OnActivateView(BOOL bActivate, CView* pActivateView, CView* pDeactiveView); // Returns .cx/.cy as the numerator/denominator pair for the ratio // using CSize for convenience virtual CSize CalcScaleRatio(CSize windowSize, CSize actualSize); virtual void PositionPage(UINT nPage); virtual void OnDisplayPageNumber(UINT nPage, UINT nPagesDisplayed); // Implementation public: virtual ~CPreviewView(); virtual void OnPrepareDC(CDC* pDC, CPrintInfo* pInfo = NULL); #ifdef _DEBUG void AssertValid() const; void Dump(CDumpContext& dc) const; #endif protected: //{{AFX_MSG(CPreviewView) afx_msg void OnPreviewClose(); afx_msg int OnCreate(LPCREATESTRUCT lpCreateStruct); afx_msg void OnSize(UINT nType, int cx, int cy); afx_msg void OnDraw(CDC* pDC); afx_msg void OnHScroll(UINT nSBCode, UINT nPos, CScrollBar* pScrollBar); afx_msg void OnVScroll(UINT nSBCode, UINT nPos, CScrollBar* pScrollBar); afx_msg void OnLButtonDown(UINT nFlags, CPoint point); afx_msg BOOL OnEraseBkgnd(CDC* pDC); afx_msg void OnNumPageChange(); afx_msg void OnNextPage(); afx_msg void OnPrevPage(); afx_msg void OnPreviewPrint(); afx_msg void OnZoomIn(); afx_msg void OnZoomOut(); afx_msg void OnUpdateNumPageChange(CCmdUI* pCmdUI); afx_msg void OnUpdateNextPage(CCmdUI* pCmdUI); afx_msg void OnUpdatePrevPage(CCmdUI* pCmdUI); afx_msg void OnUpdateZoomIn(CCmdUI* pCmdUI); afx_msg void OnUpdateZoomOut(CCmdUI* pCmdUI); afx_msg BOOL OnSetCursor(CWnd* pWnd, UINT nHitTest, UINT message); //}}AFX_MSG void DoZoom(UINT nPage, CPoint point); void SetScaledSize(UINT nPage); CSize CalcPageDisplaySize(); CPrintPreviewState* m_pPreviewState; // State to restore CDialogBar* m_pToolBar; // Toolbar for preview struct PAGE_INFO { #if _MFC_VER >= 0x0600 PAGE_INFO(); #endif CRect rectScreen; // screen rect (screen device units) CSize sizeUnscaled; // unscaled screen rect (screen device units) CSize sizeScaleRatio; // scale ratio (cx/cy) CSize sizeZoomOutRatio; // scale ratio when zoomed out (cx/cy) }; PAGE_INFO* m_pPageInfo; // Array of page info structures PAGE_INFO m_pageInfoArray[2]; // Embedded array for the default implementation BOOL m_bPageNumDisplayed;// Flags whether or not page number has yet // been displayed on status line UINT m_nZoomOutPages; // number of pages when zoomed out UINT m_nZoomState; UINT m_nMaxPages; // for sanity checks UINT m_nCurrentPage; UINT m_nPages; int m_nSecondPageOffset; // used to shift second page position HCURSOR m_hMagnifyCursor; CSize m_sizePrinterPPI; // printer pixels per inch CPoint m_ptCenterPoint; CPrintInfo* m_pPreviewInfo; DECLARE_MESSAGE_MAP() friend class CView; friend BOOL CALLBACK _AfxPreviewCloseProc(CFrameWnd* pFrameWnd); }; // Zoom States #define ZOOM_OUT 0 #define ZOOM_MIDDLE 1 #define ZOOM_IN 2 #if _MFC_VER >= 0x0600 ///////////////////////////////////////////////////////////////////////////// // mirroring support //WINBUG: some mirroring stuff will be in wingdi.h someday #ifndef LAYOUT_LTR #define LAYOUT_LTR 0x00000000 #endif #ifndef LAYOUT_RTL #define LAYOUT_RTL 0x00000001 #endif #ifndef NOMIRRORBITMAP #define NOMIRRORBITMAP 0x80000000 #endif //WINBUG: some mirroring stuff will be in winuser.h someday #ifndef WS_EX_LAYOUTRTL #define WS_EX_LAYOUTRTL 0x00400000L #endif #endif ///////////////////////////////////////////////////////////////////////////// // toolbar docking support class CDockContext { public: // Construction CDockContext(CControlBar* pBar); // Attributes CPoint m_ptLast; // last mouse position during drag CRect m_rectLast; CSize m_sizeLast; BOOL m_bDitherLast; // Rectangles used during dragging or resizing CRect m_rectDragHorz; CRect m_rectDragVert; CRect m_rectFrameDragHorz; CRect m_rectFrameDragVert; CControlBar* m_pBar; // the toolbar that created this context CFrameWnd* m_pDockSite; // the controlling frame of the CControlBar DWORD m_dwDockStyle; // allowable dock styles for bar DWORD m_dwOverDockStyle; // style of dock that rect is over DWORD m_dwStyle; // style of control bar BOOL m_bFlip; // if shift key is down BOOL m_bForceFrame; // if ctrl key is down CDC* m_pDC; // where to draw during drag BOOL m_bDragging; int m_nHitTest; UINT m_uMRUDockID; CRect m_rectMRUDockPos; DWORD m_dwMRUFloatStyle; CPoint m_ptMRUFloatPos; // Drag Operations virtual void StartDrag(CPoint pt); void Move(CPoint pt); // called when mouse has moved void EndDrag(); // drop void OnKey(int nChar, BOOL bDown); // Resize Operations virtual void StartResize(int nHitTest, CPoint pt); void Stretch(CPoint pt); void EndResize(); // Double Click Operations virtual void ToggleDocking(); // Operations void InitLoop(); void CancelLoop(); // Implementation public: ~CDockContext(); BOOL Track(); void DrawFocusRect(BOOL bRemoveRect = FALSE); // draws the correct outline void UpdateState(BOOL* pFlag, BOOL bNewValue); DWORD CanDock(); CDockBar* GetDockBar(DWORD dwOverDockStyle); }; ///////////////////////////////////////////////////////////////////////////// // CControlBarInfo - used for docking serialization class CControlBarInfo { public: // Implementation CControlBarInfo(); // Attributes UINT m_nBarID; // ID of this bar BOOL m_bVisible; // visibility of this bar BOOL m_bFloating; // whether floating or not BOOL m_bHorz; // orientation of floating dockbar BOOL m_bDockBar; // TRUE if a dockbar CPoint m_pointPos; // topleft point of window UINT m_nMRUWidth; // MRUWidth for Dynamic Toolbars BOOL m_bDocking; // TRUE if this bar has a DockContext UINT m_uMRUDockID; // most recent docked dockbar CRect m_rectMRUDockPos; // most recent docked position DWORD m_dwMRUFloatStyle; // most recent floating orientation CPoint m_ptMRUFloatPos; // most recent floating position CPtrArray m_arrBarID; // bar IDs for bars contained within this one CControlBar* m_pBar; // bar which this refers to (transient) void Serialize(CArchive& ar, CDockState* pDockState); BOOL LoadState(LPCTSTR lpszProfileName, int nIndex, CDockState* pDockState); BOOL SaveState(LPCTSTR lpszProfileName, int nIndex); }; ///////////////////////////////////////////////////////////////////////////// // CDockBar - used for docking class CDockBar : public CControlBar { DECLARE_DYNAMIC(CDockBar) // Construction public: CDockBar(BOOL bFloating = FALSE); // TRUE if attached to CMiniDockFrameWnd BOOL Create(CWnd* pParentWnd, DWORD dwStyle, UINT nID); // Attributes BOOL m_bFloating; virtual BOOL IsDockBar() const; int GetDockedCount() const; virtual int GetDockedVisibleCount() const; // Operations void DockControlBar(CControlBar* pBar, LPCRECT lpRect = NULL); void ReDockControlBar(CControlBar* pBar, LPCRECT lpRect = NULL); #if _MFC_VER >= 0x0600 BOOL RemoveControlBar(CControlBar*, int nPosExclude = -1, int nAddPlaceHolder = 0); #else BOOL RemoveControlBar(CControlBar*, int nPosExclude = -1, BOOL bAddPlaceHolder = FALSE); #endif void RemovePlaceHolder(CControlBar* pBar); // Implementation public: virtual ~CDockBar(); #ifdef _DEBUG virtual void AssertValid() const; virtual void Dump(CDumpContext& dc) const; #endif virtual CSize CalcFixedLayout(BOOL bStretch, BOOL bHorz); virtual void DoPaint(CDC* pDC); // public implementation helpers void GetBarInfo(CControlBarInfo* pInfo); void SetBarInfo(CControlBarInfo* pInfo, CFrameWnd* pFrameWnd); int FindBar(CControlBar* pBar, int nPosExclude = -1); void ShowAll(BOOL bShow); CPtrArray m_arrBars; // each element is a CControlBar protected: BOOL m_bLayoutQuery; CRect m_rectLayout; CControlBar* GetDockedControlBar(int nPos) const; // implementation helpers int Insert(CControlBar* pBar, CRect rect, CPoint ptMid); virtual void OnUpdateCmdUI(CFrameWnd* pTarget, BOOL bDisableIfNoHndler); //{{AFX_MSG(CDockBar) afx_msg void OnNcCalcSize(BOOL bCalcValidRects, NCCALCSIZE_PARAMS* lpncsp); afx_msg void OnNcPaint(); afx_msg void OnWindowPosChanging(LPWINDOWPOS lpWndPos); afx_msg void OnPaint(); afx_msg LRESULT OnSizeParent(WPARAM, LPARAM); //}}AFX_MSG DECLARE_MESSAGE_MAP() friend class CMiniDockFrameWnd; }; class CMiniDockFrameWnd : public CMiniFrameWnd { DECLARE_DYNCREATE(CMiniDockFrameWnd) public: // Construction CMiniDockFrameWnd(); virtual BOOL Create(CWnd* pParent, DWORD dwBarStyle); // Operations virtual void RecalcLayout(BOOL bNotify = TRUE); // Implementation public: CDockBar m_wndDockBar; //{{AFX_MSG(CMiniFrameWnd) afx_msg void OnClose(); afx_msg void OnNcLButtonDown(UINT nHitTest, CPoint point); afx_msg void OnNcLButtonDblClk(UINT nHitTest, CPoint point); //}}AFX_MSG afx_msg int OnMouseActivate(CWnd* pDesktopWnd, UINT nHitTest, UINT message); DECLARE_MESSAGE_MAP() }; ///////////////////////////////////////////////////////////////////////////// // COleCntrFrameWnd class COleIPFrameWnd; class COleCntrFrameWnd : public CFrameWnd { // Constructor public: COleCntrFrameWnd(COleIPFrameWnd* pInPlaceFrame); // Implementation protected: COleIPFrameWnd* m_pInPlaceFrame; virtual void PostNcDestroy(); public: virtual ~COleCntrFrameWnd(); virtual void RecalcLayout(BOOL bNotify = TRUE); void OnIdleUpdateCmdUI(); virtual BOOL OnCmdMsg(UINT nID, int nCode, void* pExtra, AFX_CMDHANDLERINFO* pHandlerInfo); #ifdef _DEBUG void AssertValid() const; #endif }; ///////////////////////////////////////////////////////////////////////////// // CDialogTemplate class CDialogTemplate { // Constructors public: CDialogTemplate(const DLGTEMPLATE* pTemplate = NULL); CDialogTemplate(HGLOBAL hGlobal); // Attributes BOOL HasFont() const; BOOL SetFont(LPCTSTR lpFaceName, WORD nFontSize); BOOL SetSystemFont(WORD nFontSize = 0); BOOL GetFont(CString& strFaceName, WORD& nFontSize) const; void GetSizeInDialogUnits(SIZE* pSize) const; void GetSizeInPixels(SIZE* pSize) const; static BOOL AFX_CDECL GetFont(const DLGTEMPLATE* pTemplate, CString& strFaceName, WORD& nFontSize); // Operations BOOL Load(LPCTSTR lpDialogTemplateID); HGLOBAL Detach(); // Implementation public: ~CDialogTemplate(); HGLOBAL m_hTemplate; DWORD m_dwTemplateSize; BOOL m_bSystemFont; protected: static BYTE* AFX_CDECL GetFontSizeField(const DLGTEMPLATE* pTemplate); static UINT AFX_CDECL GetTemplateSize(const DLGTEMPLATE* pTemplate); BOOL SetTemplate(const DLGTEMPLATE* pTemplate, UINT cb); }; ///////////////////////////////////////////////////////////////////////////// // WM_NOTIFY support struct AFX_NOTIFY { LRESULT* pResult; NMHDR* pNMHDR; }; ///////////////////////////////////////////////////////////////////////////// // Global implementation helpers // window creation hooking void AFXAPI AfxHookWindowCreate(CWnd* pWnd); BOOL AFXAPI AfxUnhookWindowCreate(); void AFXAPI AfxResetMsgCache(); // for backward compatibility to previous versions #define _AfxHookWindowCreate AfxHookWindowCreate #define _AfxUnhookWindowCreate AfxUnhookWindowCreate // string helpers void AFXAPI AfxSetWindowText(HWND hWndCtrl, LPCTSTR lpszNew); int AFXAPI AfxLoadString(UINT nIDS, LPTSTR lpszBuf, UINT nMaxBuf = 256); HDC AFXAPI AfxCreateDC(HGLOBAL hDevNames, HGLOBAL hDevMode); void AFXAPI AfxGetModuleShortFileName(HINSTANCE hInst, CString& strShortName); // Failure dialog helpers void AFXAPI AfxFailMaxChars(CDataExchange* pDX, int nChars); void AFXAPI AfxFailRadio(CDataExchange* pDX); // DLL load helpers HINSTANCE AFXAPI AfxLoadDll(HINSTANCE* volatile hInst, LPCSTR lpszDLL); HINSTANCE AFXAPI AfxLoadDll(HINSTANCE* volatile hInst, LPCSTR lpszDLL, FARPROC* pProcPtrs, LPCSTR lpszProcName); #ifndef __AFXCONV_H__ #include #endif ///////////////////////////////////////////////////////////////////////////// #ifdef _AFX_PACKING #pragma pack(pop) #endif #undef AFX_DATA #define AFX_DATA #ifdef _AFX_MINREBUILD #pragma component(minrebuild, on) #endif #ifndef _AFX_FULLTYPEINFO #pragma component(mintypeinfo, off) #endif #endif // __AFXPRIV_H__ ///////////////////////////////////////////////////////////////////////////// #ifndef __AFXPRIV2_H__ #include #endif