Bloom(pseudo-HDR): Unterschied zwischen den Versionen

Aus DGL Wiki
Wechseln zu: Navigation, Suche
(Konzept)
K (Ein paar Links eingefügt um diesen Artikel aus der Sackgasse zu holen)
Zeile 26: Zeile 26:
 
*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 Farbe auf schwarz setzen
+
*[[Fog]] aktivieren und die Farbe auf schwarz setzen
 
*die Szene rendern
 
*die Szene rendern
*glCopyTexImage2D ausführen
+
*[[glCopyTexImage2D]] ausführen
 
*Viewport zurück stellen
 
*Viewport zurück stellen
 
*Fog deaktivieren
 
*Fog deaktivieren
Zeile 44: Zeile 44:
 
*die Szene rendern
 
*die Szene rendern
 
*Blending aktivieren
 
*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 orthogonalen Modus wechseln
+
*in den [[glOrtho|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 Ausmaßen des Fensters zeichnen
 
*ein Quad mit den Ausmaßen des Fensters zeichnen

Version vom 30. Januar 2008, 19:37 Uhr

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.

Info DGL.png Diese Technik funktioniert nur auf den Hintergrund, nicht auf leuchtende Objekte.


Zuerst brauchen wir eine Textur, die unseren Z-Buffer darstellt.

fake z-buffer.png

Die Textur muss dann geblurt werden, um einen Verlauf an den Rändern der Geometrie zu erzeugen.

fake z-buffer-blured.png

Nun wird die geblurte Textur über die zu rendernde Szene übergeblendet.

fake z-buffer-blured.png+szene.png=composit.png

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

  • Qualitativ schlechter als über Shader
  • Physikalisch nicht korrekt wie bei Shadern

Beispiel

Zu sehen sind 3 Quads, die durch das Hintergrundlicht in ihrer Ausleuchtung beeinflusst werden.

Ressourcen