TextBox

__init__(
    self,
    master,
    text="",
    width=10,
    height=1,
    grid=None,
    align=None,
    visible=True,
    enabled=None,
    multiline=False,
    scrollbar=False,
    command=None,
    hide_text=False)

What is it

The TextBox object displays a text box which the user can type in.

TextBox on Windows

How do I make one?

Create a TextBox object like this:

from guizero import App, TextBox
app = App()
input_box = TextBox(app)
app.display()

Starting parameters

When you create a TextBox object you must specify master and you can specify any of the optional parameters. Specify parameters in the brackets, like this: textbox = TextBox(app, text="Please enter some text")

Parameter Data type Default Compulsory Description
master App, Window or Box - Yes The container to which this widget belongs
align string None - Alignment of this widget within its container. Possible values: "top", "bottom", "left", "right".
grid List [int, int] None - [x,y] coordinates of this widget. This parameter is only required if the master object has a grid layout.
text string "" - Any text you wish to be pre-filled in the text box
width int 10 - Set the width of the widget in characters or to "fill"
height int 1 - Set the height of the widget in characters or to "fill", only effective if multiline is True
visible boolean True No If the widget should be visible.
enabled boolean None No If the widget should be enabled. If None (the default) the enabled property will be inherited from the master
multiline boolean False No Create a multi-line text box.
scrollbar boolean False No Add a vertical scrollbar to a multi-line text box
command function name None - The name of a function to call when the text is changed. This function MUST take either zero or one argument, if the function takes one argument the key which was added to the textbox will be returned.
hide_text boolean False - When set to True will hide the text replacing typed characters with *. Setting to a character will result in the text being hidden with that character.

Methods

You can call the following methods on your TextBox object.

Method Takes Returns Description
after(time, command, args=None) time (int), command (function name), args (list of arguments) - Schedules a single call to command after time milliseconds. (To repeatedly call the same command, use repeat())
append(text) text (string) - Adds the provided text to the end of the current text within the text box
cancel(command) command (function name) - Cancels a scheduled call to command
clear() - - Clears the textbox
destroy() - - Destroys the widget
disable() - - Disables the widget so that it is "greyed out" and cannot be interacted with
enable() - - Enables the widget
focus() - - Gives focus to the widget (e.g. focusing a TextBox so that the user can type inside it)
hide() - - Hides the widget from view. This method will unpack the widget from the layout manager.
repeat(time, command, args=None) time (int), command (function name), args (list of arguments) - Repeats command every time milliseconds. This is useful for scheduling a function to be regularly called, for example updating a value read from a sensor.
resize(width, height) width (int), height (int) - Sets the width and height of the widget
show() - - Displays the widget if it was previously hidden
update_command(command) command (function name) - Updates the function to call when the text is changed.

Properties

You can set and get the following properties:

Method Data type Description
align string The alignment of this widget within its container
bg color The background colour of the widget
cursor_position int The current position of the cursor
enabled boolean True if the widget is enabled
font string The font of the text
grid List [x,y] coordinates of this widget. This parameter is only required if the master object has a grid
height size Set the height of the widget in characters or to "fill", only effective if multiline is True
hide_text boolean / char When set to True will hide the text replacing typed characters with *. Setting to a character will result in the text being hidden with that character.
master App or Box The container to which this widget belongs
value string The text in the TextBox
visible boolean If this widget is visible
width size Set the width of the widget in characters or to "fill"
text_size int The size of the text
text_bold boolean Whether the text is bold
text_italic boolean Whether the text is italic
text_underline boolean Whether the text is underlined
text_overstrike boolean Whether the text is overstruck
tk tkinter.Entry The internal tkinter object, see Using tkinter
wrap boolean Whether text in a multiline text box should be wrapped. Defaults to True. If its a single line TextBox, None will be returned and a warning displayed when trying to set.

Examples

Creating a TextBox with default text

You can set the default text in a TextBox when it is created using the text parameter:

from guizero import App, TextBox
app = App()
input_box = TextBox(app, text="Type here")
app.display()

Creating a password TextBox with hidden text

You can hide the text in a TextBox using the hide_text parameter:

from guizero import App, TextBox
app = App()
password_box = TextBox(app, hide_text=True)
app.display()

Creating a multi-line TextBox

You can create a text box which is capable of capturing multiple lines of text by setting the multiline parameter to True and giving the textbox a height:

from guizero import App, TextBox
app = App()
input_box = TextBox(app, text="Type lines here", height=10, multiline=True)
app.display()

Multi-line text boxes can also be given a scrollbar by setting the scrollbar parameter to True:

input_box = TextBox(app, text="Type lines here", height=10, multiline=True, scrollbar=True)