MRU Dialog

When you start an AppWizard generated MFC application without any command line arguments a new document is created. If the user doesnt want a new document but wants to edit an existing one, the new document created every time the application starts has no purpose at all. The code presented in this article shows a dialog which, when there are no command line arguments, gives the user the opportunity to either start with a new document, open a document from the MRU list or open another existing document. If the user cancels this dialog an empty workspace is shown. The double click event is also handled so editing a file from the MRU list can be started quickly.

The demo code provided with this article adds this functionality to the famous Scribble Application with these steps:

  1. Add the files FileOpen.cpp and FileOpen.h to your project and paste the IDD_FILEOPEN dialog into your application (you can do this easily by temporary including the demo project in your workspace.) Also create a new icon depicting a new document. This icon will be placed next to the "Create a new ... " text. The rest of the dialog will be filled with the document type information.

  2. Include the header file in your application and derive your application from CMRUWinApp instead of CWinApp:
    #include "FileOpen.h"
    
    class CScribbleApp : public CMRUWinApp
    {
    public:
     CScribbleApp();
    
     //..rest of class
    }
    
  3. In your InitInstance() function swap the processing of the command line info and the creation of the main window and call the new function ParseCommandLineEx instead. This function has the ID of the resources used with the document type and the ID of the icon for new documents as extra arguments.
    // First show the main window
    pMainFrame->ShowWindow(m_nCmdShow);
    pMainFrame->UpdateWindow();
    
    // Parse command line for standard shell commands, DDE, file open
    CCommandLineInfo cmdInfo;
    ParseCommandLineEx(cmdInfo, IDR_SCRIBBTYPE, IDR_SCRIBBNEW );
    
    // Dispatch commands specified on the command line
    if (!ProcessShellCommand(cmdInfo))
       return FALSE;
    

Downloads

Download demo project - 34Kb


Comments

  • Little adjustment

    Posted by Legacy on 11/16/2001 12:00am

    Originally posted by: Gijs Franken

    Very nice indeed. Just a little adjustment.

    Try the followinging sequence of actions:
    1) Select a recent file
    2) Select the "new document" radio option
    3) Select the previous select recent file again (directly, without selecting the "open recent.." radio button first).

    A new document is then created while the App is not supposted to do this. Add a NM_CLICK message to the CListCtrl derived list. Implementation goes like this...

    void CRecentFileDlg::OnClickRecentFileList(NMHDR* pNMHDR, LRESULT* pResult)
    {
    m_nAction = 1;
    m_btnOK.EnableWindow(m_RecentFileList.GetSelectedCount() > 0);
    UpdateData(FALSE);

    *pResult = 0;
    }

    The dialog will now selects the "open recent..." radio and all will workout great.

    First contribution/comment so don't take my english and comments not to seriously...

    Reply
Leave a Comment
  • Your email address will not be published. All fields are required.

Top White Papers and Webcasts

  • As mobile devices have pushed their way into the enterprise, they have brought cloud apps along with them. This app explosion means account passwords are multiplying, which exposes corporate data and leads to help desk calls from frustrated users. This paper will discover how IT can improve user productivity, gain visibility and control over SaaS and mobile apps, and stop password sprawl. Download this white paper to learn: How you can leverage your existing AD to manage app access. Key capabilities to …

  • This ESG study by Mark Peters evaluated a common industry-standard disk VTl deduplication system (with 15:1 reduction ratio) versus a tape library with LTO-5, drives with full nightly backups, over a five-year period.  The scenarios included replicated systems and offsite tape vaults.  In all circumstances, the TCO for VTL with deduplication ranged from about 2 to 4 times more expensive than the LTO-5 tape library TCO. The paper shares recent ESG research and lots more. 

Most Popular Programming Stories

More for Developers

Latest Developer Headlines

RSS Feeds