summaryrefslogtreecommitdiff
path: root/Userland/Libraries/LibGfx/Matrix3x3.h
blob: 2f97714b482eab2402eee85793d426c8cf8e4f54 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
/*
 * Copyright (c) 2021, Jelle Raaijmakers <jelle@gmta.nl>
 *
 * SPDX-License-Identifier: BSD-2-Clause
 */

#pragma once

#include <LibGfx/Matrix.h>
#include <LibGfx/Vector3.h>

namespace Gfx {

template<typename T>
using Matrix3x3 = Matrix<3, T>;

template<typename T>
constexpr static Vector3<T> operator*(Matrix3x3<T> const& m, Vector3<T> const& v)
{
    auto const& elements = m.elements();
    return Vector3<T>(
        v.x() * elements[0][0] + v.y() * elements[0][1] + v.z() * elements[0][2],
        v.x() * elements[1][0] + v.y() * elements[1][1] + v.z() * elements[1][2],
        v.x() * elements[2][0] + v.y() * elements[2][1] + v.z() * elements[2][2]);
}

typedef Matrix3x3<float> FloatMatrix3x3;
typedef Matrix3x3<double> DoubleMatrix3x3;
}

using Gfx::DoubleMatrix3x3;
using Gfx::FloatMatrix3x3;
using Gfx::Matrix3x3;