glCompileShader: Unterschied zwischen den Versionen

Aus DGL Wiki
Wechseln zu: Navigation, Suche
(Delphi-Spezifikation: prcedur statt function)
K (Tippfehler, Wikisyntax; Kategorisierung unter GL2.0)
Zeile 5: Zeile 5:
 
== Name ==
 
== Name ==
 
'''glCompileShader''' - Kompiliert ein Shaderobjekt.
 
'''glCompileShader''' - Kompiliert ein Shaderobjekt.
 
  
  
Zeile 12: Zeile 11:
 
  procedure '''glCompileShader'''(''shaderObj'' : GLHandle);
 
  procedure '''glCompileShader'''(''shaderObj'' : GLHandle);
 
  procedure '''glCompileShaderARB'''(''shaderObj'' : GLHandleARB);
 
  procedure '''glCompileShaderARB'''(''shaderObj'' : GLHandleARB);
 +
 +
  
 
== Parameter ==
 
== Parameter ==
<table border=1 rules=all>
+
{| border="1" rules="all"
<tr>
+
! ''shaderObj''
<td>''shaderObj''</td>
+
| Handle des zu kompilierenden Shaderobjektes.
<td>Handle des zu kompilierenden Shaderobjektes.</td>
+
|}
</tr>
 
</table>
 
  
  
  
 
== Beschreibung ==  
 
== Beschreibung ==  
'''glCompileShader''' kompiliert den Quellcode der im Shaderobjekt abgelegt ist, wobei der Status der Kompilation als Teil des Objektstatus des Shaderobjektes gespeichert wird. Dieser Wert ist True, wenn der Shader ohne Fehler kompiliert wurde und bereit zur Nutzung ist, und ansonsten False. Er kann mittels [[glGetObjectParameterARB]] und dem Shader sowie ''GL_OBJECT_COMPILE_STATUS'' als Argument abgefragt werden.
+
'''glCompileShader''' kompiliert den Quellcode der im Shaderobjekt abgelegt ist, wobei der Status der Kompilation als Teil des Objektstatus des Shaderobjektes gespeichert wird. Dieser Wert ist '''True''', wenn der Shader ohne Fehler kompiliert wurde und bereit zur Nutzung ist, und ansonsten '''False'''. Er kann mittels [[glGetObjectParameterARB]] und dem Shader sowie '''GL_OBJECT_COMPILE_STATUS''' als Argument abgefragt werden.
  
 
Die Kompilierung des Shaders kann aus vielerlei Gründen scheitern, die genauer in den Spezifikationen der OpenGL-Shadersprache aufgelistet sind. Ob die Kompilierung erfolgreich war, kann aus dem Informationslog des Shaderobjektes via [[glGetInfoLogARB]] ermittelt werden.
 
Die Kompilierung des Shaders kann aus vielerlei Gründen scheitern, die genauer in den Spezifikationen der OpenGL-Shadersprache aufgelistet sind. Ob die Kompilierung erfolgreich war, kann aus dem Informationslog des Shaderobjektes via [[glGetInfoLogARB]] ermittelt werden.
  
 
Seit der OpenGL Version 2.0 ist '''glCompileShader''' im Kern enthalten. Die alte ARB Bezeichnung war '''glCompileShaderARB'''.
 
Seit der OpenGL Version 2.0 ist '''glCompileShader''' im Kern enthalten. Die alte ARB Bezeichnung war '''glCompileShaderARB'''.
<br>
+
 
 +
 
 +
 
 
== Fehlermeldungen ==
 
== Fehlermeldungen ==
'''GL_INVALID_VALUE''' wird generiert wenn der Shader kein gültiges OpenGL-Handle ist.
+
'''GL_INVALID_VALUE''' wird generiert, wenn der Shader kein gültiges OpenGL-Handle ist.
  
'''GL_INVALID_OPERATION''' wird generiert wenn der Shader nicht vom Typ ''GL_SHADER_OBJECT'' ist.
+
'''GL_INVALID_OPERATION''' wird generiert, wenn der Shader nicht vom Typ '''GL_SHADER_OBJECT''' ist.
  
'''GL_INVALID_OPERATION''' wird generiert wenn '''glCompileShaderARB''' zwischen einem [[glBegin]] und dem passenden [[glEnd]] aufgerufen wird.
+
'''GL_INVALID_OPERATION''' wird generiert, wenn '''glCompileShaderARB''' zwischen einem [[glBegin]] und dem passenden [[glEnd]] aufgerufen wird.
  
  
Zeile 42: Zeile 43:
 
[[glGetInfoLog]] mit dem Argument ''shaderObj''.
 
[[glGetInfoLog]] mit dem Argument ''shaderObj''.
  
[[glGetObjectParameterARB]] mit den Argumenten ''shaderObj'' und ''GL_OBJECT_COMPILE_STATUS''.  
+
[[glGetObjectParameterARB]] mit den Argumenten ''shaderObj'' und '''GL_OBJECT_COMPILE_STATUS'''.  
  
  
Zeile 48: Zeile 49:
 
== Siehe auch ==
 
== Siehe auch ==
 
[[glCreateShaderObjectARB]], [[glLinkProgram]], [[glShaderSource]]<br>
 
[[glCreateShaderObjectARB]], [[glLinkProgram]], [[glShaderSource]]<br>
'''Hintergrundwissen :''' [[Shader]]<br>
+
'''Hintergrundwissen :''' [[Shader]]
 +
 
 
[http://developer.3dlabs.com/openGL2/slapi/CompileShaderARB.htm Englische Originalversion]  (Copyright 3DLabs Inc.)
 
[http://developer.3dlabs.com/openGL2/slapi/CompileShaderARB.htm Englische Originalversion]  (Copyright 3DLabs Inc.)
 
[[Kategorie:GL|CompileShader]]
 
[[Kategorie:GL|CompileShader]]
 +
[[Kategorie:GL2.0|CompileShader]]
 
[[Kategorie:SHADER_OBJECTS|CompileShader]]
 
[[Kategorie:SHADER_OBJECTS|CompileShader]]

Version vom 26. Mai 2008, 15:00 Uhr

glCompileShader (glCompileShaderARB)

Name

glCompileShader - Kompiliert ein Shaderobjekt.


Delphi-Spezifikation

procedure glCompileShader(shaderObj : GLHandle);
procedure glCompileShaderARB(shaderObj : GLHandleARB);


Parameter

shaderObj Handle des zu kompilierenden Shaderobjektes.


Beschreibung

glCompileShader kompiliert den Quellcode der im Shaderobjekt abgelegt ist, wobei der Status der Kompilation als Teil des Objektstatus des Shaderobjektes gespeichert wird. Dieser Wert ist True, wenn der Shader ohne Fehler kompiliert wurde und bereit zur Nutzung ist, und ansonsten False. Er kann mittels glGetObjectParameterARB und dem Shader sowie GL_OBJECT_COMPILE_STATUS als Argument abgefragt werden.

Die Kompilierung des Shaders kann aus vielerlei Gründen scheitern, die genauer in den Spezifikationen der OpenGL-Shadersprache aufgelistet sind. Ob die Kompilierung erfolgreich war, kann aus dem Informationslog des Shaderobjektes via glGetInfoLogARB ermittelt werden.

Seit der OpenGL Version 2.0 ist glCompileShader im Kern enthalten. Die alte ARB Bezeichnung war glCompileShaderARB.


Fehlermeldungen

GL_INVALID_VALUE wird generiert, wenn der Shader kein gültiges OpenGL-Handle ist.

GL_INVALID_OPERATION wird generiert, wenn der Shader nicht vom Typ GL_SHADER_OBJECT ist.

GL_INVALID_OPERATION wird generiert, wenn glCompileShaderARB zwischen einem glBegin und dem passenden glEnd aufgerufen wird.


Zugehörige Wertrückgaben

glGetInfoLog mit dem Argument shaderObj.

glGetObjectParameterARB mit den Argumenten shaderObj und GL_OBJECT_COMPILE_STATUS.


Siehe auch

glCreateShaderObjectARB, glLinkProgram, glShaderSource
Hintergrundwissen : Shader

Englische Originalversion (Copyright 3DLabs Inc.)