glNormal: Unterschied zwischen den Versionen

Aus DGL Wiki
Wechseln zu: Navigation, Suche
(Version Hochgeladen)
(Delphi-Spezifikation an Vorlage angepasst. Bitte auch an Vorlage halten, und stdcalls weglassen.)
Zeile 8: Zeile 8:
 
== Delphi-Spezifikation ==
 
== Delphi-Spezifikation ==
 
----
 
----
procedure glNormal3b(nx: TGLbyte; ny: TGLbyte; nz: TGLbyte); stdcall; <br>
+
procedure '''glNormal3b'''(''nx'': TGLbyte; ''ny'': TGLbyte; ''nz'': TGLbyte);<br>
procedure glNormal3d(nx: TGLdouble; ny: TGLdouble; nz: TGLdouble); stdcall;  <br>
+
procedure '''glNormal3d'''(''nx'': TGLdouble; ''ny'': TGLdouble; ''nz'': TGLdouble);<br>
procedure glNormal3f(nx: TGLfloat; ny: TGLfloat; nz: TGLfloat); stdcall;  <br>
+
procedure '''glNormal3f'''(''nx'': TGLfloat; ''ny'': TGLfloat; ''nz'': TGLfloat);<br>
procedure glNormal3i(nx: TGLint; ny: TGLint; nz: TGLint); stdcall; <br>
+
procedure '''glNormal3i'''(''nx'': TGLint; ''ny'': TGLint; ''nz'': TGLint);<br>
procedure glNormal3s(nx: TGLshort; ny: TGLshort; nz: TGLshort); stdcall;  <br>
+
procedure '''glNormal3s'''(''nx'': TGLshort; ''ny'': TGLshort; ''nz'': TGLshort);<br>
  
procedure glNormal3bv(const v: PGLbyte); stdcall; <br>  
+
procedure '''glNormal3bv'''(const ''v'': PGLbyte);<br>  
procedure glNormal3dv(const v: PGLdouble); stdcall; <br>     
+
procedure '''glNormal3dv'''(const ''v'': PGLdouble);<br>     
procedure glNormal3fv(const v: PGLfloat); stdcall; <br>
+
procedure '''glNormal3fv'''(const ''v'': PGLfloat);<br>
procedure glNormal3iv(const v: PGLint); stdcall; <br>
+
procedure '''glNormal3iv'''(const ''v'': PGLint);<br>
procedure glNormal3sv(const v: PGLshort); stdcall; <br>
+
procedure '''glNormal3sv'''(const ''v'': PGLshort);<br>
  
 
<br>
 
<br>

Version vom 21. Juli 2004, 09:11 Uhr

glNormal


Name


glnormal - setzt die aktuell gültige Normale.

Delphi-Spezifikation


procedure glNormal3b(nx: TGLbyte; ny: TGLbyte; nz: TGLbyte);
procedure glNormal3d(nx: TGLdouble; ny: TGLdouble; nz: TGLdouble);
procedure glNormal3f(nx: TGLfloat; ny: TGLfloat; nz: TGLfloat);
procedure glNormal3i(nx: TGLint; ny: TGLint; nz: TGLint);
procedure glNormal3s(nx: TGLshort; ny: TGLshort; nz: TGLshort);

procedure glNormal3bv(const v: PGLbyte);
procedure glNormal3dv(const v: PGLdouble);
procedure glNormal3fv(const v: PGLfloat);
procedure glNormal3iv(const v: PGLint);
procedure glNormal3sv(const v: PGLshort);


Parameter


Version mit 3 einzelparametern (glNormal3*)

nx, ny, nz Spezifizieren die x, y und z Koordinaten der neuen Normale.

Version mit Parameterfeld (glNormal3*v)

v v ist ein Pointer auf ein Feld welches 3 Werte enthält. Diese 3 Werte stellen die x, y und z Koordinaten der neuen Normale dar.

Initialisiert ist die Normale mit den Werten (0,0,1).

Beschreibung


Die aktuelle Normale wird immer dann auf die Übergebenen Koordinaten ausgerichtet, wenn glNormal aufgerufen wird.
Parameter in Byte, Short oder Integer Typen werden so in Fließkommazahlen umgerechnet, dass die kleinstmögliche Zahl des Paramtertyps zu -1.0 und die größtmögliche Zahl zu 1.0 wird.


Hinweise


  • Normalisierte Normalen
 - Normalen die mit glNormal gesetzt werden, müssen keine Einheitslänge haben. (||n|| <> 1)
 - Wenn Normalisierung aktiviert wurde, wird die Normale nach der Transformation normalisiert.
 - Normalisierung kann mittels  glEnable/glDisable kontrolliert werden.
 - Standardmäßig ist Normalisierung deaktiviert.
  • Die Normale kann zu jeder Zeit neu gesetzt werden. So kann glNormal auch innerhalb von glBegin-glEnd Blöcken aufgerufen werden.


Fehlermeldungen


keine


Zugehörige Wertrückgaben


glGet mit Token GL_CURRENT_NORMAL
glIsEnabled mit GL_NORMALIZE


Siehe auch


glBegin, glColor, glIndex, glTexCoord, glVertex