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.
194 lines
6.6 KiB
194 lines
6.6 KiB
#ifndef Magnum_Trade_AbstractMaterialData_h |
|
#define Magnum_Trade_AbstractMaterialData_h |
|
/* |
|
This file is part of Magnum. |
|
|
|
Copyright © 2010, 2011, 2012, 2013, 2014, 2015, 2016, 2017, 2018, 2019 |
|
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 Class @ref Magnum::Trade::AbstractMaterialData, enum @ref Magnum::Trade::MaterialType |
|
*/ |
|
|
|
#include <Corrade/Containers/EnumSet.h> |
|
|
|
#include "Magnum/Magnum.h" |
|
#include "Magnum/Trade/visibility.h" |
|
|
|
#ifdef MAGNUM_BUILD_DEPRECATED |
|
#include <Corrade/Utility/Macros.h> |
|
#endif |
|
|
|
namespace Magnum { namespace Trade { |
|
|
|
/** |
|
@brief Material type |
|
|
|
@see @ref AbstractMaterialData::type() |
|
*/ |
|
enum class MaterialType: UnsignedByte { |
|
Phong /**< Phong shading (see @ref PhongMaterialData) */ |
|
}; |
|
|
|
/** |
|
@brief Material alpha mode |
|
|
|
@see @ref AbstractMaterialData::alphaMode(), |
|
@ref AbstractMaterialData::alphaMask() |
|
*/ |
|
enum class MaterialAlphaMode: UnsignedByte { |
|
/** Alpha value is ignored and the rendered output is fully opaque. */ |
|
Opaque, |
|
|
|
/** |
|
* The rendered output is either fully transparent or fully opaque, |
|
* depending on the alpha value and specified |
|
* @ref AbstractMaterialData::alphaMask() value. |
|
*/ |
|
Mask, |
|
|
|
/** |
|
* The alpha value is used to combine source and destination colors using |
|
* additive blending. |
|
*/ |
|
Blend |
|
}; |
|
|
|
/** |
|
@brief Base for material data |
|
|
|
Subclasses provide access to parameters for given material type. |
|
*/ |
|
class MAGNUM_TRADE_EXPORT AbstractMaterialData { |
|
public: |
|
/** |
|
* @brief Material flag |
|
* |
|
* This enum is extended in subclasses. |
|
* @see @ref Flags, @ref flags() |
|
*/ |
|
enum class Flag: UnsignedShort { |
|
/** |
|
* The material is double-sided. Back faces should not be culled |
|
* away but rendered as well, with normals flipped for correct |
|
* lighting. |
|
*/ |
|
DoubleSided = 1 << 0 |
|
}; |
|
|
|
/** |
|
* @brief Material flags |
|
* |
|
* This enum is extended in subclasses. |
|
* @see @ref flags() |
|
*/ |
|
typedef Containers::EnumSet<Flag> Flags; |
|
|
|
virtual ~AbstractMaterialData(); |
|
|
|
/** @brief Copying is not allowed */ |
|
AbstractMaterialData(const AbstractMaterialData&) = delete; |
|
|
|
/** @brief Move constructor */ |
|
AbstractMaterialData(AbstractMaterialData&&) noexcept; |
|
|
|
/** @brief Copying is not allowed */ |
|
AbstractMaterialData& operator=(const AbstractMaterialData&) = delete; |
|
|
|
/** @brief Move assignment */ |
|
AbstractMaterialData& operator=(AbstractMaterialData&&) noexcept; |
|
|
|
/** @brief Material type */ |
|
MaterialType type() const { return _type; } |
|
|
|
/** |
|
* @brief Material flags |
|
* |
|
* Not all bits returned might be defiend by @ref Flag, subclasses |
|
* define extra values. |
|
*/ |
|
Flags flags() const { return _flags; } |
|
|
|
/** @brief Alpha mode */ |
|
MaterialAlphaMode alphaMode() const { return _alphaMode; } |
|
|
|
/** |
|
* @brief Alpha mask |
|
* |
|
* If @ref alphaMode() is @ref MaterialAlphaMode::Mask, alpha values |
|
* below this value are rendered as fully transparent and alpha values |
|
* above this value as fully opaque. If @ref alphaMode() is not |
|
* @ref MaterialAlphaMode::Mask, this value is ignored. |
|
*/ |
|
Float alphaMask() const { return _alphaMask; } |
|
|
|
/** |
|
* @brief Importer-specific state |
|
* |
|
* See @ref AbstractImporter::importerState() for more information. |
|
*/ |
|
const void* importerState() const { return _importerState; } |
|
|
|
protected: |
|
/** |
|
* @brief Constructor |
|
* @param type Material type |
|
* @param flags Untyped material flags |
|
* @param alphaMode Alpha mode. Use |
|
* @ref MaterialAlphaMode::Opaque for a default value. |
|
* @param alphaMask Alpha mask value. Use @cpp 0.5f @ce for a |
|
* default value. |
|
* @param importerState Importer-specific state |
|
*/ |
|
explicit AbstractMaterialData(MaterialType type, Flags flags, MaterialAlphaMode alphaMode, Float alphaMask, const void* importerState = nullptr) noexcept; |
|
|
|
#ifdef MAGNUM_BUILD_DEPRECATED |
|
/** @brief Constructor |
|
* @m_deprecated_since{2018,10} Use @ref AbstractMaterialData(MaterialType, Flags, MaterialAlphaMode, Float, const void*) |
|
* instead. |
|
*/ |
|
explicit CORRADE_DEPRECATED("use AbstractMaterialData(MaterialType, UnsignedInt, MaterialAlphaMode, Float) instead") AbstractMaterialData(MaterialType type, const void* importerState = nullptr) noexcept: AbstractMaterialData{type, {}, MaterialAlphaMode::Opaque, 0.5f, importerState} {} |
|
#endif |
|
|
|
private: |
|
MaterialType _type; |
|
MaterialAlphaMode _alphaMode; |
|
Flags _flags; |
|
Float _alphaMask; |
|
const void* _importerState; |
|
}; |
|
|
|
/** @debugoperatorenum{MaterialType} */ |
|
MAGNUM_TRADE_EXPORT Debug& operator<<(Debug& debug, MaterialType value); |
|
|
|
/** @debugoperatorenum{MaterialAlphaMode} */ |
|
MAGNUM_TRADE_EXPORT Debug& operator<<(Debug& debug, MaterialAlphaMode value); |
|
|
|
/** @debugoperatorclassenum{AbstractMaterialData,AbstractMaterialData::Flag} */ |
|
MAGNUM_TRADE_EXPORT Debug& operator<<(Debug& debug, AbstractMaterialData::Flag value); |
|
|
|
/** @debugoperatorclassenum{AbstractMaterialData,AbstractMaterialData::Flags} */ |
|
MAGNUM_TRADE_EXPORT Debug& operator<<(Debug& debug, AbstractMaterialData::Flags value); |
|
|
|
}} |
|
|
|
#endif
|
|
|