2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-04-02 19:42:19 +02:00
|
|
|
-- `openmw.util` defines utility functions and classes like 3D vectors, that don't depend on the game world.
|
|
|
|
-- @module util
|
|
|
|
-- @usage local util = require('openmw.util')
|
|
|
|
|
|
|
|
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-09-19 14:43:15 +02:00
|
|
|
-- Limits given value to the interval [`from`, `to`].
|
2021-04-02 19:42:19 +02:00
|
|
|
-- @function [parent=#util] clamp
|
|
|
|
-- @param #number value
|
|
|
|
-- @param #number from
|
|
|
|
-- @param #number to
|
|
|
|
-- @return #number min(max(value, from), to)
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-09-19 14:43:15 +02:00
|
|
|
-- Adds `2pi*k` and puts the angle in range `[-pi, pi]`.
|
2021-04-02 19:42:19 +02:00
|
|
|
-- @function [parent=#util] normalizeAngle
|
|
|
|
-- @param #number angle Angle in radians
|
|
|
|
-- @return #number Angle in range `[-pi, pi]`
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-12-14 00:36:26 +01:00
|
|
|
-- Makes a table read only.
|
|
|
|
-- @function [parent=#util] makeReadOnly
|
|
|
|
-- @param #table table Any table.
|
|
|
|
-- @return #table The same table wrapped with read only userdata.
|
|
|
|
|
2022-05-16 00:16:26 +02:00
|
|
|
---
|
|
|
|
-- Makes a table read only and overrides `__index` with the strict version that throws an error if the key is not found.
|
|
|
|
-- @function [parent=#util] makeStrictReadOnly
|
|
|
|
-- @param #table table Any table.
|
|
|
|
-- @return #table The same table wrapped with read only userdata.
|
|
|
|
|
2022-04-09 20:52:05 +02:00
|
|
|
---
|
|
|
|
-- Parses Lua code from string and returns as a function.
|
|
|
|
-- @function [parent=#util] loadCode
|
|
|
|
-- @param #string code Lua code.
|
|
|
|
-- @param #table table Environment to run the code in.
|
|
|
|
-- @return #function The loaded code.
|
|
|
|
|
2022-04-03 20:07:09 +02:00
|
|
|
---
|
|
|
|
-- Bitwise And (supports any number of arguments).
|
|
|
|
-- @function [parent=#util] bitAnd
|
|
|
|
-- @param #number A First argument (integer).
|
|
|
|
-- @param #number B Second argument (integer).
|
|
|
|
-- @return #number Bitwise And of A and B.
|
|
|
|
|
|
|
|
---
|
|
|
|
-- Bitwise Or (supports any number of arguments).
|
|
|
|
-- @function [parent=#util] bitOr
|
|
|
|
-- @param #number A First argument (integer).
|
|
|
|
-- @param #number B Second argument (integer).
|
|
|
|
-- @return #number Bitwise Or of A and B.
|
|
|
|
|
|
|
|
---
|
|
|
|
-- Bitwise Xor (supports any number of arguments).
|
|
|
|
-- @function [parent=#util] bitXor
|
|
|
|
-- @param #number A First argument (integer).
|
|
|
|
-- @param #number B Second argument (integer).
|
|
|
|
-- @return #number Bitwise Xor of A and B.
|
|
|
|
|
|
|
|
---
|
|
|
|
-- Bitwise inversion.
|
|
|
|
-- @function [parent=#util] bitNot
|
|
|
|
-- @param #number A Argument (integer).
|
|
|
|
-- @return #number Bitwise Not of A.
|
|
|
|
|
2021-04-02 19:42:19 +02:00
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-04-02 19:42:19 +02:00
|
|
|
-- Immutable 2D vector
|
|
|
|
-- @type Vector2
|
|
|
|
-- @field #number x
|
|
|
|
-- @field #number y
|
|
|
|
-- @usage
|
|
|
|
-- v = util.vector2(3, 4)
|
|
|
|
-- v.x, v.y -- 3.0, 4.0
|
|
|
|
-- str(v) -- "(3.0, 4.0)"
|
|
|
|
-- v:length() -- 5.0 length
|
|
|
|
-- v:length2() -- 25.0 square of the length
|
|
|
|
-- v:normalize() -- vector2(3/5, 4/5)
|
2021-11-18 15:11:39 +01:00
|
|
|
-- v:rotate(radians) -- rotate counterclockwise (returns rotated vector)
|
2021-04-02 19:42:19 +02:00
|
|
|
-- v1:dot(v2) -- dot product (returns a number)
|
|
|
|
-- v1 * v2 -- dot product
|
|
|
|
-- v1 + v2 -- vector addition
|
|
|
|
-- v1 - v2 -- vector subtraction
|
|
|
|
-- v1 * x -- multiplication by a number
|
|
|
|
-- v1 / x -- division by a number
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-04-02 19:42:19 +02:00
|
|
|
-- Creates a new 2D vector. Vectors are immutable and can not be changed after creation.
|
|
|
|
-- @function [parent=#util] vector2
|
|
|
|
-- @param #number x.
|
|
|
|
-- @param #number y.
|
|
|
|
-- @return #Vector2.
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-09-19 14:43:15 +02:00
|
|
|
-- Length of the vector.
|
2021-04-02 19:42:19 +02:00
|
|
|
-- @function [parent=#Vector2] length
|
|
|
|
-- @param self
|
|
|
|
-- @return #number
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-09-19 14:43:15 +02:00
|
|
|
-- Square of the length of the vector.
|
2021-04-02 19:42:19 +02:00
|
|
|
-- @function [parent=#Vector2] length2
|
|
|
|
-- @param self
|
|
|
|
-- @return #number
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-04-02 19:42:19 +02:00
|
|
|
-- Normalizes vector.
|
|
|
|
-- Returns two values: normalized vector and the length of the original vector.
|
|
|
|
-- It doesn't change the original vector.
|
|
|
|
-- @function [parent=#Vector2] normalize
|
|
|
|
-- @param self
|
|
|
|
-- @return #Vector2, #number
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-04-02 19:42:19 +02:00
|
|
|
-- Rotates 2D vector clockwise.
|
|
|
|
-- @function [parent=#Vector2] rotate
|
|
|
|
-- @param self
|
|
|
|
-- @param #number angle Angle in radians
|
|
|
|
-- @return #Vector2 Rotated vector.
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-04-02 19:42:19 +02:00
|
|
|
-- Dot product.
|
|
|
|
-- @function [parent=#Vector2] dot
|
|
|
|
-- @param self
|
|
|
|
-- @param #Vector2 v
|
|
|
|
-- @return #number
|
|
|
|
|
2022-02-10 19:43:27 +00:00
|
|
|
---
|
|
|
|
-- Element-wise multiplication
|
|
|
|
-- @function [parent=#Vector2] emul
|
|
|
|
-- @param self
|
|
|
|
-- @param #Vector2 v
|
|
|
|
-- @return #Vector2
|
|
|
|
|
|
|
|
---
|
|
|
|
-- Element-wise division
|
|
|
|
-- @function [parent=#Vector2] ediv
|
|
|
|
-- @param self
|
|
|
|
-- @param #Vector2 v
|
|
|
|
-- @return #Vector2
|
|
|
|
|
2021-04-02 19:42:19 +02:00
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-04-02 19:42:19 +02:00
|
|
|
-- Immutable 3D vector
|
|
|
|
-- @type Vector3
|
|
|
|
-- @field #number x
|
|
|
|
-- @field #number y
|
|
|
|
-- @field #number z
|
|
|
|
-- @usage
|
|
|
|
-- v = util.vector3(3, 4, 5)
|
|
|
|
-- v.x, v.y, v.z -- 3.0, 4.0, 5.0
|
|
|
|
-- str(v) -- "(3.0, 4.0, 4.5)"
|
|
|
|
-- v:length() -- length
|
|
|
|
-- v:length2() -- square of the length
|
|
|
|
-- v:normalize() -- normalized vector
|
|
|
|
-- v1:dot(v2) -- dot product (returns a number)
|
|
|
|
-- v1 * v2 -- dot product (returns a number)
|
|
|
|
-- v1:cross(v2) -- cross product (returns a vector)
|
|
|
|
-- v1 ^ v2 -- cross product (returns a vector)
|
|
|
|
-- v1 + v2 -- vector addition
|
|
|
|
-- v1 - v2 -- vector subtraction
|
|
|
|
-- v1 * x -- multiplication by a number
|
|
|
|
-- v1 / x -- division by a number
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-04-02 19:42:19 +02:00
|
|
|
-- Creates a new 3D vector. Vectors are immutable and can not be changed after creation.
|
|
|
|
-- @function [parent=#util] vector3
|
|
|
|
-- @param #number x.
|
|
|
|
-- @param #number y.
|
|
|
|
-- @param #number z.
|
|
|
|
-- @return #Vector3.
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-04-02 19:42:19 +02:00
|
|
|
-- Length of the vector
|
|
|
|
-- @function [parent=#Vector3] length
|
|
|
|
-- @param self
|
|
|
|
-- @return #number
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-04-02 19:42:19 +02:00
|
|
|
-- Square of the length of the vector
|
|
|
|
-- @function [parent=#Vector3] length2
|
|
|
|
-- @param self
|
|
|
|
-- @return #number
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-04-02 19:42:19 +02:00
|
|
|
-- Normalizes vector.
|
|
|
|
-- Returns two values: normalized vector and the length of the original vector.
|
2022-01-17 22:35:06 +00:00
|
|
|
-- It doesn't change the original vector.
|
2021-04-02 19:42:19 +02:00
|
|
|
-- @function [parent=#Vector3] normalize
|
|
|
|
-- @param self
|
|
|
|
-- @return #Vector3, #number
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-04-02 19:42:19 +02:00
|
|
|
-- Dot product.
|
|
|
|
-- @function [parent=#Vector3] dot
|
|
|
|
-- @param self
|
|
|
|
-- @param #Vector3 v
|
|
|
|
-- @return #number
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-04-02 19:42:19 +02:00
|
|
|
-- Cross product.
|
|
|
|
-- @function [parent=#Vector3] cross
|
|
|
|
-- @param self
|
|
|
|
-- @param #Vector3 v
|
|
|
|
-- @return #Vector3
|
|
|
|
|
2022-02-10 19:43:27 +00:00
|
|
|
---
|
|
|
|
-- Element-wise multiplication
|
|
|
|
-- @function [parent=#Vector3] emul
|
|
|
|
-- @param self
|
|
|
|
-- @param #Vector3 v
|
|
|
|
-- @return #Vector3
|
|
|
|
|
|
|
|
---
|
|
|
|
-- Element-wise division
|
|
|
|
-- @function [parent=#Vector3] ediv
|
|
|
|
-- @param self
|
|
|
|
-- @param #Vector3 v
|
|
|
|
-- @return #Vector3
|
|
|
|
|
2022-01-17 22:35:06 +00:00
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2022-01-17 22:35:06 +00:00
|
|
|
-- Immutable 4D vector.
|
|
|
|
-- @type Vector4
|
|
|
|
-- @field #number x
|
|
|
|
-- @field #number y
|
|
|
|
-- @field #number z
|
|
|
|
-- @field #number w
|
|
|
|
-- @usage
|
|
|
|
-- v = util.vector4(3, 4, 5, 6)
|
|
|
|
-- v.x, v.y, v.z, v.w -- 3.0, 4.0, 5.0, 6.0
|
|
|
|
-- str(v) -- "(3.0, 4.0, 5.0, 6.0)"
|
|
|
|
-- v:length() -- length
|
|
|
|
-- v:length2() -- square of the length
|
|
|
|
-- v:normalize() -- normalized vector
|
|
|
|
-- v1:dot(v2) -- dot product (returns a number)
|
|
|
|
-- v1 * v2 -- dot product (returns a number)
|
|
|
|
-- v1 + v2 -- vector addition
|
|
|
|
-- v1 - v2 -- vector subtraction
|
|
|
|
-- v1 * x -- multiplication by a number
|
|
|
|
-- v1 / x -- division by a number
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2022-01-17 22:35:06 +00:00
|
|
|
-- Creates a new 4D vector. Vectors are immutable and can not be changed after creation.
|
|
|
|
-- @function [parent=#util] vector4
|
|
|
|
-- @param #number x.
|
|
|
|
-- @param #number y.
|
|
|
|
-- @param #number z.
|
|
|
|
-- @param #number w.
|
|
|
|
-- @return #Vector4.
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2022-01-17 22:35:06 +00:00
|
|
|
-- Length of the vector
|
|
|
|
-- @function [parent=#Vector4] length
|
|
|
|
-- @param self
|
|
|
|
-- @return #number
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2022-01-17 22:35:06 +00:00
|
|
|
-- Square of the length of the vector
|
|
|
|
-- @function [parent=#Vector4] length2
|
|
|
|
-- @param self
|
|
|
|
-- @return #number
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2022-01-17 22:35:06 +00:00
|
|
|
-- Normalizes vector.
|
|
|
|
-- Returns two values: normalized vector and the length of the original vector.
|
|
|
|
-- It doesn't change the original vector.
|
|
|
|
-- @function [parent=#Vector4] normalize
|
|
|
|
-- @param self
|
|
|
|
-- @return #Vector4, #number
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2022-01-17 22:35:06 +00:00
|
|
|
-- Dot product.
|
|
|
|
-- @function [parent=#Vector4] dot
|
|
|
|
-- @param self
|
|
|
|
-- @param #Vector4 v
|
|
|
|
-- @return #number
|
|
|
|
|
2022-02-10 19:43:27 +00:00
|
|
|
---
|
|
|
|
-- Element-wise multiplication
|
|
|
|
-- @function [parent=#Vector4] emul
|
|
|
|
-- @param self
|
|
|
|
-- @param #Vector4 v
|
|
|
|
-- @return #Vector4
|
|
|
|
|
|
|
|
---
|
|
|
|
-- Element-wise division
|
|
|
|
-- @function [parent=#Vector4] ediv
|
|
|
|
-- @param self
|
|
|
|
-- @param #Vector4 v
|
|
|
|
-- @return #Vector4
|
|
|
|
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2022-01-17 22:35:06 +00:00
|
|
|
-- Color in RGBA format. All of the component values are in the range [0, 1].
|
|
|
|
-- @type Color
|
|
|
|
-- @field #number r Red component
|
|
|
|
-- @field #number g Green component
|
|
|
|
-- @field #number b Blue component
|
|
|
|
-- @field #number a Alpha (transparency) component
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2022-01-17 22:35:06 +00:00
|
|
|
-- Returns a Vector4 with RGBA components of the Color.
|
|
|
|
-- @function [parent=#Color] asRgba
|
|
|
|
-- @param self
|
|
|
|
-- @return #Vector4
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2022-01-17 22:35:06 +00:00
|
|
|
-- Returns a Vector3 with RGB components of the Color.
|
|
|
|
-- @function [parent=#Color] asRgb
|
|
|
|
-- @param self
|
|
|
|
-- @return #Vector3
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2022-01-17 22:35:06 +00:00
|
|
|
-- Converts the color into a HEX string.
|
|
|
|
-- @function [parent=#Color] asHex
|
|
|
|
-- @param self
|
|
|
|
-- @return #string
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
|
|
|
-- Methods for creating #Color values from different formats.
|
2022-01-17 22:35:06 +00:00
|
|
|
-- @type COLOR
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
|
|
|
-- Methods for creating #Color values from different formats.
|
|
|
|
-- @field [parent=#util] #COLOR color
|
|
|
|
|
|
|
|
---
|
2022-01-17 22:35:06 +00:00
|
|
|
-- Creates a Color from RGBA format
|
|
|
|
-- @function [parent=#COLOR] rgba
|
|
|
|
-- @param #number r
|
|
|
|
-- @param #number g
|
|
|
|
-- @param #number b
|
|
|
|
-- @param #number a
|
|
|
|
-- @return #Color
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2022-01-17 22:35:06 +00:00
|
|
|
-- Creates a Color from RGB format. Equivalent to calling util.rgba with a = 1.
|
|
|
|
-- @function [parent=#COLOR] rgb
|
|
|
|
-- @param #number r
|
|
|
|
-- @param #number g
|
|
|
|
-- @param #number b
|
|
|
|
-- @return #Color
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2022-01-17 22:35:06 +00:00
|
|
|
-- Parses a hex color string into a Color.
|
|
|
|
-- @function [parent=#COLOR] hex
|
|
|
|
-- @param #string hex A hex color string in RRGGBB format (e. g. "ff0000").
|
|
|
|
-- @return #Color
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-09-19 14:43:15 +02:00
|
|
|
-- @type Transform
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-09-19 14:43:15 +02:00
|
|
|
-- Returns the inverse transform.
|
|
|
|
-- @function [parent=#Transform] inverse
|
|
|
|
-- @param self
|
|
|
|
-- @return #Transform.
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-09-19 14:43:15 +02:00
|
|
|
-- @type TRANSFORM
|
|
|
|
-- @field [parent=#TRANSFORM] #Transform identity Empty transform.
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-09-19 14:43:15 +02:00
|
|
|
-- Movement by given vector.
|
|
|
|
-- @function [parent=#TRANSFORM] move
|
|
|
|
-- @param #Vector3 offset.
|
|
|
|
-- @return #Transform.
|
|
|
|
-- @usage
|
|
|
|
-- -- Accepts either 3 numbers or a 3D vector
|
|
|
|
-- util.transform.move(x, y, z)
|
|
|
|
-- util.transform.move(util.vector3(x, y, z))
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-09-19 14:43:15 +02:00
|
|
|
-- Scale transform.
|
|
|
|
-- @function [parent=#TRANSFORM] scale
|
|
|
|
-- @param #number scaleX.
|
|
|
|
-- @param #number scaleY.
|
|
|
|
-- @param #number scaleZ.
|
|
|
|
-- @return #Transform.
|
|
|
|
-- @usage
|
|
|
|
-- -- Accepts either 3 numbers or a 3D vector
|
|
|
|
-- util.transform.scale(x, y, z)
|
|
|
|
-- util.transform.scale(util.vector3(x, y, z))
|
|
|
|
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-11-18 15:11:39 +01:00
|
|
|
-- Rotation around a vector (counterclockwise if the vector points to us).
|
2021-09-19 14:43:15 +02:00
|
|
|
-- @function [parent=#TRANSFORM] rotate
|
|
|
|
-- @param #number angle
|
|
|
|
-- @param #Vector3 axis.
|
|
|
|
-- @return #Transform.
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-11-18 15:11:39 +01:00
|
|
|
-- X-axis rotation (equivalent to `rotate(angle, vector3(-1, 0, 0))`).
|
2021-09-19 14:43:15 +02:00
|
|
|
-- @function [parent=#TRANSFORM] rotateX
|
|
|
|
-- @param #number angle
|
|
|
|
-- @return #Transform.
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-11-18 15:11:39 +01:00
|
|
|
-- Y-axis rotation (equivalent to `rotate(angle, vector3(0, -1, 0))`).
|
2021-09-19 14:43:15 +02:00
|
|
|
-- @function [parent=#TRANSFORM] rotateY
|
|
|
|
-- @param #number angle
|
|
|
|
-- @return #Transform.
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-11-18 15:11:39 +01:00
|
|
|
-- Z-axis rotation (equivalent to `rotate(angle, vector3(0, 0, -1))`).
|
2021-09-19 14:43:15 +02:00
|
|
|
-- @function [parent=#TRANSFORM] rotateZ
|
|
|
|
-- @param #number angle
|
|
|
|
-- @return #Transform.
|
|
|
|
|
2022-02-02 20:30:28 +00:00
|
|
|
---
|
2021-09-19 14:43:15 +02:00
|
|
|
-- 3D transforms (scale/move/rotate) that can be applied to 3D vectors.
|
|
|
|
-- Several transforms can be combined and applied to a vector using multiplication.
|
|
|
|
-- Combined transforms apply in reverse order (from right to left).
|
|
|
|
-- @field [parent=#util] #TRANSFORM transform
|
|
|
|
-- @usage
|
|
|
|
-- local util = require('openmw.util')
|
|
|
|
-- local trans = util.transform
|
|
|
|
-- local fromActorSpace = trans.move(actor.position) * trans.rotateZ(actor.rotation.z)
|
|
|
|
--
|
|
|
|
-- -- rotation is applied first, movement is second
|
|
|
|
-- local posBehindActor = fromActorSpace * util.vector3(0, -100, 0)
|
|
|
|
--
|
|
|
|
-- -- equivalent to trans.rotateZ(-actor.rotation.z) * trans.move(-actor.position)
|
|
|
|
-- local toActorSpace = fromActorSpace:inverse()
|
|
|
|
-- local relativeTargetPos = toActorSpace * target.position
|
|
|
|
-- local deltaAngle = math.atan2(relativeTargetPos.y, relativeTargetPos.x)
|
|
|
|
|
2021-04-02 19:42:19 +02:00
|
|
|
return nil
|
|
|
|
|