2009-01-28 16:18:34 +00:00
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// SFML - Simple and Fast Multimedia Library
|
2009-02-12 17:48:35 +00:00
|
|
|
// Copyright (C) 2007-2009 Laurent Gomila (laurent.gom@gmail.com)
|
2009-01-28 16:18:34 +00:00
|
|
|
//
|
|
|
|
// 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.
|
|
|
|
//
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
|
2009-11-03 09:04:40 +00:00
|
|
|
#ifndef SFML_SHADER_H
|
|
|
|
#define SFML_SHADER_H
|
2009-01-28 16:18:34 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
// Headers
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
#include <SFML/Config.h>
|
2009-01-30 14:58:43 +00:00
|
|
|
#include <SFML/Graphics/Types.h>
|
2009-01-28 16:18:34 +00:00
|
|
|
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-03 09:04:40 +00:00
|
|
|
/// Create a new shader from a file
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
2009-07-11 22:17:24 +00:00
|
|
|
/// \param filename : File to load
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
2009-11-03 09:04:40 +00:00
|
|
|
/// \return A new sfShader object, or NULL if it failed
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-26 20:09:57 +00:00
|
|
|
CSFML_API sfShader* sfShader_CreateFromFile(const char* filename);
|
2009-01-28 16:18:34 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-03 09:04:40 +00:00
|
|
|
/// Create a new shader from an effect source code
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
2009-07-11 22:17:24 +00:00
|
|
|
/// \param effect : Source code of the effect
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
2009-11-03 09:04:40 +00:00
|
|
|
/// \return A new sfShader object, or NULL if it failed
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-03 09:04:40 +00:00
|
|
|
CSFML_API sfShader* sfShader_CreateFromMemory(const char* effect);
|
2009-01-28 16:18:34 +00:00
|
|
|
|
2010-01-05 17:52:56 +00:00
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
/// Copy an existing shader
|
|
|
|
///
|
|
|
|
/// \param shader : Shader to copy
|
|
|
|
///
|
|
|
|
/// \return Copied object
|
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
CSFML_API sfShader* sfShader_Copy(sfShader* shader);
|
|
|
|
|
2009-01-28 16:18:34 +00:00
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-03 09:04:40 +00:00
|
|
|
/// Destroy an existing shader
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
2009-11-03 09:04:40 +00:00
|
|
|
/// \param shader : Shader to delete
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-03 09:04:40 +00:00
|
|
|
CSFML_API void sfShader_Destroy(sfShader* shader);
|
2009-01-28 16:18:34 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-03 09:04:40 +00:00
|
|
|
/// Change a parameter of a shader (1 float)
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
2009-11-03 09:04:40 +00:00
|
|
|
/// \param shader : Shader to modify
|
2009-07-11 22:17:24 +00:00
|
|
|
/// \param name : Parameter name in the effect
|
|
|
|
/// \param x : Value to assign
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-03 09:04:40 +00:00
|
|
|
CSFML_API void sfShader_SetParameter1(sfShader* shader, const char* name, float x);
|
2009-01-28 16:18:34 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-03 09:04:40 +00:00
|
|
|
/// Change a parameter of a shader (2 floats)
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
2009-11-03 09:04:40 +00:00
|
|
|
/// \param shader : Shader to modify
|
2009-07-11 22:17:24 +00:00
|
|
|
/// \param name : Parameter name in the effect
|
|
|
|
/// \param x, y : Values to assign
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-03 09:04:40 +00:00
|
|
|
CSFML_API void sfShader_SetParameter2(sfShader* shader, const char* name, float x, float y);
|
2009-01-28 16:18:34 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-03 09:04:40 +00:00
|
|
|
/// Change a parameter of a shader (3 floats)
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
2009-11-03 09:04:40 +00:00
|
|
|
/// \param shader : Shader to modify
|
2009-07-11 22:17:24 +00:00
|
|
|
/// \param name : Parameter name in the effect
|
|
|
|
/// \param x, y, z : Values to assign
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-03 09:04:40 +00:00
|
|
|
CSFML_API void sfShader_SetParameter3(sfShader* shader, const char* name, float x, float y, float z);
|
2009-01-28 16:18:34 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-03 09:04:40 +00:00
|
|
|
/// Change a parameter of a shader (4 floats)
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
2009-11-03 09:04:40 +00:00
|
|
|
/// \param shader : Shader to modify
|
2009-07-11 22:17:24 +00:00
|
|
|
/// \param name : Parameter name in the effect
|
|
|
|
/// \param x, y, z, w : Values to assign
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-03 09:04:40 +00:00
|
|
|
CSFML_API void sfShader_SetParameter4(sfShader* shader, const char* name, float x, float y, float z, float w);
|
2009-01-28 16:18:34 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-03 09:04:40 +00:00
|
|
|
/// Set a texture parameter in a shader
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
2009-11-03 09:04:40 +00:00
|
|
|
/// \param shader : Shader to modify
|
2009-07-11 22:17:24 +00:00
|
|
|
/// \param name : Texture name in the effect
|
2009-11-03 09:04:40 +00:00
|
|
|
/// \param texture : Image to set (pass NULL to use the texture of the object being drawn)
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-26 20:09:57 +00:00
|
|
|
CSFML_API void sfShader_SetTexture(sfShader* shader, const char* name, const sfImage* texture);
|
2009-01-28 16:18:34 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-03 09:04:40 +00:00
|
|
|
/// Bind a shader for rendering
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
2009-11-03 09:04:40 +00:00
|
|
|
/// \param shader : Shader to bind
|
2009-01-28 16:18:34 +00:00
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-26 20:09:57 +00:00
|
|
|
CSFML_API void sfShader_Bind(const sfShader* shader);
|
2009-11-03 09:04:40 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
/// Unbind a shader
|
|
|
|
///
|
|
|
|
/// \param shader : Shader to unbind
|
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-11-26 20:09:57 +00:00
|
|
|
CSFML_API void sfShader_Unbind(const sfShader* shader);
|
2009-11-03 09:04:40 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
/// Tell whether or not the system supports shaders
|
|
|
|
///
|
|
|
|
/// \return sfTrue if the system can use shaders
|
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
2010-05-02 15:44:07 +00:00
|
|
|
CSFML_API sfBool sfShader_IsAvailable(void);
|
2009-01-28 16:18:34 +00:00
|
|
|
|
|
|
|
|
2009-11-03 09:04:40 +00:00
|
|
|
#endif // SFML_SHADER_H
|