Rogue Wave banner
Previous fileTop of DocumentContentsIndex pageNext file
Objective Toolkit User's Guide
Rogue Wave web site:  Home Page  |  Main Documentation Page

30.11 Internet Explorer Band Object Wizard and Classes

The Internet Explorer extensibility model allows you to create visible COM objects that inhabit the browser frame, or the enhanced desktop taskbar. OTL provides implementations of IDeskBand and other shell interfaces needed to accomplish this integration. The OTL band Object Wizard can generate a generic band object for any of the three possible types:

Desk Band Docked in the Windows Taskbar on the desktop
Explorer Band (Vertical Explorer Bar) Docked in the left side of the browser.
Communications Band (Horizontal Explorer Bar) Docked in the bottom edge of the browser

From a development perspective, the differences among these types are minor. In fact, the only difference among types is the registry category and default size. The wizard-generated COM object is also a window you can draw your UI onto by handling WM_PAINT messages. Your band object window can contain child windows or whatever user interface you choose.

30.11.1 Changing Size Constraints

Window size limits are controlled by the m_bandInfo member of OtlIDeskbandImpl. m_bandInfo is a DESKBANDINFO structure, which holds the minimum, maximum, integral change and ideal sizes for the band object window. These members can be modified directly in your derived class constructor.

30.11.2 Context Menu Commands

A band object can have context menu commands that appear when the window is right-clicked. OTL supports this through the OtlIContextMenuImpl base class. Menu commands can be conveniently handled in your message map as WM_COMMAND messages. By default, the band Object Wizard adds one custom context menu command handler to the object. The menu handlers are declared in an OTL command map. The command map supplies the menu item text, help string, and a command ID for the menu item.

The code below shows a default command map generated by the band Object Wizard, containing a single command:

Context menu commands are added from top to bottom when the menu is invoked. You can use the command map macros to create the context menu items that you want to add. A context menu command adheres to the following form:

The command map entries can be either OTL_COMMAND or OTL_COMMAND_ID or a mix of both. The choice depends on whether the menu strings are defined in resources or string literals.

30.11.2.1 Parameters

ID_COMMAND
ID_HELP
strCommand
strHelp

This map can be used in conjunction with either OtlIContextMenuImpl or OtlIContextMenuMsgImpl to build context menu extensions. If your object has a window, OtlIContextMenuMsgImpl transparently converts your ID_COMMAND IDs to WM_COMMAND messages that can then be handled in your message map like standard command messages. By default, band objects use OtlIContextMenuMsgImpl and WM_COMMAND handlers for context menu additions.



Previous fileTop of DocumentContentsNo linkNext file

Copyright © Rogue Wave Software, Inc. All Rights Reserved.

The Rogue Wave name and logo, and Stingray, are registered trademarks of Rogue Wave Software. All other trademarks are the property of their respective owners.
Provide feedback to Rogue Wave about its documentation.