| Unit CastleGLShadersDescription
OpenGL shaders in GLSL language.
 
   Creating/destroying the TGLSLProgram instance immediately creates/destroys appropriate program on GPU. So be sure to create/destroy it only when you have OpenGL context available (for example, create in TCastleWindowBase.OnOpen and destroy in TCastleWindowBase.OnClose). Upon creation, we check current OpenGL context abilities. Currently three support levels are possible: no support at all (old OpenGL), support through ARB extensions, or support built-in (newer OpenGL versions, >= 2.0).
 All three cases are automatically handled inside, so usually you do not have to care about these details. Note that "none" support (on older OpenGL version with no appropriate ARB extensions) means that shaders are not really initialized at all. UsesOverviewClasses, Interfaces, Objects and RecordsFunctions and ProceduresTypesVariablesDescriptionFunctions and ProceduresTypes
| TUniformNotFoundAction = (...); |  | 
What to do when GLSL uniform variable is set (TGLSLProgram.SetUniform) but doesn't exist in the shader. Values
uaWarning: Report that uniform variable not found to OnWarning.
uaException: Report that uniform variable not found by raising EGLSLUniformNotFound.
uaIgnore: Ignore the fact that uniform variable doesn't exist in the GLSL shader. Do not warn anywhere. |  
| TUniformTypeMismatchAction = (...); |  | 
What to do when GLSL uniform variable is set (by TGLSLProgram.SetUniform) to the type that doesn't match type declared in GLSL shader. Values |  Variables
| property CurrentProgram: TGLSLProgram
  read GetCurrentProgram write SetCurrentProgram; |  | 
Currently enabled GLSL program. Nilif fixed-function pipeline should be used. Setting this property encapsulates the OpenGL glUseProgram (or equivalent ARB extension), additionally preventing redundant glUseProgram calls. |  Generated by PasDoc 0.13.0 on 2013-08-17 21:27:12
 |