glSecondaryColorPointer
Inhaltsverzeichnis
glSecondaryColorPointer
Name
glSecondaryColorPointer - definiert ein Feld, das Zweitfarben enthält.
Delphi-Spezifikation
procedure glSecondaryColorPointer(size: TGLint; _type: TGLenum; stride: TGLsizei; const _pointer: PGLvoid);
Parameter
size | Gibt an aus wievielen Komponenten die Zweitfarbe besteht. (Nur 3 ist gültig.) |
---|---|
_type | Bestimmt den Datentyp jeder Farbcomponente im Feld. Als symbolische Konstanten werden GL_BYTE, GL_UNSIGNED_BYTE, GL_SHORT, GL_UNSIGNED_SHORT, GL_INT, GL_UNSIGNED_INT, GL_FLOAT und GL_DOUBLE akzeptiert. |
stride | Bestimmt den Byteabstand zwischen aufeinenderfolgenden Zweitfarben. Wenn stride 0 (Standard) ist, wird angenommen, dass die Farben in dem Array dicht gepackt liegen. |
_pointer | Bestimmt einen Zeiger auf die erste Zweitfarben-Komponente, der ersten Zweitfarbe im Feld. |
Beschreibung
glSecondaryColorPointer bestimmt den Ort und das Datenformat eines Zweitfarben-Komponenten-Arrays, das zum Rendern benutzt werden soll. size bestimmt die Anzahl an Komponenten pro Farbe und muss 3 sein. _type bestimmt den Datentyp jeder Farbkomponente. stride legt den Abstand zwischen den Farben fest, was ermöglicht, dass Vertices und Attribute im einem einzelnen oder aber verschiedenen Arrays liegen. (Einzelspeicherung kann in einigen Implementationen effizienter sein; siehe glInterleavedArrays)
Wenn ein Zweitfarb-Array festgelegt wird, werden size, _type, stride und _pointer als klientseitiger Status gespeichert.
Um das Zweitfarb-Array ein- und auszuschalten, können glEnableClientState und glDisableClientState mit dem Argument GL_SECONDARY_COLOR_ARRAY aufgerufen werden. Wenn aktiviert, wird das Zweitfarb-Array bei Aufrufen von glDrawArrays, glDrawElements, glDrawRangeElements, glMultiDrawArrays, glMultiDrawElements und glArrayElement benutzt.
Hinweise
glSecondaryColorPointer ist erst ab OpenGL Version 1.4 oder später verfügbar.
Im Initialisierungszustand ist das Zweitfarbfeld deaktiviert und wird von glArrayElement, glDrawArrays bzw. glDrawElements nicht benutzt, wenn diese Befehle aufgerufen werden.
Ein Aufruf von glSecondaryColorPointer innerhalb eines glBegin-glEnd Blocks ist nicht erlaubt. Trotzdem kann es sein, dass kein Fehler generiert wird. Wenn dies geschieht, ist die Operation undefiniert.
glSecondaryColorPointer ist normalerweise auf der Klientseite implementiert.
Zweitfarbfeld-Parameter werden klientseitig gespeichert und können deshalb nicht mit glPushAttrib und glPopAttrib gespeichert bzw. wiederhergestellt werden. Benutzen Sie stattdessen glPushClientAttrib und glPopClientAttrib.
Fehlermeldungen
- GL_INVALID_VALUE
- size hat einen anderen Wert als 3.
- GL_INVALID_ENUM
- _type wurde ein ungültiger Wert zugewiesen.
- GL_INVALID_VALUE
- stride ist negativ.
Zugehörige Wertrückgaben
glIsEnabled mit dem Token GL_SECONDARY_COLOR_ARRAY
glGet mit Token GL_SECONDARY_COLOR_ARRAY_SIZE
glGet mit Token GL_SECONDARY_COLOR_ARRAY_TYPE
glGet mit Token GL_SECONDARY_COLOR_ARRAY_STRIDE
glGetPointerv mit dem Token GL_SECONDARY_COLOR_ARRAY_POINTER
Siehe auch
glArrayElement, glColorPointer, glDrawArrays, glDrawElements, glDrawRangeElements, glEdgeFlagPointer, glEnable, glFogCoordPointer, glGetPointerv, glIndexPointer, glInterleavedArrays, glMultiDrawArrays, glMultiDrawElements, glNormalPointer, glPopClientAttrib, glPushClientAttrib, glSecondaryColor, glTexCoordPointer, glVertexPointer