glDepthRange: Unterschied zwischen den Versionen
Flash (Diskussion | Beiträge) K (Wird offline bearbeitet) |
Flash (Diskussion | Beiträge) (Version Hochgeladen) |
||
Zeile 1: | Zeile 1: | ||
− | = | + | = glDepthRange = |
− | = | + | <br> |
+ | == Name == | ||
+ | '''glDepthRange''' - bestimmt, wie z-Werte von normalisierten Gerätekoordinaten (Device coordinates) zu Fensterkoordinaten (Window coordinates) umgerechnet werden. | ||
+ | |||
+ | <br> | ||
+ | == Delphi-Spezifikation == | ||
+ | procedure '''glDepthRange'''(''zNear'': TGLclampd; ''zFar'': TGLclampd); | ||
+ | |||
+ | <br> | ||
+ | == Parameter == | ||
+ | <table border=1 rules=all> | ||
+ | <tr> | ||
+ | <td>''near''</td> | ||
+ | <td>Beschreibt, wie die nache [[Clipping Plane]] in Fensterkoordinaten umgerechnet werden soll.<br> | ||
+ | '''Vorgabewert''' ist 0.</td> | ||
+ | </tr> | ||
+ | <tr> | ||
+ | <td>''far''</td> | ||
+ | <td>Beschreibt, wie die ferne [[Clipping Plane]] in Fensterkoordinaten umgerechnet werden soll.<br> | ||
+ | '''Vorgabewert''' ist 0.</td> | ||
+ | </tr> | ||
+ | </table> | ||
+ | |||
+ | <br> | ||
+ | |||
+ | == Beschreibung == | ||
+ | Nach dem die Z-Koordinaten abgeschnitte (clipping) und durch '''w''' geteilt wurden, reichen sie von -1.0 bis 1.0 bezüglich der nahen und fernen [[Clipping Plane]].<br> | ||
+ | '''glDepthRange''' beschreibt, wie die normalisieten Z-Koordinaten linear auf dieses Intervall abgebildet und damit in Fenster-Z-Koordinaten umgerechnet werden.<br> | ||
+ | Ganz egal wie die aktuelle Implementation des [[Tiefenpuffer|Tiefenpuffers]] ist, die Tiefenwerte der Fensterkoordinaten werden immer so behandelt, als ob sie von 0.0 bis 1.0 reichen würden (so wie Farbkomponenten). Das heißt wiederum, dass beide Werte die von '''glDepthRange''' akzeptiert werden auf dieses Intervall heruntergerechnet werden bevor sie akzeptiert werden. | ||
+ | |||
+ | Die '''Vorgabe''' von 0, 1 überträgt die nahe Clipping Plane auf 0 und die ferne auf 1. <br> | ||
+ | Mit dieser Einstellung wird der Tiefenpuffer vollständig ausgenutzt. | ||
+ | |||
+ | <br> | ||
+ | == Hinweise == | ||
+ | Es ist nicht notwendig, dass ''near'' kleiner als ''far'' ist. Umgekehrtes Mapping z.B. mit 1, 0 wird akzeptiert | ||
+ | |||
+ | <br> | ||
+ | == Fehlermeldungen == | ||
+ | GL_INVALID_OPERATION wird generiert wenn '''glDepthRange''' innerhalb eines [[glBegin]]-[[glEnd]] Blocks aufgerufen wird. | ||
+ | |||
+ | <br> | ||
+ | == Zugehörige Wertrückgaben == | ||
+ | [[glGet]] mit Token [[glGet#GL_Depth_Range|GL_Depth_Range]] | ||
+ | |||
+ | <br> | ||
+ | |||
+ | == Siehe auch == | ||
+ | [[glDepthFunc]], [[glViewport]] |
Version vom 26. August 2004, 17:15 Uhr
Inhaltsverzeichnis
glDepthRange
Name
glDepthRange - bestimmt, wie z-Werte von normalisierten Gerätekoordinaten (Device coordinates) zu Fensterkoordinaten (Window coordinates) umgerechnet werden.
Delphi-Spezifikation
procedure glDepthRange(zNear: TGLclampd; zFar: TGLclampd);
Parameter
near | Beschreibt, wie die nache Clipping Plane in Fensterkoordinaten umgerechnet werden soll. Vorgabewert ist 0. |
far | Beschreibt, wie die ferne Clipping Plane in Fensterkoordinaten umgerechnet werden soll. Vorgabewert ist 0. |
Beschreibung
Nach dem die Z-Koordinaten abgeschnitte (clipping) und durch w geteilt wurden, reichen sie von -1.0 bis 1.0 bezüglich der nahen und fernen Clipping Plane.
glDepthRange beschreibt, wie die normalisieten Z-Koordinaten linear auf dieses Intervall abgebildet und damit in Fenster-Z-Koordinaten umgerechnet werden.
Ganz egal wie die aktuelle Implementation des Tiefenpuffers ist, die Tiefenwerte der Fensterkoordinaten werden immer so behandelt, als ob sie von 0.0 bis 1.0 reichen würden (so wie Farbkomponenten). Das heißt wiederum, dass beide Werte die von glDepthRange akzeptiert werden auf dieses Intervall heruntergerechnet werden bevor sie akzeptiert werden.
Die Vorgabe von 0, 1 überträgt die nahe Clipping Plane auf 0 und die ferne auf 1.
Mit dieser Einstellung wird der Tiefenpuffer vollständig ausgenutzt.
Hinweise
Es ist nicht notwendig, dass near kleiner als far ist. Umgekehrtes Mapping z.B. mit 1, 0 wird akzeptiert
Fehlermeldungen
GL_INVALID_OPERATION wird generiert wenn glDepthRange innerhalb eines glBegin-glEnd Blocks aufgerufen wird.
Zugehörige Wertrückgaben
glGet mit Token GL_Depth_Range