The three virtues of a programmer: Laziness, Impatience, and Hubris. – Larry Wall
UE3:UICalloutButtonPanel (UDK)
Object >> UIRoot >> UIScreenObject >> UIObject >> UIContainer >> UICalloutButtonPanel |
Contents
- 1 Properties
- 2 Enums
- 3 Functions
- 3.1 Native functions
- 3.2 Events
- 3.2.1 AddedChild
- 3.2.2 CanButtonAcceptFocus
- 3.2.3 ContainsButton
- 3.2.4 EnableButton
- 3.2.5 FindButton
- 3.2.6 FindButtonIndex
- 3.2.7 InsertButton
- 3.2.8 PostInitialize
- 3.2.9 RemoveAllButtons
- 3.2.10 RemoveButton
- 3.2.11 RemoveButtonByAlias
- 3.2.12 RemovedChild
- 3.2.13 RemovedFromParent
- 3.2.14 SetButtonCallback
- 3.2.15 SetButtonCaption
- 3.2.16 SetButtonInputAlias
- 3.2.17 ShowButton
- 3.2.18 SynchronizeInputAliases
- 3.3 Other instance functions
- Package:
- Engine
This is an auto-generated page and may need human attention. Please remove the {{autogenerated}} tag if the page seems reasonably complete or replace it with the {{expand}} tag if the page is not yet complete. |
Container for a list of UICalloutButtons which handle navigation between scenes as well as activating special functionality in the scene. Each button is associated with a particular key or alias; the button's associated key is used to lookup the display text and optionally an image of the keyboard or gamepad key required to activate the button.
There are two ways to add buttons to a callout panel - via the panel's CalloutButtonAliases array, and adding new buttons dynamically at runtime. Any buttons added from code dynamically in the editor will be automatically published to the persistent tag array (CalloutButtonAliases) and will be part of the button panel anytime an instance of one is created.
The UIButtonCalloutPanel provides methods for adding, removing, positioning, or modifying the associated key for any button.
Copyright 1998-2009 Epic Games, Inc. All Rights Reserved
Properties[edit]
Property group 'Appearance'[edit]
ButtonBarOrientation[edit]
Type: UIRoot.EUIOrientation
Determines whether the button bar lays out its buttons vertically or horizontally.
ButtonLayout[edit]
Type: ECalloutButtonLayoutType
Determines how the buttons will be positioned within this panel
Default value: CBLT_DockRight
ButtonPadding[edit]
Type: UIRoot.UIScreenValue_Extent
Array size: 2 (EUIOrientation.UIORIENT_MAX
)
The amount of padding to apply to this panel's buttons.
Default value, index 1:
Member | Value |
---|---|
Orientation | UIORIENT_Vertical |
Property group 'Interaction'[edit]
bSupportsButtonRepeat[edit]
Type: bool
Indicates that the buttons in the panel should react to button press and repeat events, rather than release events
Property group 'ZDebug'[edit]
bRefreshButtonDocking[edit]
Type: bool
Modifiers: private, transient
Indicates that the panel should recalculate the docking between all buttons before the next tick.
ButtonTemplate[edit]
Type: UICalloutButton
Modifiers: editinline, editconst, duplicatetransient
the button template to use when creating child button instances for this panel
Default value: UICalloutButton'Engine.Default__UICalloutButtonPanel:CalloutButtonTemplate'
CalloutButtons[edit]
Type: array<UICalloutButton>
Modifiers: editinline, editconst, transient
The list of all buttons currently contained by this callout panel, whether generated based on this object's data store binding, or added dynamically at runtime. Although the buttons would be in the panel's Children array, this separate array provides quick and easy access to the buttons without the need for casting to UICalloutButton everywhere.
Internal variables[edit]
bGeneratingInitialButtons[edit]
Type: bool
Modifiers: transient
Prevents the ConfigureChildButton function from calling SetupDockingRelationships. Used when populating the initial list of buttons from the CalloutButtonAliases array (since we want to wait until all buttons have been added before setting up docking).
ButtonInputKeyMappings[edit]
Type: Map{FName,FName}
Modifiers: native, const, transient
Runtime mapping of input key name => button alias name; updated when buttons call Un/SubscribeToInputProxy; used to quickly lookup the button input alias associated with an input key when an input event occurs.
Fixme: doesn't support multiple players correctly
CalloutButtonAliases[edit]
Modifiers: config
The array of button string aliases used for generating the buttons in this panel.
Default values[edit]
Property | Value | ||||||
---|---|---|---|---|---|---|---|
bNeverFocus | True | ||||||
DockTargets |
|
||||||
Position |
|
||||||
PrimaryStyle |
|
||||||
PrivateFlags | 1024 |
Subobjects[edit]
WidgetEventComponent[edit]
Class: Engine.UIComp_Event
Inherits from: UIContainer.WidgetEventComponent
No new values.
Enums[edit]
ECalloutButtonLayoutType[edit]
Different button layout types
- CBLT_None
- buttons are auto-sized to fit their contents, but button positions are not adjusted unless they overlap
- CBLT_DockLeft
- (Dock Left in UnrealEd) button are auto-sized to fit their contents, and docked to the left side of the panel
- CBLT_DockRight
- (Dock Right in UnrealEd) button are auto-sized to fit their contents, and docked to the right side of the panel
- CBLT_Centered
- (Centered in UnrealEd) buttons are auto-sized to fit their contents, then centered in the panel
- CBLT_Justified
- (Spaced Evenly in UnrealEd) buttons are evenly spaced out in the panel
Functions[edit]
Native functions[edit]
CreateCalloutButton[edit]
Create a new callout button and give it the specified input alias tag.
Parameters:
- ButtonInputAlias - the input alias to assign to the button (i.e. Accept, Cancel, Conditional1, etc.); this tag will be used to generate the button's data store markup.
- ButtonName - allows the caller to specify a name to use when creating the button.
- bInsertChild - if TRUE is specified, the newly created button will also be added to this panel's Children array, using the index provided by calling GetBestInsertionIndex().
Returns:
- an instance of a new UICalloutButton which has ButtonInputAlias as its InputAliasTag.
FindBestInsertionIndex[edit]
Finds the most appropriate position to insert the specified button, based on its InputAliasTag. Only relevant if this button's InputAliasTag is contained in the CalloutButtonAliases array.
Parameters:
- ButtonToInsert - the button that will be inserted into the panel
- bSearchChildren - specify TRUE to search for the best insertion index into the Children array, rather than the CalloutButtonAliases array.
Returns:
- index [into the Children or CalloutButtons array] for the position to insert the button, or INDEX_NONE if the button's InputAliasTag is not contained in the CalloutButtonAliases array (meaning that it's a dynamic button)
GetAvailableCalloutButtonAliases[edit]
Retrieves the list of callout button input aliases which are available for use in the specified button panel.
Parameters:
- AvailableAliases - receives the list of callout button aliases which aren't in use by this button panel.
- PlayerOwner - specifies the player that should be used for looking up the ButtonCallouts datastore; relevant when one player is using a gamepad and another is using a keyboard, for example.
GetCalloutInputProxy[edit]
Returns a reference to the input proxy for this button's scene.
Parameters:
- bCreateIfNecessary - specify TRUE to have an input proxy created for you if it doesn't exist. Future calls to this function would then return that proxy.
Returns:
- a reference to the button bar input proxy used by this button's owner scene.
RequestButtonDockingUpdate[edit]
Request that the docking relationships between the panel's buttons be updated at the beginning of the next scene update. Calling this method will trigger a scene update as well.
Parameters:
- bImmediately - specify TRUE to have the docking updated immediately rather than waiting until the next scene update. A scene update will then only be triggered if any docking relationships changed.
Events[edit]
AddedChild[edit]
Overrides: UIScreenObject.AddedChild
Called immediately after a child has been added to this screen object.
Parameters:
- WidgetOwner - the screen object that the NewChild was added as a child for
- NewChild - the widget that was added
CanButtonAcceptFocus[edit]
Wrapper for easily determining whether the specified button should be able to process input.
Parameters:
- InputAliasTag - the input alias tag (i.e. Conditional1, Accept, Cancel, etc.) used by the button to be found.
- PlayerIndex - index into the Engine.GamePlayers array; unless the scene is configured to allow any player to interact with any widget, filters out any buttons which are associated with players other than the one indicated by this value.
Returns:
- TRUE if the specified button is visible and enabled; FALSE if this panel doesn't contain the button or it isn't currently able to accept focus
ContainsButton[edit]
Wrapper for easily determining whether this panel contains a button associated with the specified input key.
Parameters:
- ButtonInputAlias - the input alias tag (i.e. Conditional1, Accept, Cancel, etc.) used by the button to be found.
Returns:
- TRUE if this panel contains the specified button.
EnableButton[edit]
Wrapper for changing the enabled state of the specified button
Parameters:
- ButtonInputAlias - the input alias tag (i.e. Conditional1, Accept, Cancel, etc.) used by the button to be found.
- bEnableButton - indicates whether the button should be enabled or disabled.
- bUpdateButtonVisibility - indicates that the button's visibility should be updated (if being enabled, show the button; if being disabled, hide the button).
Returns:
- TRUE if the button's enabled state was set successfully.
FindButton[edit]
Returns a reference to the button associated with the input key.
Parameters:
- ButtonInputAlias - the input alias tag (i.e. Conditional1, Accept, Cancel, etc.) used by the button to be found.
Returns:
- the button assocated with the specifed input key, or None if no buttons are associated with that input key.
FindButtonIndex[edit]
Find the index [into the CalloutButtons array] for the specified button.
Parameters:
- ButtonInputAlias - the input alias tag (i.e. Conditional1, Accept, Cancel, etc.) used by the button to be found.
Returns:
- the index for the button assocated with the specifed input key, or INDEX_NONE if no buttons are associated with that input key.
InsertButton[edit]
Adds a new button to this callout panel.
Parameters:
- NewButton - the button to add
Returns:
- the index where the button was actually inserted, or INDEX_NONE if it couldn't be inserted. not yet implemented (possible that this method will be changed to take the button's input key rather than a reference to the button itself).
PostInitialize[edit]
Overrides: UIScreenObject.PostInitialize
Called after this screen object's children have been initialized. While the Initialized event is only called when a widget is initialized for the first time, PostInitialize() will be called every time this widget receives a call to Initialize(), even if the widget was already initialized. Examples would be reparenting a widget.
RemoveAllButtons[edit]
Remove all buttons from the button bar.
Returns:
- TRUE if all buttons were successfully removed.
RemoveButton[edit]
Removes the specified button from the CalloutButtons array (as well as the Children array).
Parameters:
- ButtonToRemove - reference to the button that should be removed.
Returns:
- TRUE if the button was successfully removed.
Todo: should we provide an option for allowing the user to control whether this button's alias is removed from the CalloutButtonAliases map?
RemoveButtonByAlias[edit]
Removes the specified button from the CalloutButtons array (as well as the Children array).
Parameters:
- ButtonInputAlias - the input alias tag (i.e. Conditional1, Accept, Cancel, etc.) used by the button to be found.
Returns:
- TRUE if the button was successfully removed.
Todo: should we provide an option for allowing the user to control whether this button's alias is removed from the CalloutButtonAliases map?
RemovedChild[edit]
Overrides: UIScreenObject.RemovedChild
Called immediately after a child has been removed from this screen object.
Parameters:
- WidgetOwner - the screen object that the widget was removed from.
- OldChild - the widget that was removed
- ExclusionSet - used to indicate that multiple widgets are being removed in one batch; useful for preventing references between the widgets being removed from being severed. NOTE: If a value is specified, OldChild will ALWAYS be part of the ExclusionSet, since it is being removed.
RemovedFromParent[edit]
Overrides: UIScreenObject.RemovedFromParent
Notification that this widget's parent is about to remove this widget from its children array. Allows the widget to clean up any references to the old parent.
Parameters:
- WidgetOwner - the screen object that this widget was removed from.
SetButtonCallback[edit]
Wrapper method for changing the function assigned to the specified button's OnClicked delegate.
Parameters:
- ButtonInputAlias - the input alias tag (i.e. Conditional1, Accept, Cancel, etc.) used by the button to be found.
- NewClickHandler - the function or delegate value to assign to the button's OnClicked delegate.
Returns:
- TRUE if the button's OnClicked delegate was set successfully.
SetButtonCaption[edit]
Wrapper for changing a button's caption. Not yet implemented as this should be coming from the data store.
SetButtonInputAlias[edit]
Wrapper method for changing a button's assigned input alias.
Parameters:
- ButtonInputAlias - the input alias tag (i.e. Conditional1, Accept, Cancel, etc.) used by the button to be found.
- NewButtonInputAlias - the new input alias tag to apply to the button.
Returns:
- TRUE if the button's input alias tag was changed successfully.
ShowButton[edit]
Wrapper for changing the visibility of the specified button
Parameters:
- ButtonInputAlias - the input alias tag (i.e. Conditional1, Accept, Cancel, etc.) used by the button to be found.
- bShowButton - whether the show or hide the button.
Returns:
- TRUE if the button's visiblity was set successfully.
SynchronizeInputAliases[edit]
Ensures that the CalloutButtonAliases array matches
Other instance functions[edit]
ConfigureChildButton[edit]
Configures the button with all the appropriate settings to operate correctly in this callout panel (docking links, auto-size settings, etc.)
Parameters:
- ChildButton - the button to configure
InitializeInputProxy[edit]
Creates CalloutButtonInputProxy object for the scene (if necessary) and register the input keys for all buttons in the panel.
OnButtonVisibilityChanged[edit]
Handler for the NotifyVisibilityChanged delegate in the buttons contained by this panel.
Parameters:
- SourceWidget - the widget that changed visibility status
- bIsVisible - whether this widget is now visible.
PopulateCalloutButtonArray[edit]
Iterates over the Children array, adding any child UICalloutButtons to the CalloutButtons array. Safe to call multiple times.