![]() | Type | Description | ||
| ID as Long | A Long expression that indicates the index of the skin being added or replaced. The value must be between 1 and 126, so Appearance collection should holds no more than 126 elements. | |||
| Skin as Variant |
A string expression that indicates:
|
![]() | Return | Description | ||
| Boolean | A Boolean expression that indicates whether the new skin was added or replaced. |
The identifier you choose for the skin is very important to be used in the background properties like explained bellow. Shortly, the color properties uses 4 bytes ( DWORD, double WORD, and so on ) to hold a RGB value. More than that, the first byte ( most significant byte in the color ) is used only to specify system color. if the first bit in the byte is 1, the rest of bits indicates the index of the system color being used. So, we use the last 7 bits in the high significant byte of the color to indicates the identifier of the skin being used. So, since the 7 bits can cover 127 values, excluding 0, we have 126 possibilities to store an identifier in that byte. This way, a DWORD expression indicates the background color stored in RRGGBB format and the index of the skin ( ID parameter ) in the last 7 bits in the high significant byte of the color. For instance, the BackColor = BackColor Or &H2000000 indicates that we apply the skin with the index 2 using the old color, to the object that BackColor is applied.
The skin method may change the visual appearance for the following parts in the control:
The following VB sample changes the visual appearance for the selected
node. The SelBackColor property
indicates the selection background color. Shortly, we need to add a skin to
the Appearance object using the Add method, and we need to set the last 7 bits
in the SelBackColor property to indicates the index of the skin that we want
to use. The sample applies the "
"
to the selected node:
With XMLGrid1
With .VisualAppearance
.Add &H22, App.Path + "\selected.ebn"
End With
.SelForeColor = RGB(0, 0, 0)
.SelBackColor = RGB(0,0,255) Or &H22000000
End With
The following C++ sample changes the visual appearance for the selected node:
#include "Appearance.h"
m_xmlgrid.GetVisualAppearance().Add( 0x22, COleVariant(_T("D:\\Temp\\EXMLGrid.Help\\selected.ebn")) );
m_xmlgrid.SetSelBackColor( RGB(0,0,255) | 0x22000000 );
m_xmlgrid.SetSelForeColor( 0 );
The following VB.NET sample changes the visual appearance for the selected node:
With AxXMLGrid1
With .VisualAppearance
.Add(&H22, "D:\Temp\EXMLGrid.Help\selected.ebn")
End With
.SelForeColor = Color.Black
.Template = "SelBackColor = 587137024"
End With
where the 587137024 value is the hexa representation of 0x22FF0000
The following C# sample changes the visual appearance for the selected node:
axXMLGrid1.VisualAppearance.Add(0x22, "d:\\temp\\EXMLGrid.Help\\selected.ebn"); axXMLGrid1.Template = "SelBackColor = 587137024";
where the 587137024 value is the hexa representation of 0x22FF0000.
The following VFP sample changes the visual appearance for the selected node:
With thisform.XMLGrid1
With .VisualAppearance
.Add(34, "D:\Temp\EXMLGrid.Help\selected.ebn")
EndWith
.SelForeColor = RGB(0, 0, 0)
.SelBackColor = RGB(0,0,255) + 570425344
EndWith
The screen shot was generated using the following template: