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 releasedkind
(PointerEventKind): The kind of the eventmodifiers
(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 directiondelta_y
(length): The amount of pixel in the vertical directionmodifiers
(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 headermin_width
(length): The minimum column width (logical length)horizontal_stretch
(float): The horizontal column stretchsort_order
(SortOrder): Sorts the columnwidth
(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 aButton
or behaves like one.checkbox
: The element is aCheckBox
or behaves like one.combobox
: The element is aComboBox
or behaves like one.groupbox
: The element is aGroupBox
or behaves like one.list
: The element is aListView
or behaves like one.slider
: The element is aSlider
or behaves like one.spinbox
: The element is aSpinBox
or behaves like one.tab
: The element is aTab
or behaves like one.tab-list
: The element is similar to the tab bar in aTabWidget
.tab-panel
: The element is a container for tab content.text
: The role for aText
element. It’s automatically applied.table
: The role for aTableView
or behaves like one.tree
: The role for a TreeView or behaves like one. (Not provided yet)progress-indicator
: The element is aProgressIndicator
or behaves like one.text-input
: The role for widget with editable text such as aLineEdit
or aTextEdit
switch
: The element is aSwitch
or behaves like one.list-item
: The element is an item in aListView
.
AnimationDirection
AnimationDirection
This enum describes the direction of an animation.
normal
: The “normal” direction as defined in CSS ↗.reverse
: The “reverse” direction as defined in CSS ↗.alternate
: The “alternate” direction as defined in CSS ↗.alternate-reverse
: The “alternate reverse” direction as defined in CSS ↗.
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 rowaccept
: 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” buttonreset
: This is the role of the “Reset” buttonhelp
: This is the role of the “Help” buttonaction
: 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 itemaccept
: 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.
nonzero
: The “nonzero” fill rule as defined in SVG ↗.evenodd
: The “evenodd” fill rule as defined in SVG ↗
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 theImage
element.contain
: The source image is scaled to fit into theImage
element’s dimension while preserving the aspect ratio.cover
: The source image is scaled to cover into theImage
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 theImage
element.left
: Aligns the source image at the left of theImage
element.right
: Aligns the source image at the right of theImage
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 theImage
element.round
: The source image will be repeated and scaled to fill theImage
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 theImage
element.top
: Aligns the source image at the top of theImage
element.bottom
: Aligns the source image at the bottom of theImage
element.
InputType
InputType
This enum is used to define the type of the input field.
text
: The default value. This will render all characters normallypassword
: 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 allowedgrab
: 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 thePopupWindow
when user clicks or presses the escape key.close-on-click-outside
: Closes thePopupWindow
when user clicks outside of the popup or presses the escape key.no-auto-close
: Does not close thePopupWindow
automatically when user clicks.
ScrollBarPolicy
ScrollBarPolicy
This enum describes the scrollbar visibility
as-needed
: Scrollbar will be visible only when neededalways-off
: Scrollbar never shownalways-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 StandardButton
s depends on the environment
(OS, UI environment, etc.) the application runs in.
ok
: A “OK” button that accepts aDialog
, closing it when clicked.cancel
: A “Cancel” button that rejects aDialog
, closing it when clicked.apply
: A “Apply” button that should accept values from aDialog
without closing it.close
: A “Close” button, which should close aDialog
without looking at values.reset
: A “Reset” button, which should reset theDialog
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