281 lines
5.9 KiB
C++
281 lines
5.9 KiB
C++
// Copyright (C) 2015 Jérôme Leclercq
|
|
// This file is part of the "Nazara Engine - Graphics module"
|
|
// For conditions of distribution and use, see copyright notice in Config.hpp
|
|
|
|
#include <Nazara/Core/Error.hpp>
|
|
#include <memory>
|
|
#include <Nazara/Renderer/Debug.hpp>
|
|
|
|
namespace Nz
|
|
{
|
|
/*!
|
|
* \brief Constructs a Sprite object by default
|
|
*/
|
|
|
|
inline Sprite::Sprite() :
|
|
m_color(Color::White),
|
|
m_textureCoords(0.f, 0.f, 1.f, 1.f),
|
|
m_size(64.f, 64.f)
|
|
{
|
|
SetDefaultMaterial();
|
|
}
|
|
|
|
/*!
|
|
* \brief Constructs a Sprite object with a reference to a material
|
|
*
|
|
* \param material Reference to a material
|
|
*/
|
|
|
|
inline Sprite::Sprite(MaterialRef material) :
|
|
m_color(Color::White),
|
|
m_textureCoords(0.f, 0.f, 1.f, 1.f),
|
|
m_size(64.f, 64.f)
|
|
{
|
|
SetMaterial(std::move(material), true);
|
|
}
|
|
|
|
/*!
|
|
* \brief Constructs a Sprite object with a pointer to a texture
|
|
*
|
|
* \param texture Pointer to a texture
|
|
*/
|
|
|
|
inline Sprite::Sprite(Texture* texture) :
|
|
m_color(Color::White),
|
|
m_textureCoords(0.f, 0.f, 1.f, 1.f),
|
|
m_size(64.f, 64.f)
|
|
{
|
|
SetTexture(texture, true);
|
|
}
|
|
|
|
/*!
|
|
* \brief Constructs a Sprite object by assignation
|
|
*
|
|
* \param sprite Sprite to copy into this
|
|
*/
|
|
|
|
inline Sprite::Sprite(const Sprite& sprite) :
|
|
InstancedRenderable(sprite),
|
|
m_color(sprite.m_color),
|
|
m_material(sprite.m_material),
|
|
m_textureCoords(sprite.m_textureCoords),
|
|
m_size(sprite.m_size)
|
|
{
|
|
}
|
|
|
|
/*!
|
|
* \brief Gets the color of the sprite
|
|
* \return Current color
|
|
*/
|
|
|
|
inline const Color& Sprite::GetColor() const
|
|
{
|
|
return m_color;
|
|
}
|
|
|
|
/*!
|
|
* \brief Gets the material of the sprite
|
|
* \return Current material
|
|
*/
|
|
|
|
inline const MaterialRef& Sprite::GetMaterial() const
|
|
{
|
|
return m_material;
|
|
}
|
|
|
|
/*!
|
|
* \brief Gets the size of the sprite
|
|
* \return Current size
|
|
*/
|
|
|
|
inline const Vector2f& Sprite::GetSize() const
|
|
{
|
|
return m_size;
|
|
}
|
|
|
|
/*!
|
|
* \brief Gets the texture coordinates of the sprite
|
|
* \return Current texture coordinates
|
|
*/
|
|
|
|
inline const Rectf& Sprite::GetTextureCoords() const
|
|
{
|
|
return m_textureCoords;
|
|
}
|
|
|
|
/*!
|
|
* \brief Sets the color of the billboard
|
|
*
|
|
* \param color Color for the billboard
|
|
*/
|
|
|
|
inline void Sprite::SetColor(const Color& color)
|
|
{
|
|
m_color = color;
|
|
|
|
InvalidateVertices();
|
|
}
|
|
|
|
/*!
|
|
* \brief Sets the default material of the sprite (just default material)
|
|
*/
|
|
|
|
inline void Sprite::SetDefaultMaterial()
|
|
{
|
|
MaterialRef material = Material::New();
|
|
material->Enable(RendererParameter_FaceCulling, false);
|
|
material->EnableLighting(false);
|
|
|
|
SetMaterial(std::move(material));
|
|
}
|
|
|
|
/*!
|
|
* \brief Sets the material of the sprite
|
|
*
|
|
* \param material Material for the sprite
|
|
* \param resizeSprite Should sprite be resized to the material size (diffuse map)
|
|
*/
|
|
|
|
inline void Sprite::SetMaterial(MaterialRef material, bool resizeSprite)
|
|
{
|
|
m_material = std::move(material);
|
|
if (m_material && resizeSprite)
|
|
{
|
|
Texture* diffuseMap = m_material->GetDiffuseMap();
|
|
if (diffuseMap && diffuseMap->IsValid())
|
|
SetSize(Vector2f(Vector2ui(diffuseMap->GetSize())));
|
|
}
|
|
}
|
|
|
|
/*!
|
|
* \brief Sets the size of the sprite
|
|
*
|
|
* \param size Size for the sprite
|
|
*/
|
|
|
|
inline void Sprite::SetSize(const Vector2f& size)
|
|
{
|
|
m_size = size;
|
|
|
|
// On invalide la bounding box
|
|
InvalidateBoundingVolume();
|
|
InvalidateVertices();
|
|
}
|
|
|
|
/*!
|
|
* \brief Sets the size of the sprite
|
|
*
|
|
* \param sizeX Size in X for the sprite
|
|
* \param sizeY Size in Y for the sprite
|
|
*/
|
|
|
|
inline void Sprite::SetSize(float sizeX, float sizeY)
|
|
{
|
|
SetSize(Vector2f(sizeX, sizeY));
|
|
}
|
|
|
|
/*!
|
|
* \brief Sets the texture of the sprite
|
|
*
|
|
* \param texture Texture for the sprite
|
|
* \param resizeSprite Should sprite be resized to the texture size
|
|
*/
|
|
|
|
inline void Sprite::SetTexture(TextureRef texture, bool resizeSprite)
|
|
{
|
|
if (!m_material)
|
|
SetDefaultMaterial();
|
|
else if (m_material->GetReferenceCount() > 1)
|
|
m_material = Material::New(*m_material); // Copie
|
|
|
|
if (resizeSprite && texture && texture->IsValid())
|
|
SetSize(Vector2f(Vector2ui(texture->GetSize())));
|
|
|
|
m_material->SetDiffuseMap(std::move(texture));
|
|
}
|
|
|
|
/*!
|
|
* \brief Sets the texture coordinates of the sprite
|
|
*
|
|
* \param coords Texture coordinates
|
|
*/
|
|
|
|
inline void Sprite::SetTextureCoords(const Rectf& coords)
|
|
{
|
|
m_textureCoords = coords;
|
|
InvalidateVertices();
|
|
}
|
|
|
|
/*!
|
|
* \brief Sets the texture rectangle of the sprite
|
|
*
|
|
* \param rect Rectangles symbolizing the size of the texture
|
|
*
|
|
* \remark Produces a NazaraAssert if material is invalid
|
|
* \remark Produces a NazaraAssert if material has no diffuse map
|
|
*/
|
|
|
|
inline void Sprite::SetTextureRect(const Rectui& rect)
|
|
{
|
|
NazaraAssert(m_material, "Sprite has no material");
|
|
NazaraAssert(m_material->HasDiffuseMap(), "Sprite material has no diffuse map");
|
|
|
|
Texture* diffuseMap = m_material->GetDiffuseMap();
|
|
|
|
float invWidth = 1.f / diffuseMap->GetWidth();
|
|
float invHeight = 1.f / diffuseMap->GetHeight();
|
|
|
|
SetTextureCoords(Rectf(invWidth * rect.x, invHeight * rect.y, invWidth * rect.width, invHeight * rect.height));
|
|
}
|
|
|
|
/*!
|
|
* \brief Sets the current sprite with the content of the other one
|
|
* \return A reference to this
|
|
*
|
|
* \param sprite The other Sprite
|
|
*/
|
|
|
|
inline Sprite& Sprite::operator=(const Sprite& sprite)
|
|
{
|
|
InstancedRenderable::operator=(sprite);
|
|
|
|
m_color = sprite.m_color;
|
|
m_material = sprite.m_material;
|
|
m_textureCoords = sprite.m_textureCoords;
|
|
m_size = sprite.m_size;
|
|
|
|
// We do not copy final vertices because it's highly probable that our parameters are modified and they must be regenerated
|
|
InvalidateBoundingVolume();
|
|
InvalidateVertices();
|
|
|
|
return *this;
|
|
}
|
|
|
|
/*!
|
|
* \brief Invalidates the vertices
|
|
*/
|
|
|
|
inline void Sprite::InvalidateVertices()
|
|
{
|
|
InvalidateInstanceData(0);
|
|
}
|
|
|
|
/*!
|
|
* \brief Creates a new sprite from the arguments
|
|
* \return A reference to the newly created sprite
|
|
*
|
|
* \param args Arguments for the sprite
|
|
*/
|
|
|
|
template<typename... Args>
|
|
SpriteRef Sprite::New(Args&&... args)
|
|
{
|
|
std::unique_ptr<Sprite> object(new Sprite(std::forward<Args>(args)...));
|
|
object->SetPersistent(false);
|
|
|
|
return object.release();
|
|
}
|
|
}
|
|
|
|
#include <Nazara/Renderer/DebugOff.hpp>
|