PcoWSkbVqDnWTu_dm2ix
The Developer Hub is now deprecated and information on this page may no longer be accurate. To see our new and improved documentation, please click here. You can read more about the future of documentation here.
Collapse Sidebar

TextBox

Show deprecated

TextBox

Show deprecated
A TextBox being clicked on and typed into in Roblox Studio

A TextBox allows the player to provide text input. It behaves similarly to a TextButton, except that a single TextBox can be put in focus by clicking, tapping or gamepad selection. While in focus, the player can use a keyboard to change the TextBox/Text|Text property.

  • If there is no text, the TextBox/PlaceholderText|PlaceholderText will be visible. This is useful prompting players of the kind or format of data they should input.
  • By default, the TextBox/ClearTextOnFocus|ClearTextOnFocus property is enabled and ensures there is no existing text when a TextBox is focused. This may not be desirable for text that should be editable by the player.
  • The TextBox/MultiLine|MultiLine property allows players to enter multiple lines of text with newline characters (\n).

The ContextActionService honors TextBox keybinds and will automatically prevent key press events from being passed to actions bound with ContextActionService/BindAction. UserInputService/InputBegan and related events will still fire while a TextBox is in focus.

Focus State

It is possible to detect and change the focus state of a TextBox:

  • You can use TextBox/CaptureFocus|CaptureFocus when a dialogue appears so that the player doesn’t have to click on a TextBox when it becomes available; you can use ContextActionService/BindAction to bind a certain key to focus a TextBox using this function. When a TextBox comes into focus, the TextBox/Focused|Focused event fires.
  • You can detect if a certain TextBox is in focus by using TextBox/IsFocused|IsFocused. Alternatively, UserInputService/GetFocusedTextBox can be used to check if any TextBox is in focus.
  • When the player is done inputting text, the TextBox/FocusLost|FocusLost event fires, indicating if the user pressed Enter to submit text along with the InputObject that caused the loss of focus. When using on screen keyboards on mobile and console, TextBox/ReturnPressedFromOnScreenKeyboard|ReturnPressedFromOnScreenKeyboard may also fire.
  • If some more important matter comes up during gameplay, you can TextBox/ReleaseFocus|ReleaseFocus of the TextBox so that a player’s keyboard input returns to your game.

Text Editing

A TextBox with text being selected, copied and pasted

A TextBox supports text selection through its TextBox/CursorPosition|CursorPosition and TextBox/SelectionStart|SelectionStart properties. Using Instance/GetPropertyChangedSignal|GetPropertyChangedSignal, you can detect when a selection changes. Additionally, it is possible for players to copy and paste text within a TextBox, enabling basic clipboard support.

Text Filtering Notice
Games that facilitate player-to-player communication using text, such as custom chat or nametags, must properly filter such text using TextService/FilterStringAsync or Chat/FilterStringAsync. If this is not properly done, your game may receive moderation action.

Properties

bool

ClearTextOnFocus

Determines whether clicking on the TextBox will clear its TextBox/Text property

string

ContentText

[ReadOnly] [NotReplicated]
int

CursorPosition

Determines the offset of the text cursor in bytes, or -1 if there is no cursor.

bool

EnableRealtimeFilteringHints

[Hidden] [NotReplicated]
Font

Font

Determines the font used to render text

FontSize

FontSize

[NotReplicated] [Deprecated]

Determines the font size of a TextBox|GUI object

float

LineHeight

Scales the spacing between lines of text in the TextBox

bool

ManualFocusRelease

[Hidden] [NotReplicated]
int

MaxVisibleGraphemes

The maximum number of graphemes the TextBox can show.

bool

MultiLine

When set to true, text inside a TextBox is able to move onto multiple lines. This also enables players to use the enter key to move onto a new line.

bool

OverlayNativeInput

[Hidden] [NotReplicated]
Color3

PlaceholderColor3

Sets the text color that gets used when no text has been entered into the TextBox yet.

string

PlaceholderText

Sets the text that gets displayed when no text has been entered into the TextBox yet.

ReturnKeyType

ReturnKeyType

[Hidden] [NotReplicated]
bool

RichText

Determines whether the TextBox renders the TextBox/Text string using rich text formatting.

int

SelectionStart

Determines the starting position of a text selection, or -1 if no text is selected

bool

ShowNativeInput

If set to true, input native to the platform is used instead of Roblox’s built-in keyboard.

string

Text

Determines the string rendered by the UI element.

Vector2

TextBounds

[ReadOnly] [NotReplicated]

The size of a UI element’s text in offsets.

BrickColor

TextColor

[Hidden] [NotReplicated] [Deprecated]
Color3

TextColor3

Determines the color of rendered text

bool

TextEditable

Determines whether the user can change the TextBox/Text|Text.

bool

TextFits

[ReadOnly] [NotReplicated]

Whether the text fits within the constraints of the TextBox.

TextInputType

TextInputType

[Hidden] [NotReplicated]
bool

TextScaled

Changes whether text is resized to fit the GUI object that renders it.

float

TextSize

Determine the line height of text in offsets.

Color3

TextStrokeColor3

Determines the color of the text stroke (outline).

float

TextStrokeTransparency

Determines the transparency of the text stroke (outline).

float

TextTransparency

Determines the transparency of rendered text.

TextTruncate

TextTruncate

Controls the truncation of the text displayed in this TextBox.

bool

TextWrap

[NotReplicated] [Deprecated]
bool

TextWrapped

Determines if text wraps to multiple lines within the GuiObject|GUI element space, truncating excess text

TextXAlignment

TextXAlignment

Determines the horizontal alignment of rendered text.

TextYAlignment

TextYAlignment

Determines the vertical alignment of rendered text.

Inherited from GuiObject: Show Hide

bool

Active

Determines whether a UI element sinks input

Vector2

AnchorPoint

Determines the origin point of a GuiObject|GUI, relative to its absolute size

AutomaticSize

AutomaticSize

Determines whether resizing occurs based on child content

BrickColor

BackgroundColor

[Hidden] [NotReplicated] [Deprecated]

Determines the color of a GuiObject|GUI's background

Color3

BackgroundColor3

Determines aGuiObject|GUI's background color

float

BackgroundTransparency

Determines the transparency of the GuiObject|GUI's background and border

BrickColor

BorderColor

[Hidden] [NotReplicated] [Deprecated]

Determines the color of a GuiObject|GUI's border

Color3

BorderColor3

Determines the color of a GuiObject|GUI's border

BorderMode

BorderMode

Determines in what manner a GuiObject’s border is laid out relative to its dimensions.

int

BorderSizePixel

Determines the pixel width of a GuiObject|GUI's border

bool

ClipsDescendants

Determines if descendant GuiObject|GUIs outside of the bounds of a parent GUI element should render

bool

Draggable

[Deprecated]

Determines whether a GuiObject|GUI (and its descendants) can be dragged around the screen

int

LayoutOrder

Controls the sort order of a GuiObject|GUI when used with a UIGridStyleLayout

GuiObject

NextSelectionDown

Sets the GuiObject which will be selected when the Gamepad selector is moved in this direction

GuiObject

NextSelectionLeft

Sets the GuiObject which will be selected when the Gamepad selector is moved in this direction

GuiObject

NextSelectionRight

Sets the GuiObject|GUI which will be selected when the `Enum/Gamepad selector is moved in this direction

GuiObject

NextSelectionUp

Sets the GuiObject which will be selected when the Gamepad selector is moved in this direction

UDim2

Position

Determines the pixel and scalar position of a GUI

float

Rotation

Determines the number of degrees by which a UI element is rotated

bool

Selectable

Determine whether the GuiObject|GUI can be selected by a gamepad

GuiObject

SelectionImageObject

Overrides the default selection adornment (used for gamepads)

UDim2

Size

Determine the pixel and scalar size of a GuiObject|GUI

SizeConstraint

SizeConstraint

Selects the GuiObject/Size axes that a GuiObject|GUI will be based relative to the size of its parent

float

Transparency

[Hidden] [NotReplicated]

A mixed property of BackgroundTransparency and TextTransparency

bool

Visible

Determines whether a GuiObject/GUI and its descendants will be rendered

int

ZIndex

Determines the order in which a GuiObject|GUI renders relative to other GUIs

Inherited from GuiBase2d: Show Hide

Vector2

AbsolutePosition

[ReadOnly] [NotReplicated]

Describes the actual screen position of a UI element, in pixels.

float

AbsoluteRotation

[ReadOnly] [NotReplicated]

Describes the actual screen rotation of a UI element, in degrees.

Vector2

AbsoluteSize

[ReadOnly] [NotReplicated]

Describes the actual screen size of a UI element, in pixels.

bool

AutoLocalize

When set to true, localization will be applied to this GuiBase2d and its descendants based on the GuiBase2d/RootLocalizationTable specified for this GuiBase2d.

Rect

ClippedRect

[Hidden] [ReadOnly] [NotReplicated]
bool

IsNotOccluded

[Hidden] [ReadOnly] [NotReplicated]
bool

Localize

[Hidden] [NotReplicated] [Deprecated]

Automatically set to true when a LocalizationTable’s Root targets this object, or an ancestor of this object.

Rect

RawRect2D

[Hidden] [ReadOnly] [NotReplicated]
LocalizationTable

RootLocalizationTable

A reference to a LocalizationTable to be used to apply automated localization to this GuiBase2d and its descendants.

float

TotalGroupScale

[Hidden] [ReadOnly] [NotReplicated]

Inherited from Instance: Show Hide

bool

Archivable

Determines if an Instance can be cloned using /Instance/Clone or saved to file.

string

ClassName

[ReadOnly] [NotReplicated]

A read-only string representing the class this Instance belongs to

int

DataCost

[Hidden] [ReadOnly] [NotReplicated] [Deprecated]

The cost of saving the instance using data persistence.

string

Name

A non-unique identifier of the Instance

Instance

Parent

[NotReplicated]

Determines the hierarchical parent of the Instance

bool

RobloxLocked

[Hidden]

A deprecated property that used to protect CoreGui objects

int64

SourceAssetId

[Hidden] [NotReplicated]
bool

archivable

[Hidden] [NotReplicated] [Deprecated]
string

className

[ReadOnly] [NotReplicated] [Deprecated]

Functions

void

CaptureFocus ( )

Forces the client to focus on the TextBox.

bool

IsFocused ( )

Returns true if the textbox is focused, or false if it is not.

void

ReleaseFocus ( bool submitted )

Forces the client to unfocus the TextBox.

void

ResetKeyboardMode ( )

void

SetTextFromInput ( string text )

Inherited from GuiObject: Show Hide

bool

TweenPosition ( UDim2 endPosition , EasingDirection easingDirection , EasingStyle easingStyle , float time , bool override , Function callback )

Smoothly moves a GUI to a new DataType/UDim2

bool

TweenSize ( UDim2 endSize , EasingDirection easingDirection , EasingStyle easingStyle , float time , bool override , Function callback )

Smoothly resizes a GUI to a new DataType/UDim2

bool

TweenSizeAndPosition ( UDim2 endSize , UDim2 endPosition , EasingDirection easingDirection , EasingStyle easingStyle , float time , bool override , Function callback )

Smoothly moves a GUI to a new size and position

Inherited from Instance: Show Hide

void

ClearAllChildren ( )

This function destroys all of an Instance’s children.

Instance

Clone ( )

Create a copy of an object and all its descendants, ignoring objects that are not Instance/Archivable|Archivable

void

Destroy ( )

Sets the Instance/Parent property to nil, locks the Instance/Parent property, disconnects all connections, and calls Destroy on all children.

Instance

FindFirstAncestor ( string name )

Returns the first ancestor of the Instance whose Instance/Name is equal to the given name.

Instance

FindFirstAncestorOfClass ( string className )

Returns the first ancestor of the Instance whose Instance/ClassName is equal to the given className.

Instance

FindFirstAncestorWhichIsA ( string className )

Returns the first ancestor of the Instance for whom Instance/IsA returns true for the given className.

Instance

FindFirstChild ( string name , bool recursive )

Returns the first child of the Instance found with the given name.

Instance

FindFirstChildOfClass ( string className )

Returns the first child of the Instance whose Instance/ClassName|ClassName is equal to the given className.

Instance

FindFirstChildWhichIsA ( string className , bool recursive )

Returns the first child of the Instance for whom Instance/IsA returns true for the given className.

Instance

FindFirstDescendant ( string name )

Returns the first descendant found with the given Instance/Name.

Actor

GetActor ( )

Returns the Actor associated with the Instance, usually the first Actor ancestor

Variant

GetAttribute ( string attribute )

Returns the attribute which has been assigned to the given name

RBXScriptSignal

GetAttributeChangedSignal ( string attribute )

Returns an event that fires when the given attribute changes

Dictionary

GetAttributes ( )

Returns a dictionary of string → variant pairs for each of the Instance|Instance’s attributes

Objects

GetChildren ( )

Returns an array containing all of the Instance’s children.

string

GetDebugId ( int scopeLength )

[NotBrowsable]

Returns a coded string of the Instances DebugId used internally by Roblox.

Array

GetDescendants ( )

[CustomLuaState]

Returns an array containing all of the descendants of the instance

string

GetFullName ( )

Returns a string describing the Instance’s ancestry.

RBXScriptSignal

GetPropertyChangedSignal ( string property )

Get an event that fires when a given property of an object changes.

bool

IsA ( string className )

[CustomLuaState]

Returns true if an Instance’s class matches or inherits from a given class

bool

IsAncestorOf ( Instance descendant )

Returns true if an Instance is an ancestor of the given descendant.

bool

IsDescendantOf ( Instance ancestor )

Returns true if an Instance is a descendant of the given ancestor.

void

Remove ( )

[Deprecated]

Sets the object’s Parent to nil, and does the same for all its descendants.

void

SetAttribute ( string attribute , Variant value )

Sets the attribute with the given name to the given value

Instance

WaitForChild ( string childName , double timeOut )

[CustomLuaState] [CanYield]

Returns the child of the Instance with the given name. If the child does not exist, it will yield the current thread until it does.

Objects

children ( )

[Deprecated]

Returns an array of the object’s children.

Instance

clone ( )

[Deprecated]
void

destroy ( )

[Deprecated]
Instance

findFirstChild ( string name , bool recursive )

[Deprecated]
Objects

getChildren ( )

[Deprecated]
bool

isA ( string className )

[Deprecated] [CustomLuaState]
bool

isDescendantOf ( Instance ancestor )

[Deprecated]
void

remove ( )

[Deprecated]

Events

RBXScriptSignal

FocusLost ( bool enterPressed , InputObject inputThatCausedFocusLoss )

The FocusLost event fires when the client lets their focus off the /TextBox.

RBXScriptSignal

Focused ( )

Fires when the /TextBox gains focus.

RBXScriptSignal

ReturnPressedFromOnScreenKeyboard ( )

Inherited from GuiObject: Show Hide

RBXScriptSignal

DragBegin ( UDim2 initialPosition )

[Deprecated]

Fired when a player begins dragging the object

RBXScriptSignal

DragStopped ( int x , int y )

[Deprecated]

Fired when a player stops dragging the object

RBXScriptSignal

InputBegan ( InputObject input )

Fired when a user begins interacting via a Human-Computer Interface device (Mouse button down, touch begin, keyboard button down, etc)

RBXScriptSignal

InputChanged ( InputObject input )

Fired when a user changes how they’re interacting via a Human-Computer Interface device (Mouse button down, touch begin, keyboard button down, etc)

RBXScriptSignal

InputEnded ( InputObject input )

Fired when a user stops interacting via a Human-Computer Interface device (Mouse button down, touch begin, keyboard button down, etc)

RBXScriptSignal

MouseEnter ( int x , int y )

Fires when a user moves their mouse into a GUI element

RBXScriptSignal

MouseLeave ( int x , int y )

Fires when a user moves their mouse out of a GUI element

RBXScriptSignal

MouseMoved ( int x , int y )

Fires whenever a user moves their mouse while it is inside a GUI element

RBXScriptSignal

MouseWheelBackward ( int x , int y )

Fires when a user scrolls their mouse wheel back when the mouse is over a GUI element

RBXScriptSignal

MouseWheelForward ( int x , int y )

Fires when a user scrolls their mouse wheel forward when the mouse is over a GUI element

RBXScriptSignal

SelectionGained ( )

Fired when the GuiObject is being focused on with the Gamepad selector

RBXScriptSignal

SelectionLost ( )

Fired when the Gamepad selector stops focusing on the GuiObject

RBXScriptSignal

TouchLongPress ( Array touchPositions , UserInputState state )

Fires when the player starts, continues and stops long-pressing the UI element

RBXScriptSignal

TouchPan ( Array touchPositions , Vector2 totalTranslation , Vector2 velocity , UserInputState state )

Fires when the player moves their finger on the UI element

RBXScriptSignal

TouchPinch ( Array touchPositions , float scale , float velocity , UserInputState state )

Fires when the player performs a pinch or pull gesture using two fingers on the UI element

RBXScriptSignal

TouchRotate ( Array touchPositions , float rotation , float velocity , UserInputState state )

Fires when the player performs a rotation gesture using two fingers on the UI element

RBXScriptSignal

TouchSwipe ( SwipeDirection swipeDirection , int numberOfTouches )

Fires when the player performs a swipe gesture on the UI element

RBXScriptSignal

TouchTap ( Array touchPositions )

Fires when the player performs a tap gesture on the UI element

Inherited from Instance: Show Hide

RBXScriptSignal

AncestryChanged ( Instance child , Instance parent )

Fires when the Instance/Parent property of the object or one of its ancestors is changed.

RBXScriptSignal

AttributeChanged ( string attribute )

Fires whenever an attribute is changed on the Instance

RBXScriptSignal

Changed ( string property )

Fired immediately after a property of an object changes.

RBXScriptSignal

ChildAdded ( Instance child )

Fires after an object is parented to this Instance.

RBXScriptSignal

ChildRemoved ( Instance child )

Fires after a child is removed from this Instance.

RBXScriptSignal

DescendantAdded ( Instance descendant )

Fires after a descendant is added to the Instance

RBXScriptSignal

DescendantRemoving ( Instance descendant )

Fires immediately before a descendant of the Instance is removed.

RBXScriptSignal

Destroying ( )

Fires immediately before the instance is destroyed via Instance/Destroy.

RBXScriptSignal

childAdded ( Instance child )

[Deprecated]

Code Samples


TextBox Secret Word

This code sample creates a password-like interface for a TextBox, giving visual feedback on the player’s input.