2024-07-31 14:45:09 +03:00

4.8 KiB
Raw Blame History

Библиотека mat4

mat4 содержит набор функций для работы с матрицами трансформации размерностью 4x4.

Большинство функций имеют несколько вариантов списка агрументов (перегрузок).

Единичная матрица - mat4.idt(...)

-- создает единичную матрицу
mat4.idt()

-- записывает единичную матрицу в dst
mat4.idt(dst: matrix)

Определитель матрицы - mat4.determinant(...)

-- вычисляет определитель матрицы
mat4.determinant(m: matrix)

Матрица из кватерниона - mat4.from_quat(...)

-- создает матрицу вращения по кватерниону
mat4.from_quat(quaternion: quat)

-- записывает матрицу вращения по кватерниону в dst
mat4.from_quat(quaternion: quat, dst: matrix)

Умножение матриц - mat4.mul(...)

-- возвращает результат умножения матриц
mat4.mul(a: matrix, b: matrix)
-- записывает результат умножения матриц в dst
mat4.mul(a: matrix, b: matrix, dst: matrix)

-- возвращает результат умножения матрицы и вектора
mat4.mul(a: matrix, v: vector)
-- записывает результат умножения матрицы и вектора в dst
mat4.mul(a: matrix, v: vector, dst: vector)

Инверсия матрицы - mat4.inverse(...)

-- возвращает результат инверсии матрицы
mat4.inverse(m: matrix)
-- записывает результат инверсии матрицы в dst
mat4.inverse(m: matrix, dst: matrix)

Транспонирование матрицы - mat4.transpose(...)

-- возвращает результат транспонирования матрицы
mat4.transpose(m: matrix)
-- записывает результат транспонирования матрицы в dst
mat4.transpose(m: matrix, dst: matrix)

Смещение - mat4.translate(...)

-- создает матрицу смещения
mat4.translate(translation: vec3)
-- возвращает результат применения смещения к матрице m
mat4.translate(m: matrix, translation: vec3)
-- записывает результат применения смещения к матрице m в dst
mat4.translate(m: matrix, translation: vec3, dst: matrix)

Масштабирование - mat4.scale(...)

-- создает матрицу масштабирования
mat4.scale(scale: vec3)
-- возвращает результат применения масштабирования к матрице m
mat4.scale(m: matrix, scale: vec3)
-- записывает результат применения масштабирования к матрице m в dst
mat4.scale(m: matrix, scale: vec3, dst: matrix)

Вращение - mat4.rotate(...)

Угол поворота (angle) указывается в градусах.

-- создает матрицу поворота (angle - угол поворота) по заданной оси (axis - единичный вектор)
mat4.rotate(axis: vec3, angle: number)
-- возвращает результат применения вращения к матрице m
mat4.rotate(m: matrix, axis: vec3, angle: number)
-- записывает результат применения вращения к матрице m в dst
mat4.rotate(m: matrix, axis: vec3, angle: number, dst: matrix)

Декомпозиция - mat4.decompose(...)

Раскладывает матрицу трансформации на составляющие.

mat4.decompose(m: matrix)
-- возвращает таблицу:
{
    scale=vec3,
    rotation=matrix,
    quaternion=quat,
    translation=vec3,
    skew=vec3,
    perspective=vec4 
} или nil

Отслеживание точки mat4.look_at(...)

-- cоздает матрицу вида с точки 'eye' на точку 'center', где вектор 'up' определяет верх.
mat4.look_at(eye: vec3, center: vec3, up: vec3)
-- записывает матрицу вида в dst
mat4.look_at(eye: vec3, center: vec3, up: vec3, dst: matrix)

Перевод в строку - mat4.tostring(...)

-- возвращает строку представляющую содержимое матрицы
mat4.tostring(m: matrix)
-- возвращает строку представляющую содержимое матрицы, многострочную, если multiline = true
mat4.tostring(m: matrix, multiline: bool)