Notice: This website is an unofficial Microsoft Knowledge Base (hereinafter KB) archive and is intended to provide a reliable access to deleted content from Microsoft KB. All KB articles are owned by Microsoft Corporation. Read full disclaimer for more details.

FILE: Invoke Find, View Source, Options Dialog Boxes for WebBrowser


View products that this article applies to.

This article was previously published under Q175513

↑ Back to the top


Summary

This article illustrates how to invoke the Internet Explorer Find, Internet Options, and View Source dialog boxes from within an application that is hosting the WebBrowser control. The following file is available for download from the Microsoft Download Center:
For additional information about how to download Microsoft Support files, click the following article number to view the article in the Microsoft Knowledge Base:
119591� How to Obtain Microsoft Support Files from Online Services
Microsoft scanned this file for viruses. Microsoft used the most current virus-detection software that was available on the date that the file was posted. The file is stored on security-enhanced servers that help to prevent any unauthorized changes to the file.

↑ Back to the top


More information

Warning This sample uses an undocumented command group GUID that is subject to change in the future. Although this sample has been tested to work correctly with Internet Explorer 3.0 and 4.0, there is no guarantee that these techniques will continue to work successfully in future versions. Please use caution when adding this code to an application.

The WBSampl example is a mini-browser application that illustrates how to create an application in Microsoft Visual C++ that uses the WebBrowser control. This example provides code to invoke the Find, Internet Options, and View Source items that are part of the WebBrowser control but are not exposed as methods.

In order to implement the items listed above, the following steps should be followed.

  1. Define the command group GUID for the WebBrowser control as follows:
    DEFINE_GUID(CGID_IWebBrowser,0xED016940L,0xBD5B,0x11cf,0xBA,
          0x4E,0x00,0xC0,0x4F,0xD7,0x08,0x16);
    					
  2. Define the CommandTarget ids for menu driving as follows:
          #define HTMLID_FIND 1
          #define HTMLID_VIEWSOURCE 2
          #define HTMLID_OPTIONS 3
    					
  3. Execute a CommandTarget id as follows:
          HRESULT CMainFrame::ExecCmdTarget(DWORD nCmdID)
          {
             LPDISPATCH lpDispatch = NULL;
             LPOLECOMMANDTARGET lpOleCommandTarget = NULL;
    
             lpDispatch =
                ((CWebSurferView*)GetActiveView())->m_webBrowser.GetDocument();
             ASSERT(lpDispatch);
    
             // Get an IDispatch pointer for the IOleCommandTarget interface.
             lpDispatch->QueryInterface(IID_IOleCommandTarget,
          (void**)&lpOleCommandTarget);
             ASSERT(lpOleCommandTarget);
    
             lpDispatch->Release();
    
             // Invoke the given command id for the WebBrowser control
                  return lpOleCommandTarget->Exec(&CGID_IWebBrowser, nCmdID, 0,
                                             NULL, NULL);
          }
    					
Note that m_webBrowser is an instance of the WebBrowser control and is defined in the CView-derived class for this project. Also, nCmdID is one of the IDs defined in step 2.

↑ Back to the top


Keywords: kbdownload, kbfaq, kbfile, kbinfo, kbsample, kbwebbrowser, KB175513

↑ Back to the top

Article Info
Article ID : 175513
Revision : 6
Created on : 8/11/2004
Published on : 8/11/2004
Exists online : False
Views : 562