mirror of https://github.com/mosra/magnum.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
221 lines
6.8 KiB
221 lines
6.8 KiB
#ifndef Magnum_Mesh_h |
|
#define Magnum_Mesh_h |
|
/* |
|
This file is part of Magnum. |
|
|
|
Copyright © 2010, 2011, 2012, 2013, 2014, 2015, 2016, 2017, 2018 |
|
Vladimír Vondruš <mosra@centrum.cz> |
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a |
|
copy of this software and associated documentation files (the "Software"), |
|
to deal in the Software without restriction, including without limitation |
|
the rights to use, copy, modify, merge, publish, distribute, sublicense, |
|
and/or sell copies of the Software, and to permit persons to whom the |
|
Software is furnished to do so, subject to the following conditions: |
|
|
|
The above copyright notice and this permission notice shall be included |
|
in all copies or substantial portions of the Software. |
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL |
|
THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING |
|
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER |
|
DEALINGS IN THE SOFTWARE. |
|
*/ |
|
|
|
/** @file |
|
* @brief Enum @ref Magnum::MeshPrimitive, @ref Magnum::MeshIndexType, function @ref Magnum::meshIndexTypeSize() |
|
*/ |
|
|
|
#include <string> |
|
|
|
#include "Magnum/Magnum.h" |
|
#include "Magnum/visibility.h" |
|
|
|
#if defined(MAGNUM_BUILD_DEPRECATED) && defined(MAGNUM_TARGET_GL) |
|
#include "Magnum/GL/Mesh.h" |
|
#endif |
|
|
|
namespace Magnum { |
|
|
|
/** |
|
@brief Mesh primitive type |
|
|
|
In case of OpenGL, corresponds to @ref GL::MeshPrimitive and is convertible to |
|
it using @ref GL::meshPrimitive(). See documentation of each value for more |
|
information about the mapping. |
|
*/ |
|
enum class MeshPrimitive: UnsignedInt { |
|
/** |
|
* Single points. |
|
* |
|
* Corresponds to @ref GL::MeshPrimitive::Points. |
|
*/ |
|
Points, |
|
|
|
/** |
|
* Each pair of vertices defines a single line, lines aren't |
|
* connected together. |
|
* |
|
* Corresponds to @ref GL::MeshPrimitive::Lines. |
|
*/ |
|
Lines, |
|
|
|
/** |
|
* Line strip, last and first vertex are connected together. |
|
* |
|
* Corresponds to @ref GL::MeshPrimitive::LineLoop. |
|
*/ |
|
LineLoop, |
|
|
|
/** |
|
* First two vertices define first line segment, each following |
|
* vertex defines another segment. |
|
* |
|
* Corresponds to @ref GL::MeshPrimitive::LineStrip. |
|
*/ |
|
LineStrip, |
|
|
|
/** |
|
* Each three vertices define one triangle. |
|
* |
|
* Corresponds to @ref GL::MeshPrimitive::Triangles. |
|
*/ |
|
Triangles, |
|
|
|
/** |
|
* First three vertices define first triangle, each following |
|
* vertex defines another triangle. |
|
* |
|
* Corresponds to @ref GL::MeshPrimitive::TriangleStrip. |
|
*/ |
|
TriangleStrip, |
|
|
|
/** |
|
* First vertex is center, each following vertex is connected to |
|
* previous and center vertex. |
|
* |
|
* Corresponds to @ref GL::MeshPrimitive::TriangleFan. |
|
*/ |
|
TriangleFan, |
|
|
|
#if defined(MAGNUM_BUILD_DEPRECATED) && defined(MAGNUM_TARGET_GL) && !defined(MAGNUM_TARGET_GLES2) && !defined(MAGNUM_TARGET_WEBGL) |
|
/** |
|
* Lines with adjacency information. |
|
* @deprecated Use @ref GL::MeshPrimitive::LinesAdjacency instead. |
|
*/ |
|
LinesAdjacency CORRADE_DEPRECATED_ENUM("use GL::MeshPrimitive::LinesAdjacency instead") = UnsignedInt(GL::MeshPrimitive::LinesAdjacency), |
|
|
|
/** |
|
* Line strip with adjacency information. |
|
* @deprecated Use @ref GL::MeshPrimitive::LineStripAdjacency instead. |
|
*/ |
|
LineStripAdjacency CORRADE_DEPRECATED_ENUM("use GL::MeshPrimitive::LineStripAdjacency instead") = UnsignedInt(GL::MeshPrimitive::LineStripAdjacency), |
|
|
|
/** |
|
* Triangles with adjacency information. |
|
* @deprecated Use @ref GL::MeshPrimitive::TrianglesAdjacency instead. |
|
*/ |
|
TrianglesAdjacency CORRADE_DEPRECATED_ENUM("use GL::MeshPrimitive::TrianglesAdjacency instead") = UnsignedInt(GL::MeshPrimitive::TrianglesAdjacency), |
|
|
|
/** |
|
* Triangle strip with adjacency information. |
|
* @deprecated Use @ref GL::MeshPrimitive::TriangleStripAdjacency instead. |
|
*/ |
|
TriangleStripAdjacency CORRADE_DEPRECATED_ENUM("use GL::MeshPrimitive::TriangleStripAdjacency instead") = UnsignedInt(GL::MeshPrimitive::TriangleStripAdjacency), |
|
|
|
/** |
|
* Patches. |
|
* @deprecated Use @ref GL::MeshPrimitive::Patches instead. |
|
*/ |
|
Patches CORRADE_DEPRECATED_ENUM("use GL::MeshPrimitive::Patches instead") = UnsignedInt(GL::MeshPrimitive::Patches) |
|
#endif |
|
}; |
|
|
|
/** @debugoperatorenum{MeshPrimitive} */ |
|
MAGNUM_EXPORT Debug& operator<<(Debug& debug, MeshPrimitive value); |
|
|
|
/** |
|
@brief Mesh primitive type |
|
|
|
In case of OpenGL, corresponds to @ref GL::MeshIndexType and is convertible to |
|
it using @ref GL::meshIndexType(). See documentation of each value for more |
|
information about the mapping. |
|
@see @ref meshIndexTypeSize() |
|
*/ |
|
enum class MeshIndexType: UnsignedInt { |
|
/** |
|
* Unsigned byte |
|
* |
|
* Corresponds to @ref GL::MeshIndexType::UnsignedByte. |
|
*/ |
|
UnsignedByte, |
|
|
|
/** |
|
* Unsigned short |
|
* |
|
* Corresponds to @ref GL::MeshIndexType::UnsignedShort. |
|
*/ |
|
UnsignedShort, |
|
|
|
/** |
|
* Unsigned int |
|
* |
|
* Corresponds to @ref GL::MeshIndexType::UnsignedInt. |
|
*/ |
|
UnsignedInt |
|
}; |
|
|
|
/** @brief Size of given mesh index type */ |
|
MAGNUM_EXPORT UnsignedInt meshIndexTypeSize(MeshIndexType type); |
|
|
|
/** @debugoperatorenum{MeshIndexType} */ |
|
MAGNUM_EXPORT Debug& operator<<(Debug& debug, MeshIndexType value); |
|
|
|
} |
|
|
|
namespace Corrade { namespace Utility { |
|
|
|
/** @configurationvalue{Magnum::MeshPrimitive} */ |
|
template<> struct MAGNUM_EXPORT ConfigurationValue<Magnum::MeshPrimitive> { |
|
ConfigurationValue() = delete; |
|
|
|
/** |
|
* @brief Writes enum value as string |
|
* |
|
* If the value is invalid, returns empty string. |
|
*/ |
|
static std::string toString(Magnum::MeshPrimitive value, ConfigurationValueFlags); |
|
|
|
/** |
|
* @brief Reads enum value as string |
|
* |
|
* If the value is invalid, returns @ref Magnum::MeshPrimitive::Points "MeshPrimitive::Points". |
|
*/ |
|
static Magnum::MeshPrimitive fromString(const std::string& stringValue, ConfigurationValueFlags); |
|
}; |
|
|
|
/** @configurationvalue{Magnum::MeshIndexType} */ |
|
template<> struct MAGNUM_EXPORT ConfigurationValue<Magnum::MeshIndexType> { |
|
ConfigurationValue() = delete; |
|
|
|
/** |
|
* @brief Write enum value as string |
|
* |
|
* If the value is invalid, returns empty string. |
|
*/ |
|
static std::string toString(Magnum::MeshIndexType value, ConfigurationValueFlags); |
|
|
|
/** |
|
* @brief Read enum value as string |
|
* |
|
* If the value is invalid, returns @ref Magnum::MeshIndexType::UnsignedInt "MeshIndexType::UnsignedInt". |
|
*/ |
|
static Magnum::MeshIndexType fromString(const std::string& stringValue, ConfigurationValueFlags); |
|
}; |
|
|
|
}} |
|
|
|
#endif
|
|
|