5bae08a2d8
- Removed the internal classes sf::Renderer and sf::Matrix3 - Split sf::Drawable into sf::Drawable and sf::Transformable - Added sf::Transform - Added sf::Vertex - Added sf::VertexArray - Types of shapes are now handled with their own derived class - Modified the Pong example
174 lines
6.3 KiB
C++
174 lines
6.3 KiB
C++
////////////////////////////////////////////////////////////
|
|
//
|
|
// SFML - Simple and Fast Multimedia Library
|
|
// Copyright (C) 2007-2009 Laurent Gomila (laurent.gom@gmail.com)
|
|
//
|
|
// This software is provided 'as-is', without any express or implied warranty.
|
|
// In no event will the authors be held liable for any damages arising from the use of this software.
|
|
//
|
|
// Permission is granted to anyone to use this software for any purpose,
|
|
// including commercial applications, and to alter it and redistribute it freely,
|
|
// subject to the following restrictions:
|
|
//
|
|
// 1. The origin of this software must not be misrepresented;
|
|
// you must not claim that you wrote the original software.
|
|
// If you use this software in a product, an acknowledgment
|
|
// in the product documentation would be appreciated but is not required.
|
|
//
|
|
// 2. Altered source versions must be plainly marked as such,
|
|
// and must not be misrepresented as being the original software.
|
|
//
|
|
// 3. This notice may not be removed or altered from any source distribution.
|
|
//
|
|
////////////////////////////////////////////////////////////
|
|
|
|
#ifndef SFML_RENDERSTATES_HPP
|
|
#define SFML_RENDERSTATES_HPP
|
|
|
|
////////////////////////////////////////////////////////////
|
|
// Headers
|
|
////////////////////////////////////////////////////////////
|
|
#include <SFML/Graphics/BlendMode.hpp>
|
|
#include <SFML/Graphics/Transform.hpp>
|
|
|
|
|
|
namespace sf
|
|
{
|
|
class Shader;
|
|
class Texture;
|
|
|
|
////////////////////////////////////////////////////////////
|
|
/// \brief Define the states used for drawing to a RenderTarget
|
|
///
|
|
////////////////////////////////////////////////////////////
|
|
class SFML_API RenderStates
|
|
{
|
|
public :
|
|
|
|
////////////////////////////////////////////////////////////
|
|
/// \brief Default constructor
|
|
///
|
|
/// Constructing a default set of render states is equivalent
|
|
/// to using sf::RenderStates::Default.
|
|
/// The default set defines:
|
|
/// \li the BlendAlpha blend mode
|
|
/// \li the identity transform
|
|
/// \li a null texture
|
|
/// \li a null shader
|
|
///
|
|
////////////////////////////////////////////////////////////
|
|
RenderStates();
|
|
|
|
////////////////////////////////////////////////////////////
|
|
/// \brief Construct a default set of render states with a custom blend mode
|
|
///
|
|
/// \param blendMode Blend mode to use
|
|
///
|
|
////////////////////////////////////////////////////////////
|
|
RenderStates(sf::BlendMode blendMode);
|
|
|
|
////////////////////////////////////////////////////////////
|
|
/// \brief Construct a default set of render states with a custom transform
|
|
///
|
|
/// \param transform Transform to use
|
|
///
|
|
////////////////////////////////////////////////////////////
|
|
RenderStates(const sf::Transform& transform);
|
|
|
|
////////////////////////////////////////////////////////////
|
|
/// \brief Construct a default set of render states with a custom texture
|
|
///
|
|
/// \param texture Texture to use
|
|
///
|
|
////////////////////////////////////////////////////////////
|
|
RenderStates(const sf::Texture* texture);
|
|
|
|
////////////////////////////////////////////////////////////
|
|
/// \brief Construct a default set of render states with a custom shader
|
|
///
|
|
/// \param shader Shader to use
|
|
///
|
|
////////////////////////////////////////////////////////////
|
|
RenderStates(const sf::Shader* shader);
|
|
|
|
////////////////////////////////////////////////////////////
|
|
/// \brief Construct a set of render states with all its attributes
|
|
///
|
|
/// \param blendMode Blend mode to use
|
|
/// \param transform Transform to use
|
|
/// \param texture Texture to use
|
|
/// \param shader Shader to use
|
|
///
|
|
////////////////////////////////////////////////////////////
|
|
RenderStates(sf::BlendMode blendMode, const sf::Transform& transform,
|
|
const sf::Texture* texture, const sf::Shader* shader);
|
|
|
|
////////////////////////////////////////////////////////////
|
|
// Static member data
|
|
////////////////////////////////////////////////////////////
|
|
static const RenderStates Default; ///< Special instance holding the default render states
|
|
|
|
////////////////////////////////////////////////////////////
|
|
// Member data
|
|
////////////////////////////////////////////////////////////
|
|
sf::BlendMode BlendMode; ///< Blending mode
|
|
sf::Transform Transform; ///< Transform
|
|
const sf::Texture* Texture; ///< Texture
|
|
const sf::Shader* Shader; ///< Shader
|
|
};
|
|
|
|
} // namespace sf
|
|
|
|
|
|
#endif // SFML_RENDERSTATES_HPP
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
/// \class sf::RenderStates
|
|
/// \ingroup graphics
|
|
///
|
|
/// There are four global states that can be applied to
|
|
/// the drawn objects:
|
|
/// \li the blend mode: how pixels of the object are blended with the background
|
|
/// \li the transform: how the object is positioned/rotated/scaled
|
|
/// \li the texture: what image is mapped to the object
|
|
/// \li the shader: what custom effect is applied to the object
|
|
///
|
|
/// High-level objects such as sprites or text force some of
|
|
/// these states when they are drawn. For example, a sprite
|
|
/// will set its own texture, so that you don't have to care
|
|
/// about it when drawing the sprite.
|
|
///
|
|
/// The transform is a special case: sprites, texts and shapes
|
|
/// (and it's a good idea to do it with your own drawable classes
|
|
/// too) combine their transform with the one that is passed in the
|
|
/// RenderStates structure. So that you can use a "global" transform
|
|
/// on top of each object's transform.
|
|
///
|
|
/// Most objects, especially high-level drawables, can be drawn
|
|
/// directly without defining render states explicitely -- the
|
|
/// default set of states is ok in most cases.
|
|
/// \code
|
|
/// window.Draw(sprite);
|
|
/// \endcode
|
|
///
|
|
/// If you want to use a single specific render state,
|
|
/// for example a shader, you can pass it directly to the Draw
|
|
/// function: sf::RenderStates has an implicit one-argument
|
|
/// constructor for each state.
|
|
/// \code
|
|
/// window.Draw(sprite, shader);
|
|
/// \endcode
|
|
///
|
|
/// When you're inside the Draw function of a drawable
|
|
/// object (inherited from sf::Drawable), you can
|
|
/// either pass the render states unmodified, or change
|
|
/// some of them.
|
|
/// For example, a transformable object will combine the
|
|
/// current transform with its own transform. A sprite will
|
|
/// set its texture. Etc.
|
|
///
|
|
/// \see sf::RenderTarget, sf::Drawable
|
|
///
|
|
////////////////////////////////////////////////////////////
|