2021-11-18 15:19:54 +00:00
---
2021-04-02 17:42:19 +00:00
-- `openmw.ui` controls user interface.
2024-01-08 20:14:44 +00:00
-- Can be used only by menu scripts and local scripts, that are attached to a player.
2021-04-02 17:42:19 +00:00
-- @module ui
2021-11-18 15:19:54 +00:00
-- @usage
-- local ui = require('openmw.ui')
2021-04-02 17:42:19 +00:00
2021-11-18 15:19:54 +00:00
---
2022-02-06 20:22:38 +00:00
-- Widget types
-- @field [parent=#ui] #TYPE TYPE
2022-05-03 17:36:49 +00:00
---
-- Alignment values (details depend on the specific property). For horizontal alignment the order is left to right, for vertical alignment the order is top to bottom.
-- @type ALIGNMENT
-- @field Start
-- @field Center
-- @field End
2022-02-06 20:22:38 +00:00
---
-- Alignment values (left to right, top to bottom)
-- @field [parent=#ui] #ALIGNMENT ALIGNMENT
2021-04-02 17:42:19 +00:00
2021-12-14 17:38:06 +00:00
---
-- Tools for working with layers
-- @field [parent=#ui] #Layers layers
2021-11-18 15:19:54 +00:00
---
2022-02-06 20:22:38 +00:00
-- All available widget types
-- @type TYPE
-- @field Widget Base widget type
-- @field Text Display text
-- @field TextEdit Accepts user text input
-- @field Window Can be moved and resized by the user
2023-01-30 10:13:26 +00:00
-- @field Image Displays an image
-- @field Flex Aligns widgets in a row or column
-- @field Container Automatically wraps around its contents
2022-02-06 20:22:38 +00:00
2021-11-18 15:19:54 +00:00
---
2021-04-02 17:42:19 +00:00
-- Shows given message at the bottom of the screen.
-- @function [parent=#ui] showMessage
-- @param #string msg
2024-06-27 15:16:49 +00:00
-- @param #table options An optional table with additional optional arguments. Can contain:
--
-- * `showInDialogue` - If true, this message will only be shown in the dialogue window. If false, it will always be shown in a message box.
-- When omitted, the message will be displayed in the dialogue window if it is open and will be shown at the bottom of the screen otherwise.
-- @usage local params = {
-- showInDialogue=false
-- };
-- ui.showMessage("Hello world", params)
2021-04-02 17:42:19 +00:00
2022-04-09 21:07:57 +00:00
---
-- Predefined colors for console output
-- @field [parent=#ui] #CONSOLE_COLOR CONSOLE_COLOR
---
-- Predefined colors for console output
-- @type CONSOLE_COLOR
-- @field openmw.util#Color Default
-- @field openmw.util#Color Error
-- @field openmw.util#Color Success
-- @field openmw.util#Color Info
---
-- Print to the in-game console.
-- @function [parent=#ui] printToConsole
-- @param #string msg
-- @param openmw.util#Color color
---
-- Set mode of the in-game console.
-- The mode can be any string, by default is empty.
-- If not empty, then the console doesn't handle mwscript commands and
-- instead passes user input to Lua scripts via `onConsoleCommand` engine handler.
-- @function [parent=#ui] setConsoleMode
-- @param #string mode
---
-- Set selected object for console.
-- @function [parent=#ui] setConsoleSelectedObject
-- @param openmw.core#GameObject obj
2022-03-19 23:16:41 +00:00
---
-- Returns the size of the OpenMW window in pixels as a 2D vector.
-- @function [parent=#ui] screenSize
-- @return openmw.util#Vector2
2021-11-18 15:19:54 +00:00
---
-- Converts a given table of tables into an @{openmw.ui#Content}
-- @function [parent=#ui] content
-- @param #table table
-- @return #Content
---
-- Creates a UI element from the given layout table
-- @function [parent=#ui] create
-- @param #Layout layout
-- @return #Element
2022-02-01 18:26:05 +00:00
---
-- Adds a settings page to main menu setting's Scripts tab.
2022-02-02 14:27:48 +00:00
-- @function [parent=#ui] registerSettingsPage
2022-02-07 22:37:08 +00:00
-- @param #SettingsPageOptions page
2024-01-10 20:10:10 +00:00
---
-- Removes the settings page
-- @function [parent=#ui] removeSettingsPage
-- @param #SettingsPageOptions page must be the exact same table of options as the one passed to registerSettingsPage
2022-02-07 22:37:08 +00:00
---
-- Table with settings page options, passed as an argument to ui.registerSettingsPage
-- @type SettingsPageOptions
-- @field #string name Name of the page, displayed in the list, used for search
-- @field #string searchHints Additional keywords used in search, not displayed anywhere
2022-02-21 14:31:54 +00:00
-- @field #Element element The page's UI, which will be attached to the settings tab. The root widget has to have a fixed size. Set the `size` field in `props`, `relativeSize` is ignored.
2022-02-07 22:37:08 +00:00
2022-05-03 17:36:49 +00:00
---
-- Update all existing UI elements. Potentially extremely slow, so only call this when necessary, e. g. after overriding a template.
-- @function [parent=#ui] updateAll
2022-02-01 18:26:05 +00:00
2021-11-18 15:19:54 +00:00
---
-- Layout
-- @type Layout
2023-01-30 10:13:26 +00:00
-- @field type Type of the widget, one of the values in #TYPE. Must match the type in #Template if both are present
-- @field #string layer Optional layout to display in. Only applies for the root widget.
-- Note: if the #Element isn't attached to anything, it won't be visible!
2021-11-18 15:19:54 +00:00
-- @field #string name Optional name of the layout. Allows access by name from Content
-- @field #table props Optional table of widget properties
-- @field #table events Optional table of event callbacks
-- @field #Content content Optional @{openmw.ui#Content} of children layouts
2023-01-30 10:13:26 +00:00
-- @field #Template template Optional #Template
-- @field #table external Optional table of external properties
-- @field userData Arbitrary data for you to use, e. g. when receiving the layout in an event callback
---
-- Template
-- @type Template
-- @field #table props
-- @field #Content content
-- @field type One of the values in #TYPE, serves as the default value for the #Layout
2021-11-18 15:19:54 +00:00
2021-12-14 17:38:06 +00:00
---
2022-03-22 16:59:53 +00:00
-- @type Layer
-- @field #string name Name of the layer
2023-01-30 10:13:26 +00:00
-- @field openmw.util#Vector2 size Size of the layer in pixels
2022-03-22 16:59:53 +00:00
---
-- Layers. Implements [iterables#List](iterables.html#List) of #Layer.
2021-12-14 17:38:06 +00:00
-- @type Layers
2022-03-22 16:59:53 +00:00
-- @list <#Layer>
2021-12-14 17:38:06 +00:00
-- @usage
-- ui.layers.insertAfter('HUD', 'NewLayer', { interactive = true })
2022-03-22 16:59:53 +00:00
-- local fourthLayer = ui.layers[4]
2021-12-14 17:38:06 +00:00
-- local windowsIndex = ui.layers.indexOf('Windows')
2022-03-22 16:59:53 +00:00
-- for i, layer in ipairs(ui.layers) do
-- print('layer', i, layer.name, layer.size)
2022-02-21 20:43:27 +00:00
-- end
2021-12-14 17:38:06 +00:00
---
2022-05-18 03:22:12 +00:00
-- Index of the layer with the given name. Returns nil if the layer doesn't exist
2021-12-14 17:38:06 +00:00
-- @function [parent=#Layers] indexOf
-- @param #string name Name of the layer
-- @return #number, #nil index
---
-- Creates a layer and inserts it after another layer (shifts indexes of some other layers).
-- @function [parent=#Layers] insertAfter
-- @param #string afterName Name of the layer after which the new layer will be inserted
-- @param #string name Name of the new layer
-- @param #table options Table with a boolean `interactive` field (default is true). Layers with interactive = false will ignore all mouse interactions.
2022-03-22 16:59:53 +00:00
---
-- Creates a layer and inserts it before another layer (shifts indexes of some other layers).
-- @function [parent=#Layers] insertBefore
-- @param #string beforeName Name of the layer before which the new layer will be inserted
-- @param #string name Name of the new layer
-- @param #table options Table with a boolean `interactive` field (default is true). Layers with interactive = false will ignore all mouse interactions.
2021-11-18 15:19:54 +00:00
---
2022-02-21 20:43:27 +00:00
-- Content. An array-like container, which allows to reference elements by their name.
2023-11-11 15:00:56 +00:00
-- Implements [iterables#List](iterables.html#List) of #Layout or #Element and [iterables#Map](iterables.html#Map) of #string to #Layout or #Element.
2021-11-18 15:19:54 +00:00
-- @type Content
2023-11-11 15:00:56 +00:00
-- @list <#any>
2021-11-18 15:19:54 +00:00
-- @usage
-- local content = ui.content {
-- { name = 'input' },
-- }
-- -- bad idea!
-- -- content[1].name = 'otherInput'
-- -- do this instead:
-- content.input = { name = 'otherInput' }
-- @usage
-- local content = ui.content {
-- { name = 'display' },
-- { name = 'submit' },
-- }
-- -- allowed, but shifts all the items after it "up" the array
-- content.display = nil
-- -- still no holes after this!
-- @usage
-- -- iterate over a Content
-- for i = 1, #content do
-- print('widget',content[i].name,'at',i)
-- end
2023-01-30 22:29:00 +00:00
-- @usage
-- -- Note: layout names can collide with method names. Because of that you can't use a layout name such as "insert":
-- local content = ui.content {
-- { name = 'insert '}
-- }
-- content.insert.content = ui.content {} -- fails here, content.insert is a function!
2021-11-18 15:19:54 +00:00
2023-01-30 10:13:26 +00:00
---
-- Content also acts as a map of names to Layouts
-- @function [parent=#Content] __index
-- @param self
-- @param #string name
2023-11-11 15:00:56 +00:00
-- @return #any
2023-01-30 10:13:26 +00:00
2021-11-18 15:19:54 +00:00
---
-- Puts the layout at given index by shifting all the elements after it
-- @function [parent=#Content] insert
-- @param self
-- @param #number index
2023-11-11 15:00:56 +00:00
-- @param #any layoutOrElement
2021-11-18 15:19:54 +00:00
---
-- Adds the layout at the end of the Content
-- (same as calling insert with `last index + 1`)
-- @function [parent=#Content] add
-- @param self
2023-11-11 15:00:56 +00:00
-- @param #any layoutOrElement
2021-11-18 15:19:54 +00:00
---
-- Finds the index of the given layout. If it is not in the container, returns nil
-- @function [parent=#Content] indexOf
-- @param self
2023-11-11 15:00:56 +00:00
-- @param #any layoutOrElement
2021-11-18 15:19:54 +00:00
-- @return #number, #nil index
2021-04-02 17:42:19 +00:00
2021-11-18 15:19:54 +00:00
---
-- Element. An element of the user interface
-- @type Element
---
2023-11-24 19:41:54 +00:00
-- Refreshes the rendered element to match the current layout state.
-- Refreshes positions and sizes, but not the layout of the child Elements.
2021-11-18 15:19:54 +00:00
-- @function [parent=#Element] update
-- @param self
2023-11-24 19:41:54 +00:00
-- @usage
-- local child = ui.create {
-- type = ui.TYPE.Text,
-- props = {
-- text = 'child 1',
-- },
-- }
-- local parent = ui.create {
-- content = ui.content {
-- child,
-- {
-- type = ui.TYPE.Text,
-- props = {
-- text = 'parent 1',
-- },
-- }
-- }
-- }
-- -- ...
-- child.layout.props.text = 'child 2'
-- parent.layout.content[2].props.text = 'parent 2'
-- parent:update() -- will show 'parent 2', but 'child 1'
2021-11-18 15:19:54 +00:00
---
-- Destroys the element
-- @function [parent=#Element] destroy
-- @param self
---
-- Access or replace the element's layout
2023-02-26 12:54:07 +00:00
-- Note: Is reset to `nil` on `destroy`
2021-11-18 15:19:54 +00:00
-- @field [parent=#Element] #Layout layout
---
-- Mouse event, passed as an argument to relevant UI events
-- @type MouseEvent
-- @field openmw.util#Vector2 position Absolute position of the mouse cursor
-- @field openmw.util#Vector2 offset Position of the mouse cursor relative to the widget
2022-05-10 18:00:42 +00:00
-- @field #number button Mouse button which triggered the event.
-- Matches the arguments of @{openmw_input#input.isMouseButtonPressed} (`nil` for none, 1 for left, 3 for right).
2021-11-18 15:19:54 +00:00
2022-02-01 18:26:05 +00:00
---
2022-02-21 14:38:54 +00:00
-- Register a new texture resource. Can be used to manually atlas UI textures.
2023-01-30 10:13:26 +00:00
-- @function [parent=#ui] texture
2022-02-07 22:37:08 +00:00
-- @param #TextureResourceOptions options
2023-01-30 10:13:26 +00:00
-- @return #TextureResource
2022-02-21 14:38:54 +00:00
-- @usage
-- local ui = require('openmw.ui')
-- local vector2 = require('openmw.util').vector2
-- local myAtlas = 'textures/my_atlas.dds' -- a 128x128 atlas
-- local texture1 = ui.texture { -- texture in the top left corner of the atlas
-- path = myAtlas,
-- offset = vector2(0, 0),
-- size = vector2(64, 64),
-- }
-- local texture2 = ui.texture { -- texture in the top right corner of the atlas
-- path = myAtlas,
-- offset = vector2(64, 0),
-- size = vector2(64, 64),
-- }
2022-02-07 22:37:08 +00:00
---
-- A texture ready to be used by UI widgets
-- @type TextureResource
---
2022-02-21 14:38:54 +00:00
-- Table with arguments passed to ui.texture.
2022-02-07 22:37:08 +00:00
-- @type TextureResourceOptions
-- @field #string path Path to the texture file. Required
-- @field openmw.util#Vector2 offset Offset of this resource in the texture. (0, 0) by default
2022-02-21 14:38:54 +00:00
-- @field openmw.util#Vector2 size Size of the resource in the texture. (0, 0) by default. 0 means the whole texture size is used.
2022-02-01 18:26:05 +00:00
2021-11-18 15:19:54 +00:00
return nil