ID: Q131792
1.50 1.51 1.52 | 1.00 2.00 2.10 4.00 4.10
WINDOWS | WINDOWS NT
kbprg kbprint kbprb
The information in this article applies to:
- Microsoft Visual C++ for Windows, versions 1.5, 1.51, 1.52
- Microsoft Visual C++, 32-bit Edition, versions 2.0, 2.1, 4.0, 4.1
OnClose() is called when the user closes the Print Preview dialog box.
If your frame window class is CMainFrame, for example, you can override the OnClose() member to perform special processing (such as putting up a message box asking users if they really want to quit), but note that CMainFrame::OnClose() is also called when the user dismisses the Print Preview dialog by pressing ALT+F4 or by double-clicking the upper left corner of the dialog.
NOTE: OnClose() is not called when the user clicks the Close button in the Print Preview dialog box.
In your OnClose() function, you probably don't want to do the same processing during a Print Preview close that you want to do during an application close. Therefore, you should make a special case in the OnClose() code to check whether or not it is being called from Print Preview.
The following code demonstrates how to modify the OnClose() to do nothing during the Print Preview close.
void CMainFrame::OnClose()
{
if (m_bPreview ||
(AfxMessageBox(ID_EXIT_PROMPT, MB_YESNO) == IDYES))
{
CFrameWnd::OnClose();
}
}
In this example, ID_EXIT_PROMPT is a string table resource containing the
string that you want to display in the message box. In addition, m_bPreview
is a member that you need to add to the CMainFrame class; it is initialized
to FALSE in the constructor of the CMainFrame class. Then, the m_bPreview
variable is set again using an override of CFrameWnd::OnSetPreviewMode().
// In .h file of CMainFrame class:
class CMainFrame : public CFrameWnd
{
BOOL m_bPreview; // TRUE in print preview mode; FALSE otherwise
...
};
// In .cpp file of CMainFrame class:
CMainFrame::CMainFrame()
{
m_bPreview = FALSE;
}
void CMainFrame::OnSetPreviewMode(
BOOL bPreview, CPrintPreviewState* pModeStuff)
{
m_bPreview = bPreview;
CFrameWnd::OnSetPreviewMode(bPreview, pModeStuff);
}
This behavior is by design.
For more information on Print Preview, please see MFC Technote 30, "Print Preview."
Additional reference words: 2.50 2.51 2.52 2.10 3.00 3.10 2.00 3.0 3.1 4.00 4.10 KBCategory: kbprg kbprint kbprb KBSubcategory: MfcPrinting
Keywords : kbMFC kbPrinting kbVC
Version : 1.50 1.51 1.52 | 1.00 2.00 2.10
Platform : NT WINDOWS
Last Reviewed: August 8, 1997