glPushName

Aus DGL Wiki
(Weitergeleitet von GlPushName)
Wechseln zu: Navigation, Suche

glPushName, glPopName

Name

glPushName, glPopName - setzt bzw. nimmt einen Eintrag vom Namenstack.



Delphi-Spezifikation

procedure glPushName(name: GLuint);
procedure glPopName();


Parameter

name Der Eintrag, der auf dem Namenstack hinzugefügt werden soll.


Beschreibung

Unter einem Namen sollte man in diesem Fall nicht an einen String denken, sondern an eine Zahl in Form einer ID. Der Namenstack wird während des Selektions-Modus benutzt, um eine eindeutige Identifizierung von Render-Anweisungen zu ermöglichen. Der Namestack besteht aus vorzeichenlosen Integern und ist zu Beginn leer.

glPushName fügt einen neuen Namen dem Stack hinzu, während glPopName den obersten Eintrag vom Stack entfernt.

Die maximale Größe des Namenstack hängt von der Implementierung ab. Um herauszufinden, welche Größe auf dem System maximal unterstützt wird, kann man glGet mit dem Parameter GL_MAX_NAME_STACK_DEPTH aufrufen. Es wird als Fehler angesehen, wenn ein Name zu einem vollen Stack hinzugefügt wird oder es versucht wird, einen Eintrag aus einem leeren Stack zu entfernen. Ebenfalls wird es als Fehler angesehen, den Namestack während eines Aufrufes von glBegin und dem dazugehörigen glEnd zu manipulieren. In allen diesen Fällen wird das Error Flag gesetzt und keine weiteren Veränderungen durchgeführt.

Der Namenstack ist immer leer, wenn der Rendermodus nicht GL_SELECT entspricht. Aufrufe von glPushName oder glPopName werden werden ebenfalls ignoriert, sollte der Rendermodus nicht auf GL_SELECT gesetzt sein.


Fehlermeldungen

GL_STACK_OVERFLOW wird generiert, falls glPushName aufgerufen wird, während der Namenstack voll ist.

GL_STACK_UNDERFLOW wird generiert, wenn glPopName aufgerufen wird, während der Namenstack leer ist.

GL_INVALID_OPERATION wird generiert, falls glPushName oder glPopName zwischen glBegin und dem zugehörigen Aufruf von glEnd aufgerufen werden.


Zugehörige Wertrückgaben


Siehe auch

glInitNames, glLoadName, glRenderMode, glSelectBuffer