Creating the OutLookRichEdit Control | CodeGuru

Creating the OutLookRichEdit Control

Environment: VC6 SP4, 2000. Follow these 10 easy steps to build the OutLookRichEdit control: Insert a rich edit control into the dialog. Call AfxInitRichEdit() in the InitInstance of the App class or in InitDialog. If it does not exist, copy OutLookRichEdit.cpp and OutLookRichEdit.h to the project directory. Click the menu choice Project-Add to Project-Files and […]

Written By
CodeGuru Staff
CodeGuru Staff
Dec 30, 2002
2 minute read
CodeGuru content and product recommendations are editorially independent. We may make money when you click on links to our partners. Learn More

Environment: VC6 SP4, 2000.

Follow these 10 easy steps to build the OutLookRichEdit control:

  1. Insert a rich edit control into the dialog.
  2. Call AfxInitRichEdit() in the InitInstance of the App class or in InitDialog.
  3. If it does not exist, copy OutLookRichEdit.cpp and OutLookRichEdit.h to the project directory.
  4. Click the menu choice Project-Add to Project-Files and select the above-copied files to add the wrapper class to your project.
  5. Import the hand cursor into the resource and rename it “IDC_LINK”.
  6. Use Classwizard to add a member variable of the rich edit control (CRichEditCtrl).
  7. Include the OutLookRichEdit.h file in the dialog’s header file and change the declaration of rich edit member variable, as in
  8. CRichEditCtrl    m_ctrlText1;
    

    to

    COutLookRichEdit m_ctrlText1;
    
  9. In InitDialog(), add the following code.
  10. m_ctrlText1.SetRawHyperText(_T(“Click <%$here$#100#%>
                                    to see the about box.”));
    

    At this level, if you build the project and run it, you can see the rich edit control with linked text, but nothing would happen if you clicked on the link.

    To Show a dialog while the link is clicked, you have to add some more code in the dialog class. Before that, have a closer look at the preceding code and hypertext syntax. The link text is enclosed between the “$” symbols and the corresponding dialog’s resource value 100 (About Box), enclosed in “#” symbols.

    You can find the #define values of dialogs in the resource.h file.

  11. Use ClassWizard to map OnNotify of the dialog and write the corresponding implementation code in .cpp file, like:
  12. BOOL CDEMODlg::OnNotify(WPARAM wParam,
                            LPARAM lParam,
                            LRESULT* pResult)
    {
      NMHDR* pNmHdr = (NMHDR*) lParam;
      if(IDC_RICHEDIT1 == pNmHdr->idFrom){
        switch(pNmHdr->code)
        {
          case IDD_ABOUTBOX:
            CAboutDlg oDlg;
            oDlg.DoModal ();
            break;
        }
      }
      return CDialog::OnNotify(wParam, lParam, pResult);
    }
    
  13. Now, build and run the project. It is recommended that you set the read-only attribute to the rich edit control.

Downloads


Download demo project – 23 Kb


Download source – 6 Kb

CodeGuru Logo

CodeGuru covers topics related to Microsoft-related software development, mobile development, database management, and web application programming. In addition to tutorials and how-tos that teach programmers how to code in Microsoft-related languages and frameworks like C# and .Net, we also publish articles on software development tools, the latest in developer news, and advice for project managers. Cloud services such as Microsoft Azure and database options including SQL Server and MSSQL are also frequently covered.

Property of TechnologyAdvice. © 2026 TechnologyAdvice. All Rights Reserved

Advertiser Disclosure: Some of the products that appear on this site are from companies from which TechnologyAdvice receives compensation. This compensation may impact how and where products appear on this site including, for example, the order in which they appear. TechnologyAdvice does not include all companies or all types of products available in the marketplace.