PRB: OnClose() Is Called When Closing Print Preview Dialog Box

Last reviewed: August 7, 1997
Article 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:

  • The Microsoft Foundation Classes (MFC) included with:

        - 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
    

SYMPTOMS

OnClose() is called when the user closes the Print Preview dialog box.

CAUSE

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.

RESOLUTION

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);
    }

STATUS

This behavior is by design.

REFERENCES

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 : MfcPrinting kbprb kbprg kbprint
Technology : kbMfc
Version : 1.50 1.51 1.52 | 1.00 2.00 2.10
Platform : NT WINDOWS


THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY.

Last reviewed: August 7, 1997
© 1998 Microsoft Corporation. All rights reserved. Terms of Use.