glLoadMatrix: Unterschied zwischen den Versionen

Aus DGL Wiki
Wechseln zu: Navigation, Suche
K (Siehe auch)
K (Beispiel-Quelltext)
 
(13 dazwischenliegende Versionen von 8 Benutzern werden nicht angezeigt)
Zeile 1: Zeile 1:
 
= glLoadMatrix =
 
= glLoadMatrix =
  
<br>
+
 
 +
 
 
== Name ==
 
== Name ==
'''glLoadMatrix''' - ersetzt die aktuelle Matrix durch eine Beliebige Matrix.
+
'''glLoadMatrix''' - ersetzt die aktuelle Matrix durch eine beliebige Matrix.
 +
 
 +
 
  
<br>
 
  
 
== Delphi-Spezifikation ==
 
== Delphi-Spezifikation ==
  '''procedure''' glLoadMatrixd('''const''' ''m'': PGLdouble); <br>
+
  '''procedure''' glLoadMatrixd('''const''' ''m'': PGLdouble);
 
  '''procedure''' glLoadMatrixf('''const''' ''m'': PGLfloat);
 
  '''procedure''' glLoadMatrixf('''const''' ''m'': PGLfloat);
  
<br>
+
 
 +
 
 
== Parameter ==
 
== Parameter ==
<table border=1 rules=all>
+
{| border="1" rules="all"
<tr>
+
! ''m''
<td>''m''</td>
+
| Ein Zeiger auf eine 4x4-Matrix, welche die aktuelle Matrix ersetzen soll.
<td>Zeiger auf eine 4x4 Matrix welche die aktuelle Matrix ersetzen soll.</td>
+
|}
</tr>
+
 
</table>
+
 
  
<br>
 
 
== Beschreibung ==  
 
== Beschreibung ==  
'''glLoadMatrix''' ersetzt die aktuelle Matrix durch die, über ''m'' definierte.<br>
+
'''glLoadMatrix''' ersetzt die aktuelle Matrix durch die 4x4-Matrix, auf die ''m'' zeigt. Abhängig vom aktuellen Matrix-Modus ([[glMatrixMode]]) wird dadurch die Projektions-Matrix, die Modelview-Matrix oder die Texture-Matrix ersetzt (siehe dazu [[Matrix#Die_drei_OpenGL_Matrizen|"Die drei OpenGL-Matrizen"]]).
Die aktuelle Matrix ist entweder die Projektionsmatrix, die Modelviewmatrix oder die Texturematrix (je nach aktuellem Matrixmodus ([[glMatrixMode]]) ). <br>
+
 
Der Parameter ''m'' zeigt auf eine 4x4 Matrix welche spaltenweise Fließkommazahlen mit einfacher oder doppelter Genauigkeit enthält (single oder double). <br>
+
Der Parameter ''m'' zeigt auf eine 4x4-Matrix, welche spaltenweise Fließkommazahlen mit einfacher oder doppelter Genauigkeit (Single oder Double) enthält.
 +
 
 +
Die Matrix muß also in der folgenden Reihenfolge gespeichert sein:
  
Die Matrix wird somit in folgender Reihenfolge gespeichert:<br>
 
  
 
  +-          -+
 
  +-          -+
Zeile 35: Zeile 38:
 
  +-          -+
 
  +-          -+
  
===Beispiel-Quelltext===
 
{| border="1"
 
|+Als Ersatzt für [[glPushMatrix]] / [[glPopMatrix]]:
 
|
 
<b>type</b>
 
  TVektor = <b>record</b> X,Y,Z,W:glFloat <b>end</b>;
 
  TMatrix = <b>array</b>[(mat_XAchse,mat_YAchse,mat_ZAchse,mat_Position)] <b>of</b> TVertex;
 
  
<b>var</b>
 
  TempMatrix:TMatrix;
 
<b>begin</b>
 
  glClearColor(0,0,0,0);
 
  glClear(GL_COLOR_BUFFER_BIT or GL_DEPTH_BUFFER_BIT);
 
  glMatrixMode(GL_MODELVIEW);
 
  glLoadIdentity; 
 
  
  glTranslatef(-0.8,-0.5,0); <font color="#000080"><i>//Vorgebene Startposition</i></font>
+
== Beispiel-Quelltext ==
  glGetFloatv(GL_MODELVIEW_MATRIX,@TempMatrix);<font color="#000080"><i>//Matrix wird gespeichert
+
Als Ersatz für [[glPushMatrix]] und [[glPopMatrix]]:
  
  {Rotes Dreieck}</i></font>
+
<source lang="pascal">type
   glColor3f(1,0,0);
+
   TMatrix = array[0..3, 0..3] of glFloat;
   gltranslatef(1,0,0);
+
var
  glbegin(GL_TRIANGLES);
+
   TempMatrix: TMatrix;
    glvertex3f(1,0  ,-2);
+
begin
    glvertex3f(0,1 ,-2);
+
glClearColor(0.0, 0.0, 0.0, 0.0);
    glvertex3f(0,0 ,-2);
+
glClear(GL_COLOR_BUFFER_BIT or GL_DEPTH_BUFFER_BIT);
  glend;
+
glMatrixMode(GL_MODELVIEW);
  glLoadMatrixf(@TempMatrix);<font color="#000080"><i>//Gespeicherte Matrix wird wieder geladen
+
  glLoadIdentity;   
  
  {Grünes Dreieck}</i></font>
+
glTranslatef(-0.8, -0.5, 0.0);                // Vorgebene Startposition
  glColor3f(0,1,0);
+
glGetFloatv(GL_MODELVIEW_MATRIX, @TempMatrix); // Matrix wird gespeichert
  glbegin(GL_TRIANGLES);
+
 
    glvertex3f(1,0 ,-2);
+
// Rotes Dreieck
    glvertex3f(0,1 ,-2);
+
glColor3f(1.0, 0.0, 0.0);
    glvertex3f(0,0 ,-2);
+
glTranslatef(1.0, 0.0, 0.0);
  glend;
+
glBegin(GL_TRIANGLES);
  <b>end;</b>
+
  glVertex3f(1.0, 0.0, -2.0);
|}
+
  glVertex3f(0.0, 1.0, -2.0);
 +
  glVertex3f(0.0, 0.0, -2.0);
 +
glEnd;
 +
  glLoadMatrixf(@TempMatrix); // Gespeicherte Matrix wird wieder geladen
  
<br>
+
// Grünes Dreieck
 +
glColor3f(0.0, 1.0, 0.0);
 +
glBegin(GL_TRIANGLES);
 +
  glVertex3f(1.0, 0.0, -2.0);
 +
  glVertex3f(0.0, 1.0, -2.0);
 +
  glVertex3f(0.0, 0.0, -2.0);
 +
glEnd;
 +
end;</source>
  
 
== Fehlermeldungen ==
 
== Fehlermeldungen ==
GL_INVALID_OPERATION wird generiert wenn glLoadMatrix innerhalb eines [[glBegin]]-[[glEnd]] Blocks aufgerufen wird.
+
'''GL_INVALID_OPERATION''' wird generiert, wenn ''glLoadMatrix'' innerhalb eines [[glBegin]]-[[glEnd]]-Blocks aufgerufen wird.
<br>
+
 
 +
 
 +
 
 
==  Zugehörige Wertrückgaben ==
 
==  Zugehörige Wertrückgaben ==
[[glGet]] mit Token GL_MATRIX_MODE<br>
+
[[glGet]] mit Token [[glGet#GL_MATRIX_MODE|GL_MATRIX_MODE]]
[[glGet]] mit Token GL_MODELVIEW_MATRIX<br>
+
 
[[glGet]] mit Token GL_PROJECTION_MATRIX<br>
+
[[glGet]] mit Token [[glGet#GL_MODELVIEW_MATRIX|GL_MODELVIEW_MATRIX]]
[[glGet]] mit Token GL_TEXTURE_MATRIX<br>
+
 
 +
[[glGet]] mit Token [[glGet#GL_PROJECTION_MATRIX|GL_PROJECTION_MATRIX]]
 +
 
 +
[[glGet]] mit Token [[glGet#GL_TEXTURE_MATRIX|GL_TEXTURE_MATRIX]]
 +
 
 +
 
  
<br>
 
 
== Siehe auch ==
 
== Siehe auch ==
 
[[glLoadIdentity]], [[glMatrixMode]], [[glMultMatrix]], [[glPushMatrix]]
 
[[glLoadIdentity]], [[glMatrixMode]], [[glMultMatrix]], [[glPushMatrix]]
  
 
[[Kategorie:GL|LoadMatrix]]
 
[[Kategorie:GL|LoadMatrix]]
 +
[[Kategorie:GL1.0|LoadMatrix]]

Aktuelle Version vom 22. Juni 2018, 17:36 Uhr

glLoadMatrix

Name

glLoadMatrix - ersetzt die aktuelle Matrix durch eine beliebige Matrix.



Delphi-Spezifikation

procedure glLoadMatrixd(const m: PGLdouble);
procedure glLoadMatrixf(const m: PGLfloat);


Parameter

m Ein Zeiger auf eine 4x4-Matrix, welche die aktuelle Matrix ersetzen soll.


Beschreibung

glLoadMatrix ersetzt die aktuelle Matrix durch die 4x4-Matrix, auf die m zeigt. Abhängig vom aktuellen Matrix-Modus (glMatrixMode) wird dadurch die Projektions-Matrix, die Modelview-Matrix oder die Texture-Matrix ersetzt (siehe dazu "Die drei OpenGL-Matrizen").

Der Parameter m zeigt auf eine 4x4-Matrix, welche spaltenweise Fließkommazahlen mit einfacher oder doppelter Genauigkeit (Single oder Double) enthält.

Die Matrix muß also in der folgenden Reihenfolge gespeichert sein:


+-           -+
| 0  4  8  12 |
| 1  5  9  13 |
| 2  6  10 14 |
| 3  7  11 15 |
+-           -+


Beispiel-Quelltext

Als Ersatz für glPushMatrix und glPopMatrix:

type
  TMatrix = array[0..3, 0..3] of glFloat;
var
  TempMatrix: TMatrix;
begin
 glClearColor(0.0, 0.0, 0.0, 0.0);
 glClear(GL_COLOR_BUFFER_BIT or GL_DEPTH_BUFFER_BIT);
 glMatrixMode(GL_MODELVIEW);
 glLoadIdentity;  

 glTranslatef(-0.8, -0.5, 0.0);                 // Vorgebene Startposition
 glGetFloatv(GL_MODELVIEW_MATRIX, @TempMatrix); // Matrix wird gespeichert

 // Rotes Dreieck
 glColor3f(1.0, 0.0, 0.0);
 glTranslatef(1.0, 0.0, 0.0);
 glBegin(GL_TRIANGLES);
   glVertex3f(1.0, 0.0, -2.0);
   glVertex3f(0.0, 1.0, -2.0);
   glVertex3f(0.0, 0.0, -2.0);
 glEnd;
 glLoadMatrixf(@TempMatrix); // Gespeicherte Matrix wird wieder geladen

 // Grünes Dreieck
 glColor3f(0.0, 1.0, 0.0);
 glBegin(GL_TRIANGLES);
   glVertex3f(1.0, 0.0, -2.0);
   glVertex3f(0.0, 1.0, -2.0);
   glVertex3f(0.0, 0.0, -2.0);
 glEnd;
end;

Fehlermeldungen

GL_INVALID_OPERATION wird generiert, wenn glLoadMatrix innerhalb eines glBegin-glEnd-Blocks aufgerufen wird.


Zugehörige Wertrückgaben

glGet mit Token GL_MATRIX_MODE

glGet mit Token GL_MODELVIEW_MATRIX

glGet mit Token GL_PROJECTION_MATRIX

glGet mit Token GL_TEXTURE_MATRIX


Siehe auch

glLoadIdentity, glMatrixMode, glMultMatrix, glPushMatrix