Skip to content

Global Structs and Enums

Structs

FontMetrics

FontMetrics

A structure to hold metrics of a font for a specified pixel size.

  • ascent (length): The distance between the baseline and the top of the tallest glyph in the font.
  • descent (length): The distance between the baseline and the bottom of the tallest glyph in the font. This is usually negative.
  • x_height (length): The distance between the baseline and the horizontal midpoint of the tallest glyph in the font, or zero if not specified by the font.
  • cap_height (length): The distance between the baseline and the top of a regular upper-case glyph in the font, or zero if not specified by the font.

KeyboardModifiers

KeyboardModifiers

The KeyboardModifiers struct provides booleans to indicate possible modifier keys on a keyboard, such as Shift, Control, etc. It is provided as part of KeyEvent’s modifiers field.

Keyboard shortcuts on Apple platforms typically use the Command key (⌘), such as Command+C for “Copy”. On other platforms the same shortcut is typically represented using Control+C. To make it easier to develop cross-platform applications, on macOS, Slint maps the Command key to the control modifier, and the Control key to the meta modifier.

On Windows, the Windows key is mapped to the meta modifier.

  • alt (bool): Indicates the Alt key on a keyboard.
  • control (bool): Indicates the Control key on a keyboard, except on macOS, where it is the Command key (⌘).
  • shift (bool): Indicates the Shift key on a keyboard.
  • meta (bool): Indicates the Control key on macos, and the Windows key on Windows.

KeyEvent

KeyEvent

This structure is generated and passed to the key press and release callbacks of the FocusScope element.

  • text (string): The unicode representation of the key pressed.
  • modifiers (KeyboardModifiers): The keyboard modifiers active at the time of the key press event.
  • repeat (bool): This field is set to true for key press events that are repeated, i.e. the key is held down. It’s always false for key release events.

Point

Point

This structure represents a point with x and y coordinate

  • x (length):
  • y (length):

PointerEvent

PointerEvent

Represents a Pointer event sent by the windowing system. This structure is passed to the pointer-event callback of the TouchArea element.

  • button (PointerEventButton): The button that was pressed or released
  • kind (PointerEventKind): The kind of the event
  • modifiers (KeyboardModifiers): The keyboard modifiers pressed during the event

PointerScrollEvent

PointerScrollEvent

Represents a Pointer scroll (or wheel) event sent by the windowing system. This structure is passed to the scroll-event callback of the TouchArea element.

  • delta_x (length): The amount of pixel in the horizontal direction
  • delta_y (length): The amount of pixel in the vertical direction
  • modifiers (KeyboardModifiers): The keyboard modifiers pressed during the event

StandardListViewItem

StandardListViewItem

Represents an item in a StandardListView and a StandardTableView.

  • text (string): The text content of the item

TableColumn

TableColumn

This is used to define the column and the column header of a TableView

  • title (string): The title of the column header
  • min_width (length): The minimum column width (logical length)
  • horizontal_stretch (float): The horizontal column stretch
  • sort_order (SortOrder): Sorts the column
  • width (length): the actual width of the column (logical length)

Enums

AccessibleRole

AccessibleRole

This enum represents the different values for the accessible-role property, used to describe the role of an element in the context of assistive technology such as screen readers.

  • none: The element isn’t accessible.
  • button: The element is a Button or behaves like one.
  • checkbox: The element is a CheckBox or behaves like one.
  • combobox: The element is a ComboBox or behaves like one.
  • groupbox: The element is a GroupBox or behaves like one.
  • list: The element is a ListView or behaves like one.
  • slider: The element is a Slider or behaves like one.
  • spinbox: The element is a SpinBox or behaves like one.
  • tab: The element is a Tab or behaves like one.
  • tab-list: The element is similar to the tab bar in a TabWidget.
  • tab-panel: The element is a container for tab content.
  • text: The role for a Text element. It’s automatically applied.
  • table: The role for a TableView or behaves like one.
  • tree: The role for a TreeView or behaves like one. (Not provided yet)
  • progress-indicator: The element is a ProgressIndicator or behaves like one.
  • text-input: The role for widget with editable text such as a LineEdit or a TextEdit
  • switch: The element is a Switch or behaves like one.
  • list-item: The element is an item in a ListView.

AnimationDirection

AnimationDirection

This enum describes the direction of an animation.

ColorScheme

ColorScheme

This enum indicates the color scheme used by the widget style. Use this to explicitly switch between dark and light schemes, or choose Unknown to fall back to the system default.

  • unknown: The scheme is not known and a system wide setting configures this. This could mean that the widgets are shown in a dark or light scheme, but it could also be a custom color scheme.
  • dark: The style chooses light colors for the background and dark for the foreground.
  • light: The style chooses dark colors for the background and light for the foreground.

DialogButtonRole

DialogButtonRole

This enum represents the value of the dialog-button-role property which can be added to any element within a Dialog to put that item in the button row, and its exact position depends on the role and the platform.

  • none: This isn’t a button meant to go into the bottom row
  • accept: This is the role of the main button to click to accept the dialog. e.g. “Ok” or “Yes”
  • reject: This is the role of the main button to click to reject the dialog. e.g. “Cancel” or “No”
  • apply: This is the role of the “Apply” button
  • reset: This is the role of the “Reset” button
  • help: This is the role of the “Help” button
  • action: This is the role of any other button that performs another action.

EventResult

EventResult

This enum describes whether an event was rejected or accepted by an event handler.

  • reject: The event is rejected by this event handler and may then be handled by the parent item
  • accept: The event is accepted and won’t be processed further

FillRule

FillRule

This enum describes the different ways of deciding what the inside of a shape described by a path shall be.

ImageFit

ImageFit

This enum defines how the source image shall fit into an Image element.

  • fill: Scales and stretches the source image to fit the width and height of the Image element.
  • contain: The source image is scaled to fit into the Image element’s dimension while preserving the aspect ratio.
  • cover: The source image is scaled to cover into the Image element’s dimension while preserving the aspect ratio. If the aspect ratio of the source image doesn’t match the element’s one, then the image will be clipped to fit.
  • preserve: Preserves the size of the source image in logical pixels. The source image will still be scaled by the scale factor that applies to all elements in the window. Any extra space will be left blank.

ImageHorizontalAlignment

ImageHorizontalAlignment

This enum specifies the horizontal alignment of the source image.

  • center: Aligns the source image at the center of the Image element.
  • left: Aligns the source image at the left of the Image element.
  • right: Aligns the source image at the right of the Image element.

ImageRendering

ImageRendering

This enum specifies how the source image will be scaled.

  • smooth: The image is scaled with a linear interpolation algorithm.
  • pixelated: The image is scaled with the nearest neighbor algorithm.

ImageTiling

ImageTiling

This enum specifies how the source image will be tiled.

  • none: The source image will not be tiled.
  • repeat: The source image will be repeated to fill the Image element.
  • round: The source image will be repeated and scaled to fill the Image element, ensuring an integer number of repetitions.

ImageVerticalAlignment

ImageVerticalAlignment

This enum specifies the vertical alignment of the source image.

  • center: Aligns the source image at the center of the Image element.
  • top: Aligns the source image at the top of the Image element.
  • bottom: Aligns the source image at the bottom of the Image element.

InputType

InputType

This enum is used to define the type of the input field.

  • text: The default value. This will render all characters normally
  • password: This will render all characters with a character that defaults to ”*”
  • number: This will only accept and render number characters (0-9)
  • decimal: This will accept and render characters if it’s valid part of a decimal

LayoutAlignment

LayoutAlignment

Enum representing the alignment property of a HorizontalBox, a VerticalBox, a HorizontalLayout, or VerticalLayout.

  • stretch: Use the minimum size of all elements in a layout, distribute remaining space based on *-stretch among all elements.
  • center: Use the preferred size for all elements, distribute remaining space evenly before the first and after the last element.
  • start: Use the preferred size for all elements, put remaining space after the last element.
  • end: Use the preferred size for all elements, put remaining space before the first element.
  • space-between: Use the preferred size for all elements, distribute remaining space evenly between elements.
  • space-around: Use the preferred size for all elements, distribute remaining space evenly before the first element, after the last element and between elements.

MouseCursor

MouseCursor

This enum represents different types of mouse cursors. It’s a subset of the mouse cursors available in CSS. For details and pictograms see the MDN Documentation for cursor. Depending on the backend and used OS unidirectional resize cursors may be replaced with bidirectional ones.

  • default: The systems default cursor.
  • none: No cursor is displayed.
  • help: A cursor indicating help information.
  • pointer: A pointing hand indicating a link.
  • progress: The program is busy but can still be interacted with.
  • wait: The program is busy.
  • crosshair: A crosshair.
  • text: A cursor indicating selectable text.
  • alias: An alias or shortcut is being created.
  • copy: A copy is being created.
  • move: Something is to be moved.
  • no-drop: Something can’t be dropped here.
  • not-allowed: An action isn’t allowed
  • grab: Something is grabbable.
  • grabbing: Something is being grabbed.
  • col-resize: Indicating that a column is resizable horizontally.
  • row-resize: Indicating that a row is resizable vertically.
  • n-resize: Unidirectional resize north.
  • e-resize: Unidirectional resize east.
  • s-resize: Unidirectional resize south.
  • w-resize: Unidirectional resize west.
  • ne-resize: Unidirectional resize north-east.
  • nw-resize: Unidirectional resize north-west.
  • se-resize: Unidirectional resize south-east.
  • sw-resize: Unidirectional resize south-west.
  • ew-resize: Bidirectional resize east-west.
  • ns-resize: Bidirectional resize north-south.
  • nesw-resize: Bidirectional resize north-east-south-west.
  • nwse-resize: Bidirectional resize north-west-south-east.

Orientation

Orientation

Represents the orientation of an element or widget such as the Slider.

  • horizontal: Element is oriented horizontally.
  • vertical: Element is oriented vertically.

PathEvent

PathEvent

PathEvent is a low-level data structure describing the composition of a path. Typically it is generated at compile time from a higher-level description, such as SVG commands.

  • begin: The beginning of the path.
  • line: A straight line on the path.
  • quadratic: A quadratic bezier curve on the path.
  • cubic: A cubic bezier curve on the path.
  • end-open: The end of the path that remains open.
  • end-closed: The end of a path that is closed.

PointerEventButton

PointerEventButton

This enum describes the different types of buttons for a pointer event, typically on a mouse or a pencil.

  • other: A button that is none of left, right, middle, back or forward. For example, this is used for the task button on a mouse with many buttons.
  • left: The left button.
  • right: The right button.
  • middle: The center button.
  • back: The back button.
  • forward: The forward button.

PointerEventKind

PointerEventKind

The enum reports what happened to the PointerEventButton in the event

  • cancel: The action was cancelled.
  • down: The button was pressed.
  • up: The button was released.
  • move: The pointer has moved,

PopupClosePolicy

PopupClosePolicy

  • close-on-click: Closes the PopupWindow when user clicks or presses the escape key.
  • close-on-click-outside: Closes the PopupWindow when user clicks outside of the popup or presses the escape key.
  • no-auto-close: Does not close the PopupWindow automatically when user clicks.

ScrollBarPolicy

ScrollBarPolicy

This enum describes the scrollbar visibility

  • as-needed: Scrollbar will be visible only when needed
  • always-off: Scrollbar never shown
  • always-on: Scrollbar always visible

SortOrder

SortOrder

This enum represents the different values of the sort-order property. It’s used to sort a StandardTableView by a column.

  • unsorted: The column is unsorted.
  • ascending: The column is sorted in ascending order.
  • descending: The column is sorted in descending order.

StandardButtonKind

StandardButtonKind

Use this enum to add standard buttons to a Dialog. The look and positioning of these StandardButtons depends on the environment (OS, UI environment, etc.) the application runs in.

  • ok: A “OK” button that accepts a Dialog, closing it when clicked.
  • cancel: A “Cancel” button that rejects a Dialog, closing it when clicked.
  • apply: A “Apply” button that should accept values from a Dialog without closing it.
  • close: A “Close” button, which should close a Dialog without looking at values.
  • reset: A “Reset” button, which should reset the Dialog to its initial state.
  • help: A “Help” button, which should bring up context related documentation when clicked.
  • yes: A “Yes” button, used to confirm an action.
  • no: A “No” button, used to deny an action.
  • abort: A “Abort” button, used to abort an action.
  • retry: A “Retry” button, used to retry a failed action.
  • ignore: A “Ignore” button, used to ignore a failed action.

TextHorizontalAlignment

TextHorizontalAlignment

This enum describes the different types of alignment of text along the horizontal axis of a Text element.

  • left: The text will be aligned with the left edge of the containing box.
  • center: The text will be horizontally centered within the containing box.
  • right: The text will be aligned to the right of the containing box.

TextOverflow

TextOverflow

This enum describes the how the text appear if it is too wide to fit in the Text width.

  • clip: The text will simply be clipped.
  • elide: The text will be elided with .

TextStrokeStyle

TextStrokeStyle

This enum describes the positioning of a text stroke relative to the border of the glyphs in a Text.

  • outside: The inside edge of the stroke is at the outer edge of the text.
  • center: The center line of the stroke is at the outer edge of the text, like in Adobe Illustrator.

TextVerticalAlignment

TextVerticalAlignment

This enum describes the different types of alignment of text along the vertical axis of a Text element.

  • top: The text will be aligned to the top of the containing box.
  • center: The text will be vertically centered within the containing box.
  • bottom: The text will be aligned to the bottom of the containing box.

TextWrap

TextWrap

This enum describes the how the text wrap if it is too wide to fit in the Text width.

  • no-wrap: The text won’t wrap, but instead will overflow.
  • word-wrap: The text will be wrapped at word boundaries if possible, or at any location for very long words.
  • char-wrap: The text will be wrapped at any character. Currently only supported by the Qt and Software renderers.

© 2025 SixtyFPS GmbH