Berserk
Geometry.hpp
Go to the documentation of this file.
1 /**********************************************************************************/
2 /* This file is part of Berserk Engine project */
3 /* https://github.com/EgorOrachyov/Berserk */
4 /**********************************************************************************/
5 /* MIT License */
6 /* */
7 /* Copyright (c) 2018 - 2021 Egor Orachyov */
8 /* */
9 /* Permission is hereby granted, free of charge, to any person obtaining a copy */
10 /* of this software and associated documentation files (the "Software"), to deal */
11 /* in the Software without restriction, including without limitation the rights */
12 /* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell */
13 /* copies of the Software, and to permit persons to whom the Software is */
14 /* furnished to do so, subject to the following conditions: */
15 /* */
16 /* The above copyright notice and this permission notice shall be included in all */
17 /* copies or substantial portions of the Software. */
18 /* */
19 /* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR */
20 /* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, */
21 /* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE */
22 /* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER */
23 /* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, */
24 /* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE */
25 /* SOFTWARE. */
26 /**********************************************************************************/
27 
28 #ifndef BERSERK_GEOMETRY_HPP
29 #define BERSERK_GEOMETRY_HPP
30 
31 #include <core/math/MathUtils.hpp>
32 #include <core/math/TVecN.hpp>
33 
34 #include <array>
35 
37 
47 class Geometry {
48 public:
61  BRK_API static void GenTangentSpace(const std::array<Vec3f, 3> &positions, const std::array<Vec3f, 3> &normals, const std::array<Vec2f, 3> &texCoords, std::array<Vec3f, 3> &tangents, std::array<Vec3f, 3> &bitangents);
62 };
63 
69 
70 #endif//BERSERK_GEOMETRY_HPP
#define BRK_NS_END
Definition: Config.hpp:48
#define BRK_API
Definition: Config.hpp:32
Util class to manipulate 3d geometry.
Definition: Geometry.hpp:47
static BRK_API void GenTangentSpace(const std::array< Vec3f, 3 > &positions, const std::array< Vec3f, 3 > &normals, const std::array< Vec2f, 3 > &texCoords, std::array< Vec3f, 3 > &tangents, std::array< Vec3f, 3 > &bitangents)
Generates tangent vectors from provided vertex data.
Definition: Geometry.cpp:33
Definition: GLDevice.cpp:46