Download Demonstration Question? Contact Us
FlexToolBarSplitButton
class
It
derived from FlexToolBarBaseButton. The
item
is a composite control with which the user can select a default
value bound to a primary button, or select from a list of mutually exclusive
values displayed in a drop-down list bound to a secondary
button.
Examples
The
following example shows how to use the CommandID attribute of a tool
item.
public partial class PasteGroupButton : FlexToolBarSplitButton
{
public PasteGroupButton()
: base()
{
//
******* //
CommandID =
PASTEGROUP_COMMAND_ID;
}
}
class PasteGroupCommand : LinsUICommand
{
public PasteGroupyCommand(long nCommandID, object data) : base(nCommandID, data)
{
//
Assign a help file to this command. The help file must be stored at the
location
//
specified by FlexUISettings.DefaultHelpFilePath,
HelpFile = "PasteGroup.rtf";
//
Assign a short-cut key to this command.
InputKeyGesture = new System.Windows.Input.KeyGesture(
System.Windows.Input.Key.P,
System.Windows.Input.ModifierKeys.Control | System.Windows.Input.ModifierKeys.Alt);
}
public override void
Execute(object parameter)
{
base.Execute(parameter);
//
Execute your command //
}
[CommandEventAttribute(COMMAND_EVENT.HELPBUTTON_CLICK)]
protected void HelpClick(object sender, EventArgs e)
{
//
******* //
}
[CommandEventAttribute(COMMAND_EVENT.DESCENDANT_CLICK)]
protected void OnDescendantClicked(object sender, EventArgs e)
{
//
******* //
}
[CommandEventAttribute(COMMAND_EVENT.DROPDOWN_OPENING)]
protected void OnDropDownOpening(object sender, EventArgs e)
{
//
******* //
}
[CommandEventAttribute(COMMAND_EVENT.DROPDOWN_CLOSED)]
protected void OnDropDownClosed(object sender, EventArgs e)
{
//
******* //
}
public override bool
CanExecute(object parameter)
{
return true;
}
}
public partial class MainWindow : LinsMDIWindow
{
public MainWindow()
{
InitializeComponent();
CreateCommands();
}
private void CreateCommands()
{
//
Create PasteGroup command instance
LinsUICommand command = new PasteGroupCommand(PASTEGROUP_COMMAND_ID, null);
}
}
§
Constructors
1)
public
FlexToolBarSplitButton()
Remarks
Initialize
a new instance of FlexToolBarSplitButton.
§
Members
1)
public
virtual ToolBarItemDisplayStyle Appearence { get; set;
}
Remarks
Gets
or sets the appearance of the tool item.
The default is ToolBarItemDisplayStyle.ImageAndText.
It can be one of the following values,
§
None:
Assigned
Text and assigned Icon are to be rendered.
§
Text:
Only
Text is to be rendered.
§
Image:
Only
Icon is to be rendered.
§
ImageAndText:
Both
Text and Icon are to be rendered.
2)
public virtual Rect Bounds { get; }
Remarks
Retrieve
both the size and the location of the tool item, in pixels, relative to its
parent.
3)
public virtual Rect BoundsAtMDIFrame { get; }
Remarks
Retrieve
both the size and the location of the tool item, in pixels, relative to MDI
frame.
4)
public
virtual bool Checked { get; set; }
Remarks
Gets
or sets the check status of the tool item.
The default is false.
5)
public
long CommandID
{ get; set; }
Remarks
If
this attribute is assigned, then this tool item will be associated to the
correspondent command with the same CommandID. See the above example for
creating a command.
6)
public
FontFamily Font {
get; set; }
Remarks
Gets
or sets the font of the tool item.
The default is SystemFonts.MenuFontFamily.
7)
public
Color
FontColor { get; set; }
Remarks
Gets
or sets the font color of the tool item.
The default is SystemManager.FlexParameters.DefaultToolItemFontColor.
8)
public
double FontSize
{ get; set; }
Remarks
Gets
or sets the font size of the tool item.
The default is SystemFonts.MenuFontSize.
9)
public
FontStyle
FontStyle { get; set; }
Remarks
Gets
or sets the font style of the tool item.
The default is normal.
10)public FontWeight FontWeight { get; set; }
Remarks
Gets
or sets the font weight of the tool item.
The default is normal.
11)public string
HelpContext { get; set; }
Remarks
Gets
or sets the help content for the tool item.
If this tool item has been associated to a command (CommandID attribute is
assigned), then this attribute will be ignored, instead the COMMAND_EVENT.HELPBUTTON_CLICK
event defined inside the correspondent command will be executed once the help
button on the tooltip is clicked.
12)public string
HelpFile { get; set; }
Remarks
Gets
or sets the help file for the tool item.
If this tool item has been associated to a command (CommandID attribute is
assigned), then this attribute will be ignored, instead the COMMAND_EVENT.HELPBUTTON_CLICK
event defined inside the correspondent command will be executed once the help
button on the tooltip is clicked.
13)public virtual ImageSource Icon { get; set; }
Remarks
Gets
or sets the icon of the tool item.
14)public double IconSize { get; set; }
Remarks
Gets
or sets the icon size of the tool item.
The default is 16
pixels.
15)public virtual long
ID { get; set; }
Remarks
Every
tool item should have a unique ID. If the user does not assign a number to the
ID, a unique number which is larger than FlexConstants.m_nUserDefinedControlStartID
(10,000,000) will be automatically generated and assigned to it. If the ID
is between FlexConstants.m_nUserDefinedControlStartID (1000) and
FlexConstants.m_nUserDefinedControlStartID
(10,000,000), then once the tool item is created, it will never been
destroyed, and its layout will be persistent and customizable. You can always
use LinsUIToolItemManager.GetToolItem()
to retrieve its instance, once it is created.
16)public bool
IsCheckable { get; set; }
Remarks
Gets
or sets the check ability of the tool item.
The default is false.
17)public override bool
IsSubMenu { get; }
Remarks
True,
if the tool item has sub-items.
18)public FlexCollection<UIElement> Items { get;
set; }
Remarks
Gets
or sets all sub-tool items.
19)public virual bool
MouseHoverShowDropDownMenu { get; set; }
Remarks
True,
the dropdown list will automatically pop up when the mouse hovers above the
dropdown button for a period of time.
20)public virtual TextImageRelation Relation { get; set; }
Remarks
Gets
or sets the appearance of the tool item.
The default is TextImageRelation.TextBeforeImage.
It can be one of the following values,
§
Overlay:
The
Icon and the Text share the same space.
§
ImageAboveText:
The
Icon is displayed vertically above the Text.
§
TextAboveImage:
The
Text is displayed vertically above the Icon.
§
ImageBeforeText:
The
Icon is displayed horizontally before the Text.
§
TextBeforeImage:
The
Text is displayed horizontally before the Icon.
21)public override string Text { get; set; }
Remarks
Gets
or sets the text of the tool item.
22)public string
ToolTipText { get; set; }
Remarks
Gets
or sets the tooltip of the tool item.
23)public bool UseDefaultButtonIcon { get; set;
}
Remarks
True,
the icon of the selected sub-item will be rendered instead of the original icon
of the dropdown button.
§
Methods
1)
public virtual bool HitTest(
Point
ptMousePosAtMDIFrame)
Parameters
ptMousePosAtMDIFrame
Type:
Point
A
location which is in MDI Frame coordinate.
Remarks
Test
whether the point, ptMousePosAtMDIFrame,
which is in MDI Frame coordinate, is inside this tool item.
2)
public
virtual Size MeasureSize(
bool
bDropDown,
FLEX_DOCKING_ALIGN
nDock)
Parameters
bDropDown
Type:
bool
True,
if this tool item is on a dropdown list, for example a context menu or a
sub-menu.
nDock
Type:
FLEX_DOCKING_ALIGN
The
docking style of the tool item’s container. Always pass in FLEX_DOCKING_ALIGN.TOP,
except the container is a FlexToolBar, and then pass the toolbar’s
FlexDock.
Remarks
This
calculates how much space the tool item requires. If the user wants to customize
the tool item, this method may need to be overridden by the user.
3)
public
virtual void Refresh()
Remarks
This
forces to redraw the tool item.
§
Events
1)
public
event ClickEventhandler
ClickEvent
Remarks
This
event is fired when the tool item is clicked.
2)
public
event RoutedEventHandler
GotFocus
Remarks
This
event is fired when the tool item receives focus.
3)
public
event DescendantItemClickedEventhandler
ItemClicked
Remarks
This
event is fired when any sub-item is clicked.
4)
public
event RoutedEventHandler
LostFocus
Remarks
This
event is fired when the tool item lost focus.
References:
No comments:
Post a Comment