The Objective Toolkit Color Well classes provide a sophisticated Color Selection control. This control displays the 20-system colors in a five by four grid.
The user can select a color by clicking a cell in the grid. The user can select from a wider range of colors by clicking the Other button.
The hierarchy diagram for the Objective Toolkit color well classes is as follows:
The SECColorWell class is a CWnd derivative designed for embedding in a dialog window or a CFormView. The color well automatically sizes to fit its content, and it can have a 3D-raised border. SECColorWell also supports palette realization of the selected color. In other words, it maps entries from the current logical palette to the system palette.
The SECColorWell sends a CWN_COLOR_CHANGE message to its parent window when a new color is selected.
To incorporate SECColorWell into your code:
Create the SECColorWell window using the Create() method. Remember to specify whether the control should have an Other button. If you want to embed the color well in a dialog, specify the initial x and y coordinates in dialog base units.
Set the initially selected color with the SetColor() method.
Enable or disable palette realization of the colors before drawing with the SetPaletteRealization() method.
Enable or disable the ability to select a color by passing the mouse over a cell with the SetMouseTracking() method.
Call GetColor() to obtain the currently selected color.
After you create the SECColorWell window, you can use the DDX_Color() function as part of a DoDataExchange() method.
You can customize the SECColorWell class with the following virtual methods:
Method | Description |
DrawCell() | Override to customize the drawing of an unselected cell. |
DrawSelectedCell() | Override to customize the drawing of a selected cell. |
SetGridSize() | Override to change the size of the grid. Set the m_nCols and m_nRows member variables. |
InitAdditionalColors() | Override in conjunction with SetGridSize() to initialize any extra color cells defined in the grid. |
HasFocusRectangle() | Override to define whether the color well has a focus rectangle, an extra 1-pixel-wide border drawn around the edge of the window, when it has focus. |
GetColorDialogFlags() | Override to specify the flags with which the common color selection dialog is opened when the Other button is clicked. |
The SECPopupColorWell class works with the SECWellButton class. It provides a pop-up color selection window. After the application creates the window, it self-destructs when it loses focus or a color is selected.
When the user selects a new color or clicks the Other button, the SECWellButton sends CWN_COLOR_CHANGE and CWN_CUSTOM_COLOR messages to a specified window.
Create the pop-up color well using the Create() method.
Set the window to receive color change notifications using the SetNotifyWindow() method.
Set any other required options as you would for an SECColorWell window.
The use of SECColorWell and SECPopupColorWell is demonstrated in the Objective Toolkit COLOR sample, located at Samples\Toolkit\MFC\Controls\colrwell. This sample is not shipped with the product. For information on how to obtain this sample, see Section 3.6.1, "Location of Sample Code," in the Stingray Studio Getting Started Guide.
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.