/* * This program source code file is part of KICAD, a free EDA CAD application. * * Copyright (C) 2012 Torsten Hueter, torstenhtr gmx.de * Copyright (C) 2012 Kicad Developers, see change_log.txt for contributors. * * Graphics Abstraction Layer (GAL) for OpenGL * * Shader class * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, you may find one here: * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html * or you may search the http://www.gnu.org website for the version 2 license, * or you may write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA */ #ifndef SHADER_H_ #define SHADER_H_ #include #include #include namespace KiGfx { class OPENGL_GAL; /// Type definition for the shader enum ShaderType { SHADER_TYPE_VERTEX = GL_VERTEX_SHADER, ///< Vertex shader SHADER_TYPE_FRAGMENT = GL_FRAGMENT_SHADER, ///< Fragment shader SHADER_TYPE_GEOMETRY = GL_GEOMETRY_SHADER ///< Geometry shader }; /** * @brief Class SHADER provides the access to the OpenGL shaders. * * The purpose of this class is advanced drawing with OpenGL. One example is using the pixel * shader for drawing exact circles or for anti-aliasing. This class supports vertex, geometry * and fragment shaders. *
* Make sure that the hardware supports these features. This can be identified with the "GLEW" * library. */ class SHADER { public: /** * @brief Constructor */ SHADER(); /** * @brief Destructor */ virtual ~SHADER(); /** * @brief Add a shader and compile the shader sources. * * @param aShaderSourceName is the shader source file name. * @param aShaderType is the type of the shader. */ void AddSource( std::string aShaderSourceName, ShaderType aShaderType ); /** * Link the shaders. */ void Link(); /** * Use the shader. */ void Use(); /** * @brief Deactivate the shader and use the default OpenGL program. */ void Deactivate(); /** * @brief Configure the geometry shader - has to be done before linking! * * @param maxVertices is the maximum of vertices to be generated. * @param geometryInputType is the input type [e.g. GL_LINES, GL_TRIANGLES, GL_QUADS etc.] * @param geometryOutputType is the output type [e.g. GL_LINES, GL_TRIANGLES, GL_QUADS etc.] */ void ConfigureGeometryShader( GLuint maxVertices, GLuint geometryInputType, GLuint geometryOutputType ); /** * @brief Add a parameter to the parameter queue. * * To communicate with the shader use this function to set up the names for the uniform * variables. These are queued in a list and can be assigned with the SetParameter(..) * method using the queue position. * * @param aParameterName is the name of the parameter. */ void AddParameter( std::string aParameterName ); /** * @brief Set a parameter of the shader. * * @param aParameterNumber is the number of the parameter. * @param aValue is the value of the parameter. */ void SetParameter( int aParameterNumber, float aValue ); private: /** * @brief Get the shader program information. * * @param aProgram is the program number. */ void ProgramInfo( GLuint aProgram ); /** * @brief Read the shader source file * * @param aShaderSourceName is the shader source file name. * @return the source as string */ std::string ReadSource( std::string aShaderSourceName ); std::deque shaderNumbers; ///< Shader number list GLuint programNumber; ///< Shader program number bool isProgramCreated; ///< Flag for program creation bool isShaderLinked; ///< Is the shader linked? GLuint maximumVertices; ///< The maximum of vertices to be generated GLuint geomInputType; ///< Input type [e.g. GL_LINES, GL_TRIANGLES, GL_QUADS etc.] GLuint geomOutputType; ///< Output type [e.g. GL_LINES, GL_TRIANGLES, GL_QUADS etc.] std::deque parameterLocation; ///< Location of the parameter }; } // namespace KiGfx #endif /* SHADER_H_ */