Gadgets > Rogue Wave Views Gadgets > Matrices > Using IlvMatrix
 
Using IlvMatrix
A matrix is an instance of the IlvMatrix class, a subclass of IlvAbstractMatrix. A matrix is a rectangular grid made up of rows and columns, which can contain many different types of objects (labels, graphic objects, other gadgets, and so on). These objects, called matrix items, are of the class IlvAbstractMatrixItem.
This section covers the following topics:
*Handling Columns and Rows
*Handling Matrix Items
*Handling Events
*Using Gadget Items in a Matrix
Handling Columns and Rows
This section introduces the various operations you can perform on rows and columns:
*Adding Rows and Columns
*Resizing Rows and Columns
*Setting the Automatic Fit-to-Size Mode
Adding Rows and Columns
You can specify the number of rows or columns that a matrix will contain in the IlvMatrix constructor.
IlvMatrix(IlvDisplay* display,
const IlvRect& rect,
IlUShort nbcol,
IlUShort nbrow,
IlvDim xgrid = IlvDefaultMatrixWidth,
IlvDim ygrid = IlvDefaultMatrixWidth,
IlvDim thickness = IlvDefaultGadgetThickness,
IlvPalette* palette = 0);
Note: A matrix must have at least one row and one column.
You can add new columns and rows to a matrix with the IlvMatrix::insertColumn and IlvMatrix::insertRow member functions and remove them with IlvMatrix::removeColumn or removeRow.
You can modify the number of columns and rows in a matrix in one operation using the member function IlvMatrix::reinitialize.
Resizing Rows and Columns
The initial width of a column and height of a row are specified by the xgrid and ygrid parameters provided to the IlvMatrix constructor. When a matrix is created, its rows and columns all have the same dimensions that are indicated by these parameters. You can, however, modify the original settings with the IlvMatrix::setXgrid and IlvMatrix::setYgrid member functions, which let you set the width of each column and the height of each row, respectively. Also, you can change the size of each individual column or row with the member functions IlvMatrix::resizeColumn and IlvMatrix::resizeRow. In this case, the global settings defined for the matrix are no longer used, and modifying their values will have no effect on the dimensions of the other rows and columns.
To revert to a matrix whose columns and rows are all of the same size, use IlvMatrix::sameHeight and IlvMatrix::sameWidth.
Setting the Automatic Fit-to-Size Mode
You can request that the dimensions of the columns and rows in a matrix be adjusted automatically when the matrix is resized with the member function IlvMatrix::autoFitToSize. This feature does not apply when a matrix has scrollbars. When the “auto fit to size” mode is set, you can specify that only the width of the last column or the height of the last row be adjusted when the matrix is resized with IlvMatrix::adjustLast.
You can also recompute the size of all the columns and rows so that they fit into the matrix bounding box with IlvMatrix::fitToSize.
Handling Matrix Items
Matrix items are instances of subclasses of the class IlvAbstractMatrixItem. Matrix items can be selected and edited. Gadgets used as matrix items are active, meaning that they react to user input.
This section covers the following topics:
*Predefined Matrix Item Classes
*Creating a New Subclass of Matrix Items
*Adding and Removing Matrix Items
*Redrawing Matrix items
*Aligning Matrix Items
*Creating a Relief Matrix Item
*Setting Matrix Items Selection
*Changing Matrix Items Sensitivity
Predefined Matrix Item Classes
Below is a list of subclasses of IlvAbstractMatrixItem:
*IlvLabelMatrixItem  defines a matrix item as a label.
*IlvFilledLabelMatrixItem  defines a matrix item as a label with a filled background.
*IlvBitmapMatrixItem  defines a matrix item as a bitmap.
*IlvIntMatrixItem  defines a matrix item as an integer.
*IlvFilledIntMatrixItem  defines a matrix item as an integer with a filled background.
*IlvFloatMatrixItem  defines a matrix item as a floating-point value.
*IlvFilledFloatMatrixItem  defines a matrix item as a floating-point value with a filled background.
*IlvDoubleMatrixItem  defines a matrix item as a double-precision floating-point value.
*IlvFilledDoubleMatrixItem  defines a matrix item as a double-precision floating-point value with a filled background.
*IlvGraphicMatrixItem  defines a matrix item as a graphic object.
*IlvGadgetMatrixItem  defines a matrix item as a gadget. This type of matrix item differs from IlvGraphicMatrixItem objects in that it can be active in a matrix.
*IlvGadgetItemMatrixItem  defines a matrix item as a gadget item.
Creating a New Subclass of Matrix Items
If the predefined subclasses of the IlvAbstractMatrixItem class (see Predefined Matrix Item Classes) do not fit your needs, you can create your own matrix item subclass. This section describes how to properly register a new matrix item class. Typically, this will enable your matrix item class to be persistent.
The code sample located below is taken from the sample edit. This sample can be found in ILVHOME/samples/gadgets/table/src/edit.cpp, where ILVHOME is the root directory under which Rogue Wave Views has been installed.
The class described here is a subclass of the IlvFloatMatrixItem class. It overrides the IlvFloatMatrixItem::getFormat method to give an access to the display format. However, the important point here is not the class itself, but the registration of the class through the use of macros.
class FormattedFloatItem : public IlvFloatMatrixItem
{
public:
FormattedFloatItem(IlFloat value, const IlString& format)
: IlvFloatMatrixItem(value),
_format(format)
{
}
void setFormat(const IlString& format)
{
_format = format;
}
virtual const char* getFormat() const
{
return (const char*)_format;
}
DeclareMatrixItemInfo();
DeclareMatrixItemIOConstructors(FormattedFloatItem);
protected:
IlString _format;
};
The macro DeclareMatrixItemInfo declares the methods and members needed to handle class information.
The macro DeclareMatrixItemIOConstructors declares the i/o and copy constructors. These constructors are defined in the following way:
FormattedFloatItem::FormattedFloatItem(const FormattedFloatItem& source)
: IlvFloatMatrixItem(source),
_format(source._format)
{
}
FormattedFloatItem::FormattedFloatItem(IlvDisplay* display,
IlvInputFile& is)
: IlvFloatMatrixItem(display, is),
_format()
{
_format.readQuoted(is.getStream());
}
The write method is needed because the macro DeclareMatrixItemInfo was used in the class declaration. It simply calls the superclass write method, and writes the _format member into the stream. To create a read-only subclass of IlvAbstractMatrixItem, use the macro DeclareMatrixItemInfoRO.
void
FormattedFloatItem::write(IlvOutputFile& os) const
{
IlvFloatMatrixItem::write(os);
os.getStream() << " ";
_format.writeQuoted(os.getStream());
os.getStream() << " ";
}
The implementation of the copy and readItem methods are defined using the following macro:
IlvPredefinedMatrixItemIOMembers(FormattedFloatItem);
Finally, the class is registered as a subclass of IlvFloatMatrixItem.
IlvRegisterMatrixItemClass(FormattedFloatItem, IlvFloatMatrixItem);
Adding and Removing Matrix Items
You can add an item to a matrix at a specific location with the member function IlvMatrix::set and remove it with IlvMatrix::remove. The IlvMatrix::getItem member function retrieves an item given its position in the matrix.
Redrawing Matrix items
After adding or removing an item, or modifying it in any way, you must call IlvMatrix::reDrawItem to redraw it. You can also wait until all the modifications are made and call reDraw at the very end to redraw the entire matrix.
Aligning Matrix Items
A matrix item can be centered within a cell or be aligned with the right or left border of the cell.
Figure 14.2    Aligning Items in a Cell
You can change the alignment of a matrix item using the member function IlvMatrix::setItemAlignment. You have to redraw the matrix item for the modifications to take effect. See the section Redrawing Matrix items.
Note:  IlvGadgetMatrixItem objects and IlvGraphicMatrixItem objects holding nonzoomable graphics occupy the full rectangle of the cell and cannot be aligned. For information on these classes, see Predefined Matrix Item Classes.
Creating a Relief Matrix Item
You can create a special relief effect for a matrix item. An item in relief has the same appearance as a button. When selected, a relief matrix item appears like a clicked button. To have a button appear in relief, use IlvMatrix::setItemRelief. You must call the redrawItem member function for the modifications to take effect. See Redrawing Matrix items.
Setting Matrix Items Selection
Matrix items can be selected. A selected matrix item is surrounded by a filled rectangle.
Figure 14.3    Selected and Nonselected Matrix Items
You can select a single matrix item with the member function IlvMatrix::setItemSelected and an entire row or column with IlvMatrix::setColumnSelected and IlvMatrix::setRowSelected. In single selection mode setSelectedItem does not deselect the previously selected item. See Selection Modes.
Once you have selected an item, you must redraw it. See Redrawing Matrix items.
You can change the way the selection is drawn by overriding the member function IlvMatrix::drawSelection in subclasses.
To retrieve the first item selected in a matrix, call IlvMatrix::getFirstSelected.
Changing Matrix Items Sensitivity
Matrix items can be sensitive or nonsensitive. Nonsensitive matrix items cannot be selected nor edited and appear dimmed by default as shown below. You can use the member function IlvMatrix::setItemGrayed with IlFalse as the parameter to make them look like sensitive items (that is, not grayed).
Figure 14.4    Sensitive and Nonsensitive Matrix Items
To change the sensitivity of an item, use the member function IlvMatrix::setItemSensitive. You must redraw the item for the modifications to take effect. See Redrawing Matrix items.
Note: If the matrix item is a graphic object or a gadget, modifying the sensitivity does not affect the drawing of the item.
You can also set a matrix item as read only with IlvMatrix::setItemReadOnly. Read-only matrix items cannot be edited but can be selected.
Handling Events
This section describes the standard matrix behavior implemented by the member function IlvMatrix::handleMatrixEvent. The following topics are covered:
*Selection Modes
*Editing a Matrix Item
*Item Callback
*Activate Callback
*Using Gadgets in a Matrix
*Modifying handleEventMatrix
Selection Modes
There are two selection modes for matrices: single (or exclusive) selection and multiple selection. To set the selection mode, use IlvMatrix::setExclusive with IlTrue as its parameter if you want to specify the single selection mode or IlFalse to specify the multiple selection mode.
In single selection mode, only one item can be selected at a time. This mode has two submodes:
*Single selection—In this mode, you can select only one item at a time. When the selection changes, the previous selected item is deselected.
*Single browse—This mode is similar to the previous one except that clicking the selected item with the middle mouse button cancels the selection.
In multiple selection mode, several items can be selected at the same time. This mode has two submodes:
*Multiple browse—In this mode, you can select several items at the same time either by clicking them or dragging the mouse. Similarly, you can deselect several items by clicking them or by dragging the mouse with the middle button.
*Extended—In this mode, you can select several items at the same time either by clicking them or by dragging the mouse. You can extend the selection by pressing the Shift and CTRL keys while selecting items. You can also specify the direction of the extended selection by using IlvMatrix::setExtendedSelectionOrientation
To specify the selection submode, use IlvMatrix::setBrowseMode.
When the user selects a matrix item or cancels the selection, the Main callback of the matrix is called.
Note: You cannot select items that are not sensitive.
Editing a Matrix Item
If editing is allowed for the matrix (see IlvMatrix::allowEdit), you can edit matrix items. Nonsensitive or read-only matrix items cannot be edited. When an item is being edited, an editor is displayed over it as shown in the illustration below. The base class for matrix item editors is the IlvMatrixItemEditor class. It encapsulates an IlvGraphic object that will be used to display and edit the matrix item. The default editor class used by an IlvMatrix is the IlvDefaultMatrixItemEditor class. It uses an IlvTextField object to edit matrix items. You can change this behavior by using the IlvMatrixItemEditorFactory class.
Figure 14.5    Editing a Matrix Item
To edit an item, select it first with the mouse and click it, or press the F2 key to edit the last selected item. To validate your modifications, press the Enter key in the text field or click in another cell. The virtual member function IlvMatrix::validate is called. Its default implementation invokes the callback associated with the item, if any. See “Item Callback” below. If there is none, it invokes the secondary callback of the matrix. See Associating a Callback with a Gadget.
To edit an item by code, call IlvMatrix::editItem.
IlvMatrix::getEditedItem returns the location of the matrix item being edited.
Item Callback
You can attach a callback to each matrix item. When the user validates the editing of an item, its associated callback is invoked. This callback is defined by:
typedef void (*IlvMatrixItemCallback)(IlvMatrix* matrix,
IlUShort column,
IlUShort row,
IlvAny arg);
where matrix specifies the matrix that contains the item, column and row the location of the item that invoked the callback, and arg an argument passed when installing the callback.
To attach a callback to an item, use IlvMatrix::setItemCallback.
Activate Callback
When the user double-clicks an item or presses the Enter key, the member function IlvMatrix::activateMatrixItem is called. By default, this method invokes the Active Item callback. To set this callback, use IlvMatrix::ActivateMatrixItemCallbackType. See Associating a Callback with a Gadget.
Note: By default, when the user double-clicks a matrix item, this item is ready for editing. In this case, the member function IlvMatrix::activateMatrixItem is not called. If you want to override this default behavior, call IlvMatrix::allowEditOnDoubleClick with IlFalseIlFalse as the parameter.
Using Gadgets in a Matrix
Gadget matrix items do not have the same behavior as other items. They react to events by using their handleEvent member function. This means that a gadget inside a matrix behaves like a gadget outside a matrix. The matrix defines a specific gadget matrix item that can have the keyboard focus. You can specify this item with IlvMatrix::setFocus.
When navigating through the matrix using the arrow keys, you can reach a cell that contains a gadget matrix item. You may want to either continue navigating, or send events to the gadget matrix item. To continue navigating, use the arrow keys to leave the cell. To send events to the gadget matrix item, you can either press a key that the gadget will catch (any key except the arrow keys) or press CTRL+Enter. The gadget matrix item will receive all the keyboard inputs until it receives another CTRL+Enter, or a key that it does not handle.
Modifying handleEventMatrix
You may need to modify the default behavior of a matrix in a subclass of IlvMatrix by redefining the method IlvMatrix::handleMatrixEvent. Some methods can help you as those shown below.
This method returns the column and row to which the mouse points:
virtual IlBoolean pointToPosition(IlvPoint& p,
IlUShort& c,
IlUShort& r,
const IlvTransformer* t =0) const;
This method returns the matrix item to which the mouse points:
virtual IlvAbstractMatrixItem* pointToItem(IlvPoint& p,
IlUShort& c,
IlUShort& r,
const IlvTransformer* t = 0) const;
Using Gadget Items in a Matrix
A matrix can hold gadget items via the class IlvGadgetItemMatrixItem, a subclass of IlvAbstractMatrixItem. Instances of this class encapsulate a gadget item and therefore benefit from all its features. See Gadget Items.
Picture and Label Visibility
You can specify whether all the pictures in a matrix should be displayed by calling the method IlvMatrix::showPicture. Likewise, you can use IlvMatrix::showLabel define the visibility of all its labels. By default, the matrix displays both labels and pictures.
Note: You can override these global settings for a specific item by using the API of the IlvGadgetItem class. For details, see the methods IlvGadgetItem::showLabel and IlvGadgetItem::showPicture.
Label and Picture Position
You may want to change the position of the item labels relative to their pictures. To do so, use the method IlvMatrix::setLabelPosition. By default, the label is placed to the right of the picture (IlvRight).
Note: You can override this global setting for a specific item by using the API of the IlvGadgetItem class. For details, see the method IlvGadgetItem::setLabelPosition.
Editing Items
You can edit gadget items located in a matrix. See Editing Gadget Items.
Dragging and Dropping Items
The IlvMatrix class provides an easy-to-use drag-and-drop mechanism. See Dragging and Dropping Gadget Items.
Tooltips
Matrices can display tooltips when the mouse pointer is over partially visible items.

Version 5.8
Copyright © 2014, Rogue Wave Software, Inc. All Rights Reserved.