Bloom(pseudo-HDR): Unterschied zwischen den Versionen
I0n0s (Diskussion | Beiträge) K (→Konzept) |
I0n0s (Diskussion | Beiträge) (→Umsetzung) |
||
Zeile 23: | Zeile 23: | ||
Es gibt mit neuen Techniken die Möglichkeit den Z-Buffer in eine Textur auszulesen aber diese wären warscheinlich nicht so schnell. | Es gibt mit neuen Techniken die Möglichkeit den Z-Buffer in eine Textur auszulesen aber diese wären warscheinlich nicht so schnell. | ||
− | Wie erstelle ich die Z-Buffer Textur ? | + | Wie erstelle ich also die Z-Buffer Textur ? |
*Modelview Matrix sichern | *Modelview Matrix sichern | ||
− | *Clearcolor von OpenGL auf Weiß oder andere helle Farben(je nach Himmelfarbe) stellen | + | *Clearcolor von OpenGL auf Weiß oder andere helle Farben (je nach Himmelfarbe) stellen |
*Viewport auf eine niedrige Auflösung stellen(z.B. 128x96 oder 64x48) | *Viewport auf eine niedrige Auflösung stellen(z.B. 128x96 oder 64x48) | ||
*alle Puffer löschen | *alle Puffer löschen | ||
− | *Fog aktivieren und die | + | *Fog aktivieren und die Farbe auf schwarz setzen |
*die Szene rendern | *die Szene rendern | ||
*glCopyTexImage2D ausführen | *glCopyTexImage2D ausführen | ||
− | * | + | *Viewport zurück stellen |
*Fog deaktivieren | *Fog deaktivieren | ||
*Modelview Matrix wieder herstellen | *Modelview Matrix wieder herstellen | ||
− | Dies ist eine ziemlich | + | Dies ist eine ziemlich dreckige Methode aber sie funktioniert und ist ziemlich schnell. |
− | Nun muss die Textur in unseren | + | Nun muss die Textur in unseren Arbeitspeicher geladen werden und geblurt werden. |
− | Hierzu verwendet man glGetTexImage und nach dem Blur muss | + | Hierzu verwendet man glGetTexImage und nach dem Blur muss es wieder eine Textur werden, dies macht man mit glTexImage2D. |
− | Was nun ? | + | Was nun? |
*alle Puffer löschen | *alle Puffer löschen | ||
*die Szene rendern | *die Szene rendern | ||
− | * | + | *Blending aktivieren |
*glBlendFunc(GL_ONE,GL_ONE); | *glBlendFunc(GL_ONE,GL_ONE); | ||
*die Textur vom Z-Buffer binden | *die Textur vom Z-Buffer binden | ||
− | *in den | + | *in den orthogonalen Modus wechseln |
*mit glcolor3f(glowing,glowing,glowing) die Deckungsstärke festlegen | *mit glcolor3f(glowing,glowing,glowing) die Deckungsstärke festlegen | ||
− | *ein Quad mit den | + | *ein Quad mit den Ausmaßen des Fensters zeichnen |
− | * | + | *orthogonalen Modus verlassen |
− | * | + | *Blending deaktivieren |
Um den Effekt zu verbessern, kann man noch einen Variable anlegen, die den invertierten Wert von Glowing darstellt. | Um den Effekt zu verbessern, kann man noch einen Variable anlegen, die den invertierten Wert von Glowing darstellt. | ||
Diesen InvGlowing Wert kann man dann mit den Farbwerten der zu zeichnenden Flächen multiplizieren. | Diesen InvGlowing Wert kann man dann mit den Farbwerten der zu zeichnenden Flächen multiplizieren. | ||
So scheint es dann, dass bei hoher Lichtintensität alles dunkler ist als bei niedriger. | So scheint es dann, dass bei hoher Lichtintensität alles dunkler ist als bei niedriger. | ||
− | Diesen Effekt kann man durch eine | + | Diesen Effekt kann man durch eine invertierte Z-Buffer Textur auch erreichen. |
− | Wie man nun die Glowing Variable | + | Wie man nun die Glowing-Variable regelt ist dem Entwickler überlassen. |
− | Man könnte z.B. sagen, | + | Man könnte z.B. sagen, desto näher man mit dem Sichtfeld der Sonne zuwendet, desto höher ist die Variable. |
Alternativ kann man auch den Regler an den Pixel unter dem Cursor abhängig machen. | Alternativ kann man auch den Regler an den Pixel unter dem Cursor abhängig machen. | ||
Version vom 19. März 2006, 18:37 Uhr
Inhaltsverzeichnis
Konzept
Dieser Artikel zeigt, wie man den bei HDR bekannten Bloom Effekt erzeugt. Dieser simuliert den Einfluss von Eigenschaften der menschlichen Pupille. Bei dieser Technik ist eine Hardware nötig die OpenGL1.1 API unterstützt.
Um die Qualität des Effektes zu erhöhen, ist es nötig eine nicht völlig ausgelastete CPU zu haben.
Diese Technik funktioniert nur auf den Hintergrund, nicht auf leuchtende Objekte. |
Zuerst brauchen wir eine Textur, die unseren Z-Buffer darstellt.
Die Textur muss dann geblurt werden, um einen Verlauf an den Rändern der Geometrie zu erzeugen.
Nun wird die geblurte Textur über die zu rendernde Szene übergeblendet.
Umsetzung
Um die Z-Buffer Textur als RGB zu bekommen, ist ein weiterer Fake von nöten. Es gibt mit neuen Techniken die Möglichkeit den Z-Buffer in eine Textur auszulesen aber diese wären warscheinlich nicht so schnell.
Wie erstelle ich also die Z-Buffer Textur ?
- Modelview Matrix sichern
- Clearcolor von OpenGL auf Weiß oder andere helle Farben (je nach Himmelfarbe) stellen
- Viewport auf eine niedrige Auflösung stellen(z.B. 128x96 oder 64x48)
- alle Puffer löschen
- Fog aktivieren und die Farbe auf schwarz setzen
- die Szene rendern
- glCopyTexImage2D ausführen
- Viewport zurück stellen
- Fog deaktivieren
- Modelview Matrix wieder herstellen
Dies ist eine ziemlich dreckige Methode aber sie funktioniert und ist ziemlich schnell.
Nun muss die Textur in unseren Arbeitspeicher geladen werden und geblurt werden. Hierzu verwendet man glGetTexImage und nach dem Blur muss es wieder eine Textur werden, dies macht man mit glTexImage2D.
Was nun?
- alle Puffer löschen
- die Szene rendern
- Blending aktivieren
- glBlendFunc(GL_ONE,GL_ONE);
- die Textur vom Z-Buffer binden
- in den orthogonalen Modus wechseln
- mit glcolor3f(glowing,glowing,glowing) die Deckungsstärke festlegen
- ein Quad mit den Ausmaßen des Fensters zeichnen
- orthogonalen Modus verlassen
- Blending deaktivieren
Um den Effekt zu verbessern, kann man noch einen Variable anlegen, die den invertierten Wert von Glowing darstellt. Diesen InvGlowing Wert kann man dann mit den Farbwerten der zu zeichnenden Flächen multiplizieren. So scheint es dann, dass bei hoher Lichtintensität alles dunkler ist als bei niedriger. Diesen Effekt kann man durch eine invertierte Z-Buffer Textur auch erreichen.
Wie man nun die Glowing-Variable regelt ist dem Entwickler überlassen. Man könnte z.B. sagen, desto näher man mit dem Sichtfeld der Sonne zuwendet, desto höher ist die Variable. Alternativ kann man auch den Regler an den Pixel unter dem Cursor abhängig machen.
Vor- und Nachteile
Vorteile
- sehr schnell
- läuft auf niedriger Hardware
Nachteile
- Qualitative schlechter als über Shader
- Physikalisch nicht korrekt wie bei Shader
Beispiel
Zu sehen sind 3 Quads, die durch das Hintergrundlicht in ihrer Ausläuchtung beeinflusst werden.