Packagefeathers.controls.text
Classpublic class BitmapFontTextRenderer
InheritanceBitmapFontTextRenderer Inheritance BaseTextRenderer Inheritance FeathersControl Inheritance starling.display.Sprite
Implements ITextRenderer
Subclasses BitmapFontTextEditor

Product Version : Feathers 1.0.0

Renders text using bitmap fonts.

The following example shows how to use BitmapFontTextRenderer with a Label:

var label:Label = new Label();
label.text = "I am the very model of a modern Major General";
label.textRendererFactory = function():ITextRenderer
{
    return new BitmapFontTextRenderer();
};
this.addChild( label );

See also

Introduction to Feathers text renderers
How to use the Feathers BitmapFontTextRenderer component
Starling Wiki: Displaying Text with Bitmap Fonts


Public Properties
 PropertyDefined By
 InheritedaddedEffect : Function
An optional effect that is activated when the component is added to the stage.
FeathersControl
  baseline : Number
[read-only] Returns the text baseline measurement, in pixels.
BitmapFontTextRenderer
  breakLongWords : Boolean
If wordWrap is true, determines if words longer than the width of the text renderer will break in the middle or if the word will extend outside the edges until it ends.
BitmapFontTextRenderer
  currentTextFormat : BitmapFontTextFormat
[read-only] For debugging purposes, the current feathers.text.BitmapFontTextFormat used to render the text.
BitmapFontTextRenderer
 InheriteddefaultTextEditorFactory : Function
[static] A function used by all UI controls that support text editor to create an ITextEditor instance.
FeathersControl
 InheriteddefaultTextRendererFactory : Function
[static] A function used by all UI controls that support text renderers to create an ITextRenderer instance.
FeathersControl
 Inheriteddepth : int
[read-only] The component's depth in the display list, relative to the stage.
FeathersControl
  disabledTextFormat : BitmapFontTextFormat
Advanced font formatting used to draw the text when the component is disabled, if disabledFontStyles and starling.text.TextFormat cannot be used on the parent component because the other features of bitmap fonts are required.
BitmapFontTextRenderer
 InheritedeffectsSuspended : Boolean
[read-only] Indicates if effects have been suspended.
FeathersControl
 InheritedexplicitHeight : Number
[read-only] The height value explicitly set by passing a value to the height setter or by calling the setSize() function.
FeathersControl
 InheritedexplicitMaxHeight : Number
[read-only] The maximum height value explicitly set by passing a value to the maxHeight setter.
FeathersControl
 InheritedexplicitMaxWidth : Number
[read-only] The maximum width value explicitly set by passing a value to the maxWidth setter.
FeathersControl
 InheritedexplicitMinHeight : Number
[read-only] The minimum height value explicitly set by passing a value to the minHeight setter.
FeathersControl
 InheritedexplicitMinWidth : Number
[read-only] The minimum width value explicitly set by passing a value to the minWidth setter.
FeathersControl
 InheritedexplicitWidth : Number
[read-only] The width value explicitly set by passing a value to the width setter or to the setSize() method.
FeathersControl
 InheritedfocusInEffect : Function
An optional effect that is activated when the component receives focus.
FeathersControl
 InheritedfocusManager : IFocusManager
The implementation of this property is provided for convenience, but it cannot be used unless a subclass implements the IFocusDisplayObject interface. The current focus manager for this component.
FeathersControl
 InheritedfocusOutEffect : Function
An optional effect that is activated when the component loses focus.
FeathersControl
 InheritedfocusOwner : IFocusDisplayObject
The implementation of this property is provided for convenience, but it cannot be used unless a subclass implements the IFocusDisplayObject interface. Used for associating focusable display objects that are not direct children with an "owner" focusable display object, such as pop-ups.
FeathersControl
 InheritedfontStyles : FontStylesSet
The internal font styles used to render the text that are passed down from the parent component.
BaseTextRenderer
  globalStyleProvider : IStyleProvider
[static] The default IStyleProvider for all BitmapFontTextRenderer components.
BitmapFontTextRenderer
 Inheritedheight : Number
[override] The height of the component, in pixels.
FeathersControl
 InheritedhideEffect : Function
An optional effect that is activated when the component is hidden.
FeathersControl
 InheritedincludeInLayout : Boolean
Determines if the ILayout should use this object or ignore it.
FeathersControl
 InheritedisCreated : Boolean
[read-only] Determines if the component has been initialized and validated for the first time.
FeathersControl
 InheritedisEnabled : Boolean
Indicates whether the control is interactive or not.
FeathersControl
 InheritedisFocusEnabled : Boolean
The implementation of this property is provided for convenience, but it cannot be used unless a subclass implements the IFocusDisplayObject interface. Determines if this component can receive focus.
FeathersControl
 InheritedisInitialized : Boolean
[read-only] Determines if the component has been initialized yet.
FeathersControl
 InheritedisQuickHitAreaEnabled : Boolean
Similar to mouseChildren on the classic display list.
FeathersControl
 InheritedisShowingFocus : Boolean
[read-only] The implementation of this method is provided for convenience, but it cannot be used unless a subclass implements the IFocusDisplayObject interface. Indicates if the showFocus() method has been called on the object when it has focus.
FeathersControl
 InheritedlayoutData : ILayoutData
Extra parameters associated with this display object that will be used by the layout algorithm.
FeathersControl
 InheritedmaintainTouchFocus : Boolean
[read-only] The implementation of this method is provided for convenience, but it cannot be used unless a subclass implements the IFocusDisplayObject interface. If true, the display object should remain in focus, even if something else is touched.
FeathersControl
 InheritedmaxHeight : Number
The maximum recommended height to be used for self-measurement and, optionally, by any code that is resizing this component.
FeathersControl
 InheritedmaxWidth : Number
The maximum recommended width to be used for self-measurement and, optionally, by any code that is resizing this component.
FeathersControl
 InheritedminHeight : Number
The minimum recommended height to be used for self-measurement and, optionally, by any code that is resizing this component.
FeathersControl
 InheritedminTouchHeight : Number
If using isQuickHitAreaEnabled, and the hit area's height is smaller than this value, it will be expanded.
FeathersControl
 InheritedminTouchWidth : Number
If using isQuickHitAreaEnabled, and the hit area's width is smaller than this value, it will be expanded.
FeathersControl
 InheritedminWidth : Number
The minimum recommended width to be used for self-measurement and, optionally, by any code that is resizing this component.
FeathersControl
 InheritedmoveEffect : Function
An optional effect that is activated when the component is moved to a new position.
FeathersControl
 InheritednextDownFocus : IFocusDisplayObject
The implementation of this property is provided for convenience, but it cannot be used unless a subclass implements the IFocusDisplayObject interface. The next object that will receive focus when Keyboard.DOWN is pressed at KeyLocation.D_PAD and a focus manager is enabled.
FeathersControl
 InheritednextLeftFocus : IFocusDisplayObject
The implementation of this property is provided for convenience, but it cannot be used unless a subclass implements the IFocusDisplayObject interface. The next object that will receive focus when Keyboard.LEFT is pressed at KeyLocation.D_PAD and a focus manager is enabled.
FeathersControl
 InheritednextRightFocus : IFocusDisplayObject
The implementation of this property is provided for convenience, but it cannot be used unless a subclass implements the IFocusDisplayObject interface. The next object that will receive focus when Keyboard.RIGHT is pressed at KeyLocation.D_PAD and a focus manager is enabled.
FeathersControl
 InheritednextTabFocus : IFocusDisplayObject
The implementation of this property is provided for convenience, but it cannot be used unless a subclass implements the IFocusDisplayObject interface. The next object that will receive focus when the tab key is pressed when a focus manager is enabled.
FeathersControl
 InheritednextUpFocus : IFocusDisplayObject
The implementation of this property is provided for convenience, but it cannot be used unless a subclass implements the IFocusDisplayObject interface. The next object that will receive focus when Keyboard.UP is pressed at KeyLocation.D_PAD and a focus manager is enabled.
FeathersControl
  numLines : int
[read-only] The number of text lines in the text renderer.
BitmapFontTextRenderer
  pixelSnapping : Boolean
Determines if the position of the text should be snapped to the nearest whole pixel when rendered.
BitmapFontTextRenderer
 InheritedpreviousTabFocus : IFocusDisplayObject
The implementation of this property is provided for convenience, but it cannot be used unless a subclass implements the IFocusDisplayObject interface. The previous object that will receive focus when the tab key is pressed while holding shift when a focus manager is enabled.
FeathersControl
 InheritedresizeEffect : Function
An optional effect that is activated when the component is resized with new dimensions.
FeathersControl
  selectedTextFormat : BitmapFontTextFormat
Advanced font formatting used to draw the text when the stateContext is disabled, if selectedFontStyles and starling.text.TextFormat cannot be used on the parent component because the other features of bitmap fonts are required.
BitmapFontTextRenderer
 InheritedshowEffect : Function
An optional effect that is activated when the component is shown.
FeathersControl
 InheritedstateContext : IStateContext
When the text renderer observes a state context, the text renderer may change its font styles based on the current state of that context.
BaseTextRenderer
  style : MeshStyle
The style that is used to render the text's mesh.
BitmapFontTextRenderer
 InheritedstyleName : String
The concatenated styleNameList, with values separated by spaces.
FeathersControl
 InheritedstyleNameList : TokenList
[read-only] Contains a list of all "styles" assigned to this control.
FeathersControl
 InheritedstyleProvider : IStyleProvider
When a component initializes, a style provider may be used to set properties that affect the component's visual appearance.
FeathersControl
 Inheritedtext : String
The text to render.
BaseTextRenderer
  textFormat : BitmapFontTextFormat
Advanced font formatting used to draw the text, if fontStyles and starling.text.TextFormat cannot be used on the parent component because the other features of bitmap fonts are required.
BitmapFontTextRenderer
  textureSmoothing : String
A texture smoothing value passed to each character image.
BitmapFontTextRenderer
 InheritedtoolTip : String
Text to display in a tool tip to when hovering over this component, if the ToolTipManager is enabled.
FeathersControl
  truncateToFit : Boolean
If word wrap is disabled, and the text is longer than the width of the label, the text may be truncated using truncationText.
BitmapFontTextRenderer
  truncationText : String
The text to display at the end of the label if it is truncated.
BitmapFontTextRenderer
  useSeparateBatch : Boolean
Determines if the characters are batched normally by Starling or if they're batched separately.
BitmapFontTextRenderer
 Inheritedwidth : Number
[override] The width of the component, in pixels.
FeathersControl
 InheritedwordWrap : Boolean
Determines if the text wraps to the next line when it reaches the width (or max width) of the component.
BaseTextRenderer
Protected Properties
 PropertyDefined By
 InheritedactualHeight : Number = 0
The final height value that should be used for layout.
FeathersControl
 InheritedactualMinHeight : Number = 0
The final minimum height value that should be used for layout.
FeathersControl
 InheritedactualMinWidth : Number = 0
The final minimum width value that should be used for layout.
FeathersControl
 InheritedactualWidth : Number = 0
The final width value that should be used for layout.
FeathersControl
 InheriteddefaultStyleProvider : IStyleProvider
[read-only] When the FeathersControl constructor is called, the styleProvider property is set to this value.
FeathersControl
Public Methods
 MethodDefined By
  
Constructor.
BitmapFontTextRenderer
 Inherited
getBounds(targetSpace:DisplayObject, resultRect:Rectangle = null):Rectangle
[override] Feathers components use an optimized getBounds() implementation that may sometimes behave differently than regular Starling display objects.
FeathersControl
  
Gets the advanced BitmapFontTextFormat font formatting passed in using setTextFormatForState() for the specified state.
BitmapFontTextRenderer
 Inherited
hideFocus():void
The implementation of this method is provided for convenience, but it cannot be used unless a subclass implements the IFocusDisplayObject interface.
FeathersControl
 Inherited
If the component has not yet initialized, initializes immediately.
FeathersControl
 Inherited
invalidate(flag:String):void
Call this function to tell the UI control that a redraw is pending.
FeathersControl
 Inherited
isInvalid(flag:String = null):Boolean
Indicates whether the control is pending validation or not.
FeathersControl
  
measureText(result:Point = null):Point
Measures the text's bounds (without a full validation, if possible).
BitmapFontTextRenderer
 Inherited
move(x:Number, y:Number):void
Sets both the x and the y positions of the control in a single function call.
FeathersControl
 Inherited
removeFromParentWithEffect(effect:Function, dispose:Boolean = false):void
Plays an effect before removing the component from its parent.
FeathersControl
 Inherited
Resets the styleProvider property to its default value, which is usually the global style provider for the component.
FeathersControl
 Inherited
Indicates that effects should be re-activated after being suspended.
FeathersControl
 Inherited
setSize(width:Number, height:Number):void
Sets both the width and the height of the control in a single function call.
FeathersControl
  
setTextFormatForState(state:String, textFormat:BitmapFontTextFormat):void
Sets the advanced BitmapFontTextFormat font formatting to be used by the text renderer when the currentState property of the stateContext matches the specified state value.
BitmapFontTextRenderer
 Inherited
showFocus():void
The implementation of this method is provided for convenience, but it cannot be used unless a subclass implements the IFocusDisplayObject interface.
FeathersControl
 Inherited
Indicates that effects should not be activated temporarily.
FeathersControl
 Inherited
validate():void
Immediately validates the display object, if it is invalid.
FeathersControl
Protected Methods
 MethodDefined By
 Inherited
clearInvalidationFlag(flag:String):void
Clears an invalidation flag.
FeathersControl
 Inherited
draw():void
Override to customize layout and to adjust properties of children.
FeathersControl
 Inherited
focusInHandler(event:Event):void
Default event handler for FeathersEventType.FOCUS_IN that may be overridden in subclasses to perform additional actions when the component receives focus.
FeathersControl
 Inherited
focusOutHandler(event:Event):void
Default event handler for FeathersEventType.FOCUS_OUT that may be overridden in subclasses to perform additional actions when the component loses focus.
FeathersControl
 Inherited
The next style that is set will not be restricted.
FeathersControl
 Inherited
initialize():void
Called the first time that the UI control is added to the stage, and you should override this function to customize the initialization process.
FeathersControl
 Inherited
processStyleRestriction(key:Object):Boolean
Used by setters for properties that are considered "styles" to determine if the setter has been called directly on the component or from a style provider.
FeathersControl
 Inherited
Updates the focus indicator skin by showing or hiding it and adjusting its position and dimensions.
FeathersControl
 Inherited
saveMeasurements(width:Number, height:Number, minWidth:Number = 0, minHeight:Number = 0):Boolean
Saves the dimensions and minimum dimensions calculated for the component.
FeathersControl
 Inherited
setInvalidationFlag(flag:String):void
Sets an invalidation flag.
FeathersControl
 Inherited
setSizeInternal(width:Number, height:Number, canInvalidate:Boolean):Boolean
Sets the width and height of the control, with the option of invalidating or not.
FeathersControl
Events
 Event Summary Defined By
 InheritedDispatched after the component has validated for the first time.FeathersControl
 InheritedDispatched after initialize() has been called, but before the first time that draw() has been called.FeathersControl
 InheritedDispatched when the width or height of the control changes.FeathersControl
Styles
 StyleDefined By
 Inherited
focusIndicatorSkin : DisplayObject
If this component supports focus, this optional skin will be displayed above the component when showFocus() is called.
FeathersControl
 Inherited
focusPadding : Number
Quickly sets all focus padding properties to the same value.
FeathersControl
 Inherited
The minimum space, in pixels, between the object's bottom edge and the bottom edge of the focus indicator skin.
FeathersControl
 Inherited
The minimum space, in pixels, between the object's left edge and the left edge of the focus indicator skin.
FeathersControl
 Inherited
The minimum space, in pixels, between the object's right edge and the right edge of the focus indicator skin.
FeathersControl
 Inherited
The minimum space, in pixels, between the object's top edge and the top edge of the focus indicator skin.
FeathersControl
Public Constants
 ConstantDefined By
 InheritedINVALIDATION_FLAG_ALL : String = "all"
[static] Flag to indicate that everything is invalid and should be redrawn.
FeathersControl
 InheritedINVALIDATION_FLAG_DATA : String = "data"
[static] Invalidation flag to indicate that the primary data displayed by the UI control has changed.
FeathersControl
 InheritedINVALIDATION_FLAG_FOCUS : String = "focus"
[static] Invalidation flag to indicate that the focus of the UI control has changed.
FeathersControl
 InheritedINVALIDATION_FLAG_LAYOUT : String = "layout"
[static] Invalidation flag to indicate that the layout of the UI control has changed.
FeathersControl
 InheritedINVALIDATION_FLAG_SCROLL : String = "scroll"
[static] Invalidation flag to indicate that the scroll position of the UI control has changed.
FeathersControl
 InheritedINVALIDATION_FLAG_SELECTED : String = "selected"
[static] Invalidation flag to indicate that the selection of the UI control has changed.
FeathersControl
 InheritedINVALIDATION_FLAG_SIZE : String = "size"
[static] Invalidation flag to indicate that the dimensions of the UI control have changed.
FeathersControl
 InheritedINVALIDATION_FLAG_SKIN : String = "skin"
[static] Invalidation flag to indicate that the skin of the UI control has changed.
FeathersControl
 InheritedINVALIDATION_FLAG_STATE : String = "state"
[static] Invalidation flag to indicate that the state has changed.
FeathersControl
 InheritedINVALIDATION_FLAG_STYLES : String = "styles"
[static] Invalidation flag to indicate that the styles or visual appearance of the UI control has changed.
FeathersControl
Property Detail
baselineproperty
baseline:Number  [read-only]

Returns the text baseline measurement, in pixels.


Implementation
    public function get baseline():Number
breakLongWordsproperty 
breakLongWords:Boolean

If wordWrap is true, determines if words longer than the width of the text renderer will break in the middle or if the word will extend outside the edges until it ends.

In the following example, the text will break long words:

textRenderer.breakLongWords = true;

The default value is false.


Implementation
    public function get breakLongWords():Boolean
    public function set breakLongWords(value:Boolean):void

See also

currentTextFormatproperty 
currentTextFormat:BitmapFontTextFormat  [read-only]

For debugging purposes, the current feathers.text.BitmapFontTextFormat used to render the text. Updated during validation, and may be null before the first validation.

Do not modify this value. It is meant for testing and debugging only. Use the parent's starling.text.TextFormat font styles APIs instead.


Implementation
    public function get currentTextFormat():BitmapFontTextFormat
disabledTextFormatproperty 
disabledTextFormat:BitmapFontTextFormat

Advanced font formatting used to draw the text when the component is disabled, if disabledFontStyles and starling.text.TextFormat cannot be used on the parent component because the other features of bitmap fonts are required.

In the following example, the disabled text format is changed:

textRenderer.isEnabled = false;
textRenderer.disabledTextFormat = new BitmapFontTextFormat( bitmapFont );

Warning: If this property is not null, any starling.text.TextFormat font styles that are passed in from the parent component may be ignored. In other words, advanced font styling with BitmapFontTextFormat will always take precedence.

The default value is null.


Implementation
    public function get disabledTextFormat():BitmapFontTextFormat
    public function set disabledTextFormat(value:BitmapFontTextFormat):void

See also

globalStyleProviderproperty 
public static var globalStyleProvider:IStyleProvider

The default IStyleProvider for all BitmapFontTextRenderer components.

The default value is null.

See also

numLinesproperty 
numLines:int  [read-only]

The number of text lines in the text renderer. The text renderer may contain multiple text lines if the text contains line breaks or if the wordWrap property is enabled.


Implementation
    public function get numLines():int
pixelSnappingproperty 
pixelSnapping:Boolean

Determines if the position of the text should be snapped to the nearest whole pixel when rendered. When snapped to a whole pixel, the text is often more readable. When not snapped, the text may become blurry due to texture smoothing.

In the following example, the text is not snapped to pixels:

textRenderer.pixelSnapping = false;

The default value is true.


Implementation
    public function get pixelSnapping():Boolean
    public function set pixelSnapping(value:Boolean):void
selectedTextFormatproperty 
selectedTextFormat:BitmapFontTextFormat

Advanced font formatting used to draw the text when the stateContext is disabled, if selectedFontStyles and starling.text.TextFormat cannot be used on the parent component because the other features of bitmap fonts are required.

In the following example, the selected text format is changed:

textRenderer.selectedTextFormat = new BitmapFontTextFormat( bitmapFont );

Warning: If this property is not null, any starling.text.TextFormat font styles that are passed in from the parent component may be ignored. In other words, advanced font styling with BitmapFontTextFormat will always take precedence.

The default value is null.


Implementation
    public function get selectedTextFormat():BitmapFontTextFormat
    public function set selectedTextFormat(value:BitmapFontTextFormat):void

See also

styleproperty 
style:MeshStyle

The style that is used to render the text's mesh.

In the following example, the text renderer uses a custom style:

textRenderer.style = new DistanceFieldStyle();

The default value is null.


Implementation
    public function get style():MeshStyle
    public function set style(value:MeshStyle):void
textFormatproperty 
textFormat:BitmapFontTextFormat

Advanced font formatting used to draw the text, if fontStyles and starling.text.TextFormat cannot be used on the parent component because the other features of bitmap fonts are required.

In the following example, the text format is changed:

textRenderer.textFormat = new BitmapFontTextFormat( bitmapFont );

Warning: If this property is not null, any starling.text.TextFormat font styles that are passed in from the parent component may be ignored. In other words, advanced font styling with BitmapFontTextFormat will always take precedence.

The default value is null.


Implementation
    public function get textFormat():BitmapFontTextFormat
    public function set textFormat(value:BitmapFontTextFormat):void

See also

textureSmoothingproperty 
textureSmoothing:String

A texture smoothing value passed to each character image. If null, defaults to the value specified by the smoothing property of the BitmapFont.

In the following example, the texture smoothing is changed:

textRenderer.textureSmoothing = TextureSmoothing.NONE;

The default value is null.


Implementation
    public function get textureSmoothing():String
    public function set textureSmoothing(value:String):void

See also

truncateToFitproperty 
truncateToFit:Boolean

If word wrap is disabled, and the text is longer than the width of the label, the text may be truncated using truncationText.

This feature may be disabled to improve performance.

This feature does not currently support the truncation of text displayed on multiple lines.

In the following example, truncation is disabled:

textRenderer.truncateToFit = false;

The default value is true.


Implementation
    public function get truncateToFit():Boolean
    public function set truncateToFit(value:Boolean):void

See also

truncationTextproperty 
truncationText:String

The text to display at the end of the label if it is truncated.

In the following example, the truncation text is changed:

textRenderer.truncationText = " [more]";

The default value is "...".


Implementation
    public function get truncationText():String
    public function set truncationText(value:String):void
useSeparateBatchproperty 
useSeparateBatch:Boolean

Determines if the characters are batched normally by Starling or if they're batched separately. Batching separately may improve performance for text that changes often, while batching normally may be better when a lot of text is displayed on screen at once.

In the following example, separate batching is disabled:

textRenderer.useSeparateBatch = false;

The default value is true.


Implementation
    public function get useSeparateBatch():Boolean
    public function set useSeparateBatch(value:Boolean):void
Constructor Detail
BitmapFontTextRenderer()Constructor
public function BitmapFontTextRenderer()

Constructor.

Method Detail
getTextFormatForState()method
public function getTextFormatForState(state:String):BitmapFontTextFormat

Gets the advanced BitmapFontTextFormat font formatting passed in using setTextFormatForState() for the specified state.

If an BitmapFontTextFormat is not defined for a specific state, returns null.

Parameters

state:String

Returns
BitmapFontTextFormat

See also

measureText()method 
public function measureText(result:Point = null):Point

Measures the text's bounds (without a full validation, if possible).

Parameters

result:Point (default = null)

Returns
Point
setTextFormatForState()method 
public function setTextFormatForState(state:String, textFormat:BitmapFontTextFormat):void

Sets the advanced BitmapFontTextFormat font formatting to be used by the text renderer when the currentState property of the stateContext matches the specified state value. For advanced use cases where starling.text.TextFormat cannot be used on the parent component because other features of bitmap fonts are required.

If an BitmapFontTextFormat is not defined for a specific state, the value of the textFormat property will be used instead.

If the disabledTextFormat property is not null and the isEnabled property is false, all other text formats will be ignored.

Parameters

state:String
 
textFormat:BitmapFontTextFormat

See also