Shadersammlung: Unterschied zwischen den Versionen

Aus DGL Wiki
Wechseln zu: Navigation, Suche
K (Radial Blur Zusammenfassung verändert)
Zeile 1: Zeile 1:
Die DGL Shadersammlung soll euch helfen Shader für OpenGL zu finden.  
+
==Was sind Shader?==
 +
Die traditionelle Funktionspipeline der OpenGL ist sehr beschränkt, neuere Algorithmen erfordern eine viel höhere Flexibilität. [[Shader]] sind kleine Programme die es erlauben Teile der Funktionspipeline völlig frei zu programmieren. Dies bietet völlig neue Möglichkeiten. Auf der einen Seite sind Shader für Einsteiger eine gewisse Hürde, auf der anderen Seite können sie viele Dinge aber auch enorm vereinfachen. Aus diesem Grund wurde in OpenGL 3.1 sowie OpenGL ES 2.0 wurde die feste Funktionspipeline entfernt, so dass Shader dort verpflichtend sind.
  
=Organisation=
+
Der Artikel [[Shader]] gibt einen ausführlichen Überblick zum Thema sowie eine [[Shader#Wie_geht_es_nun_weiter.3F|Linksammlung]] für den Einstieg.
==Aufbau==
 
Für den Anfang wird die Shadersammlung nicht gegliedert. Mit wachsender Anzahl der verlinkten Shader wird sich dies ändern.
 
{{Hinweis|Die Shadersammlung braucht eure Hilfe um zu wachsen. Wenn ihr Shader bereitstellen könntet wäre dies ein toller Dienst für die Community.<br><br>
 
''The shader collection is still in an early phase. If you can publish one of your shaders here, this would be a great thing for the community.''}}
 
  
 +
==Shader hinzufügen==
 +
Die Shadersammlung braucht deine Hilfe um zu wachsen. Wenn du einen Shader bereitstellen könntest wäre dies ein toller Dienst für die Community.
  
==Vorlage==
+
Wer einen Shader zur Shadersammlung hinzufügen möchte, findet am Ende dieses Seite eine [[#Vorlage|Vorlage]].
Falls ihr einen Shader bereitstellen wollt sind drei Dinge nötig:
 
# Kopiert die nachfolgende Vorlage ans Ende der Shaderliste und tragt die passenden Daten ein.
 
# Erstellt einen neuen Shaderartikel den ihr in der eingefügten Zeile verlinkt. Benutzt dazu die [[Shaderartikelvorlage]]. Shaderartikel müssen mit '''shader_''' benannt sein. ''z.B. shader_Wasser2d'' für einen 2D Wassershader.
 
# Da Shader zu 90% optische Effekte bewirken, sollte (mindestens) ein aussagekräftiges Beispielbild im Shaderartikel hinterlegt werden. Das Bild muss dann auch hier in der Liste verlinkt werden.
 
  
Fügt folgenden Code ans Ende der Shaderliste an:
+
==Schwierigkeitsgrad==
!<nowiki>[[shader_HierNameEintragen]]</nowiki>
+
Es ist nicht leicht einen Schwierigkeitsgrad für Shader anzugeben, trotzdem haben wir dies einmal versucht. Der Schwierigkeitsgrad kann zumindest für Einsteiger einen groben Hinweis geben was man sich vielleicht mal anschauen könnte.
!HierNameEintragen
+
{|{{Prettytable_B1}} style="margin-left:50px;"
!Autorname
+
| {{TableHead}} | {{ShaderLevel|1}}
!Was macht der Shader.<nowiki><br></nowiki>
+
| Der Shader ist für Einsteiger geeignet. Um den Shader herum wird keine zusätzliche Infrastruktur benötigt.
''What does the shader do.''*
+
|-
!<nowiki>[[Bild:Beispielbild.jpg|150px|150px]]</nowiki>
+
| {{TableHead}} | {{ShaderLevel|2}}
 +
| Der Shader ist für Einsteiger geeignet, benötigt aber etwas zusätzliche Infrastruktur. Etwa benötigt ein Post-Processing-Shader ein FrameBufferObject, für Bumpmapping wird eine Normalmap benötigt.
 +
|-
 +
| {{TableHead}} | {{ShaderLevel|3}}
 +
| Mittlerer Schwierigkeitsgrad. Der Shader ist etwas komplizierter und/oder benötigt viel zusätzliche Infrastruktur.
 +
|-
 +
| {{TableHead}} | {{ShaderLevel|4}}
 +
| Hoher Schwierigkeitsgrad. Der Shader ist kompliziert und/oder verwendet intensiv Extensions.
 +
|-
 +
| {{TableHead}} | {{ShaderLevel|5}}
 +
| Extremer Schwierigkeitsgrad...alles was es sonst noch gibt.
 +
|}
  
''* Die englische Beschreibung ist freiwillig. Hilft aber bestimmt den Shader zu verbreiten. Die deutsche Beschreibung ist Pflicht.''
+
==GLSL-Shader==
 +
Die hier gelisteten Shader sind in Kategorien aufgeteilt. Weitere Kategorien dürfen bei Bedarf einfach ergänzt werden.
  
 
+
===Beleuchtung und Texturen===
Für euren neuen Shaderartikel sollte diese [[Shaderartikelvorlage]] benutzt werden. (Vorlage aufrufen, bearbeiten klicken, Alles kopieren und in euren neuen Shaderartikel einfügen.)
+
Diese Kategorie umfasst alles vom einfachen Fixed-Function-Pipeline-Ersatz über PerPixel-Licht und Bumpmapping bis zu ShadowMaps. Der Shader-Einsteiger wird in dieser Kategorie sicherlich fündig.
 
 
=Shader=
 
== ARB-Shader ==
 
 
{|{{Prettytable_B1}} width=100%
 
{|{{Prettytable_B1}} width=100%
!width=20%|Link
+
| {{TableHead}}  | [[shader_verysimple|Verysimple]] von [[Benutzer:damadmax|damadmax]] {{ShaderLevel|1}}
!width=20%|Shadername
+
| {{Table150R2}} style="text-align:center;" | (kein Bild vorhanden)
!width=20%|Autor
+
|-
!width=40%|Kurzbeschreibung
+
| {{TableCell}}  | Ein einfacher Shader, welcher eine Textur an Vertices bindet. Dieser Shader baut damit das Standardverhalten der festen Pipeline nach. {{ShaderLink|shader_verysimple}}
!width=150px|Bild
+
|-
 +
| {{TableHead}}  | [[shader_PerPixelLighting|Per Pixel-Beleuchtung]] von [[Benutzer:Ireyon|Ireyon]] {{ShaderLevel|1}}
 +
| {{Table150R2}} | [[Bild:shader_ppl.png|150px|150px]]
 
|-
 
|-
![[shader_surface_scattering(ARB)|shader_surface_scattering]]
+
| {{TableCell}}  | Shader, der Per Pixel beleuchtet. {{ShaderLink|shader_PerPixelLighting}}
!surface scattering
 
!dj3hut1
 
!Bestimmt die Distanz, die Licht durch ein Material zurücklegt.
 
<br>
 
''Calculates the distance of light through a material.''
 
![[Bild:Scattering_s.jpg|150px|150px]]
 
 
|-
 
|-
![[shader_texturing(ARB)|shader_texturing]]
+
| {{TableHead}}  | [[shader_PerPixel_Lighting2|Per Pixel-Beleuchtung2]] von [[Benutzer:Olee|Olee]] {{ShaderLevel|1}}
!texturing
+
| {{Table150R2}} | [[Bild:PPLShader.jpg|150px|150px]]
!dj3hut1
 
!Demonstriert eine einfache Texturierung.
 
<br>
 
''Demonstrates a simple texturing.''
 
![[Bild:Texarb_textured_s.png|166px|150px]]
 
 
|-
 
|-
![[shader_phong_per_pixel(ARB)|shader_phong_per_pixel]]
+
| {{TableCell}}  | Beleuchtet Flächen nach Pixeln anstatt wie OpenGl-Licht je Vertex. Erlaubt unendlich weit entferntes Licht und beachtet [[glFog]]. {{ShaderLink|shader_PerPixel_Lighting2}}
!phong lighting per pixel
 
!dj3hut1
 
!Per-Pixel-Beleuchtung.
 
<br>
 
''Per-pixel-lighting.''
 
![[Bild:Phong_arb_s.png|150px|150px]]
 
 
 
 
|}
 
|}
  
== GLSL-Shader ==
+
===Post-Processing===
 +
Post-Processing-Shader zeichnen sich dadurch aus, dass sie auf die gesamte Szene angewendet werden <u>nachdem</u> diese bereits gerendert wurde. Üblicherweise wird die Szene zuerst mit einem [[FBO|FramebufferObject]] (FBO) in eine Textur gerendert. Anschließend wird diese Textur auf ein bildschirmfüllendes Quad gespannt und mit dem Post-Processing-Shader gerendert.
 
{|{{Prettytable_B1}} width=100%
 
{|{{Prettytable_B1}} width=100%
!width=20%|Link
+
| {{TableHead}}  | [[shader_sepia|Sepia-Shader]] von [[Benutzer:Markus|Markus]] {{ShaderLevel|2}}
!width=20%|Shadername
+
| {{Table150R2}} | [[Bild:shader_sepia_nachher.jpg|150px|150px]]
!width=20%|Autor
 
!width=40%|Kurzbeschreibung
 
!width=150px|Bild
 
 
|-
 
|-
![[shader_verysimple]]
+
| {{TableCell}}  | Post-Processing-Shader, welcher einen Sepia-Farbfilter auf die Szene anwendet. {{ShaderLink|shader_sepia}}
!verysimple
 
(standard texture binding)
 
!damadmax
 
!Ein einfacher Shader, welcher eine Textur an Vertices bindet. Dieser Shader baut damit das standard Texturierungsverhalten der fixen Pipeline nach.<br>
 
''A very simple shader. It only binds a texture on some vertices, thus this shader simulates the standard behavior of a part of the fixed pipeline.''
 
!''Kein Bild vorhanden''
 
 
|-
 
|-
![[shader_sepia]]
+
| {{TableHead}}  | [[shader_radial_blur|Radial Blur]] von [[Benutzer:Markus|Markus]] {{ShaderLevel|2}}
!Sepia
+
| {{Table150R2}} | [[Bild:shader_radial_blur_nachher.jpg|150px|150px]]
!Markus
 
!Post-Processing-Shader, welcher einen Sepia-Farbfilter auf die Szene anwendet.<br>
 
''Post-Processing-Shader which applies a sepia color filter to the scene.''
 
![[Bild:shader_sepia_nachher.jpg|150px|150px]]
 
 
|-
 
|-
![[shader_radial_blur]]
+
| {{TableCell}}  | Post-Processing-Shader, welcher die Szene ausgehend von einem beliebigen Punkt verwischt. {{ShaderLink|shader_radial_blur}}
!Radial Blur
+
|-
!Markus
+
| {{TableHead}}  | [[shader_blur2|Blur-Shader]] von [[Benutzer:Skeptiker|Skeptiker]] und [[Benutzer:Coolcat|Coolcat]] {{ShaderLevel|3}}
!Post-Processing-Shader, welcher die Szene ausgehend von einem beliebigen Punkt verwischt.<br>
+
| {{Table150R2}} | [[Bild:Shader_blur_seerose_blured_small.jpg|150px|150px]]
''Post-Processing-Shader which applies a radial blur to the scene.''
+
|-
![[Bild:shader_radial_blur_nachher.jpg|150px|150px]]
+
| {{TableCell}}  | Post-Processing-Shader, welcher die Szene insgesamt verwischt. Dieser Shader kann beispielsweise genutzt werden um einen Glow-Effekt zu erreichen. {{ShaderLink|shader_blur2}}
 +
|}
 +
 
 +
===Geometrie===
 +
Hier finden sich Shader die die Geometrie entweder komplett neu erzeugen oder stark verändern. Es muss nicht unbedingt Geometryshader oder Instancing sein, auch mit dem Vertexshader kann man schon viel anstellen. Ein klassisches Beispiel ist die Mesh-Animation.
 +
{|{{Prettytable_B1}} width=100%
 +
| {{TableHead}}  | [[shader_Terrain_GPU4|Heightmap-Terrain]] von [[Benutzer:Coolcat|Coolcat]] {{ShaderLevel|3}}
 +
| {{Table150R2}} | [[Bild:Terrain.jpg|150px|150px]]
 
|-
 
|-
![[shader_blur2]]
+
| {{TableCell}}  | Shader für ein Heightmap-Terrain der ShaderModel 4.0 Features nutzt. Das Terrain wird zur Laufzeit fast vollständig aus der Heightmap generiert, was ordentlich Speicherplatz spart. Im Fragmentshader werden drei Texturlayer mit Hilfe einer Alphamap interpoliert {{ShaderLink|shader_Terrain_GPU4}}
!Blur-Shader
+
 
!Skeptiker/Coolcat
+
'''Extensions:'''<br>
!Post-Processing-Shader, welcher die Szene insgesamt verwischt.<br>
+
[[GL_EXT_gpu_shader4]]
''Post-Processing-Shader which applies a blur-effect to the scene.''  
 
![[Bild:Shader_blur_seerose_blured_small.jpg|150px|150px]]
 
 
|-
 
|-
![[shader_PerPixelLighting]]
+
| {{TableHead}}  | [[shader_Instancing|Instancing-Shader]] von [[Benutzer:Coolcat|Coolcat]] {{ShaderLevel|4}}
!Per Pixel-Beleuchtung
+
| {{Table150R2}} | [[Bild:shader_Instancing.jpg|150px|150px]]
!Ireyon
 
!Shader, der Per Pixel beleuchtet<br>
 
''Shader which calculates lighting per pixel''
 
![[Bild:shader_ppl.png|150px|150px]]
 
 
|-
 
|-
![[shader_PerPixel_Lighting2]]
+
| {{TableCell}}  | Dieser Shader zeigt die Benutzung von [[GL_ARB_draw_instanced]]. Ein häufiger Anwendungsfall ist das rendern vieler gleichartiger Objekte. Die Extension beschleunigt derartige Anwendungen, in dem die Anzahl der API-Aufrufe und die Menge redundanter Daten reduziert wird. {{ShaderLink|shader_Instancing}}
!Per-Pixel-Lighting Shader
+
 
!Olee
+
'''Extensions:'''<br>
!Beleuchtet Flächen nach Pixeln anstatt wie OpenGl-Licht je Vertex. Erlaubt unendlich weit entferntes Licht und beachtet [[glFog]]<br>
+
[[GL_ARB_draw_instanced]]<br>
''Iluminates faces per pixel istead of OpenGl-Lighting per Vertex. Allows infinite distance to the light and [[glFog]].''
+
[[GL_EXT_gpu_shader4]]<br>
![[Bild:PPLShader.jpg|150px|150px]]
+
[[GL_EXT_texture_buffer_object]]<br>
 +
[[GL_ARB_texture_float]]
 
|-
 
|-
![[shader_Terrain_GPU4]]
+
| {{TableHead}}  | [[shader_tesselation|Tesselation-Shader]] von [[Benutzer:dj3hut1|dj3hut1]] {{ShaderLevel|4}}
!Heightmap-Terrain
+
| {{Table150R2}} | [[Bild:Tesselation_s.png|150px|150px]]
!Coolcat
 
!Shader für ein Heightmap-Terrain, benutzt [[GL_EXT_gpu_shader4]]<br>
 
''Shader for Heightmap-Terrain, uses [[GL_EXT_gpu_shader4]]''
 
![[Bild:Terrain.jpg|150px|150px]]
 
 
|-
 
|-
![[shader_Zufallsgenerator]]
+
| {{TableCell}}  | Dieser Shader nutzt einen Geometry Shader um ein Dreieck zu tesselieren. {{ShaderLink|shader_tesselation}}
!Pseudozufallsgenerator,<br>Zufallswirbelfeld für Partikel
+
 
!Coolcat
+
'''Extensions:'''<br>
!Pseudozufallszahlen im Shader mit [[GL_EXT_gpu_shader4]].<br>
+
[[GL_ARB_geometry_shader4]]
''Pseudo random numbers in the Shader using [[GL_EXT_gpu_shader4]] and a random turbulence field for particles.''
 
![[Bild:shader_Zufallsgenerator.png|150px|150px]]
 
 
|-
 
|-
![[shader_game_of_life]]
+
| {{TableHead}}  | [[shader_normal_debug|Normal Debugging-Shader]] von [[Benutzer:dj3hut1|dj3hut1]] {{ShaderLevel|4}}
!game of life
+
| {{Table150R2}} | [[Bild:Normal_debug_s.png|113px|150px]]
!dj3hut1  
 
!Simuliert das altbekannte 'Game of Life'.<br>
 
''Simulates the well-known 'Game of Life'.''
 
![[Bild:Game_of_life_s.png|150px|150px]]
 
 
|-
 
|-
![[shader_Instancing]]
+
| {{TableCell}}  | Nützlicher Shader um ohne viel Aufwand die Normalen eines Modells anzuzeigen. {{ShaderLink|shader_normal_debug}}
!Instancing
+
 
!Coolcat
+
'''Extensions:'''<br>
!Benutzung von [[GL_ARB_draw_instanced]]<br>
+
[[GL_ARB_geometry_shader4]]
''Usage of [[GL_ARB_draw_instanced]]''
 
![[Bild:shader_Instancing.jpg|150px|150px]]
 
 
|}
 
|}
  
=== Mit Geometry-Shader ===
+
===Partikel===
 +
Natürlich kann man auch bei einem [[Partikelsystem]] Shader einsetzen. Mit etwas Geschick kann man die gesamte Berechnung sogar vollständig auf die Grafikkarte verlagern um die CPU zu entlasten.
 
{|{{Prettytable_B1}} width=100%
 
{|{{Prettytable_B1}} width=100%
!width=20%|Link
+
| {{TableHead}}  | [[GLSL_Partikel_2|GPU Partikelsystem]] von [[Benutzer:Coolcat|Coolcat]] {{ShaderLevel|5}}
!width=20%|Shadername
+
| {{Table150R2}} | [[Bild:Partikel-Gravitation.jpg|150px|150px]]
!width=20%|Autor
 
!width=40%|Kurzbeschreibung
 
!width=150px|Bild
 
 
|-
 
|-
![[shader_tesselation]]
+
| {{TableCell}}  | Ein GPU-Partikelsystem welches insbesondere auf SM4 Features wie Geometryshader und Transform-Feedback setzt. So ist auch eine Partikel-Partikel-Interaktion mit über 200.000 Partikeln ist kein Problem. {{ShaderLink|GLSL_Partikel_2}}
!tesselation
+
 
!dj3hut1
+
'''Extensions:'''<br>
!Tesseliert ein Dreieck.<br>
+
[[GL_EXT_geometry_shader4]]<br>
''Tesselates a triangle.''
+
[[GL_NV_transform_feedback]]<br>
![[Bild:Tesselation_s.png|150px|150px]]
+
[[GL_EXT_gpu_shader4]]<br>
 +
[[GL_EXT_texture_buffer_object]]<br>
 +
[[GL_ARB_texture_float]]<br>
 +
[[GL_EXT_texture_integer]]
 +
|}
 +
 
 +
===Sonstiges===
 +
Hier kommt alles rein was sonst nirgendwo rein passt und eine neue Kategorie nicht lohnenswert ist.
 +
{|{{Prettytable_B1}} width=100%
 +
| {{TableHead}}  | [[shader_game_of_life|Game of Life]] von [[Benutzer:dj3hut1|dj3hut1]] {{ShaderLevel|3}}
 +
| {{Table150R2}} | [[Bild:Game_of_life_s.png|150px|150px]]
 +
|-
 +
| {{TableCell}}  | Simuliert das altbekannte 'Game of Life' im Shader. {{ShaderLink|shader_game_of_life}}
 +
|-
 +
| {{TableHead}}  | [[shader_Zufallsgenerator|Pseudozufallsgenerator]] von [[Benutzer:Coolcat|Coolcat]] {{ShaderLevel|4}}
 +
| {{Table150R2}} | [[Bild:shader_Zufallsgenerator.png|150px|150px]]
 
|-
 
|-
![[shader_normal_debug]]
+
| {{TableCell}}  | Generierung von Pseudozufallszahlen im Shader mit [[GL_EXT_gpu_shader4]]. Außerdem eine Beispielanwendung: Ein reproduzierbares pesudozufälliges Verwirbelfeld für ein GPU-Partikelsystem. {{ShaderLink|shader_Zufallsgenerator}}
!normal debugging
+
 
!dj3hut1
+
'''Extensions:'''<br>
!Nützlicher Shader um ohne viel Aufwand die Normalen eines Modells anzuzeigen.<br>
+
[[GL_EXT_gpu_shader4]]
''Useful shader to show the normals of a model without much effort.''
 
![[Bild:Normal_debug_s.png|113px|150px]]
 
 
|}
 
|}
  
== Cg-Shader ==
+
==Non-GLSL-Shader==
 +
In diesem Abschnitt findet ihr Shader die mit einer anderen Technik als GLSL geschrieben wurden.
 +
 
 
{|{{Prettytable_B1}} width=100%
 
{|{{Prettytable_B1}} width=100%
!width=20%|Link
+
| {{TableHead}}  | [[shader_diffuse_bumpmapping(Cg)|Diffuse Bumpmapping (NVIDIA-Cg)]] von [[Benutzer:igel457|igel457]] {{ShaderLevel|2}}
!width=20%|Shadername
+
| {{Table150R2}} | [[Bild:shader_diffuse_bumpmapping_cg.jpg|150px|150px]]
!width=20%|Autor
 
!width=40%|Kurzbeschreibung
 
!width=150px|Bild
 
 
|-
 
|-
![[shader_diffuse_bumpmapping(Cg)|diffuse_bumpmapping]]
+
| {{TableCell}}  | Wendet diffuses Bumpmapping auf eine beliebige Oberfläche an. {{ShaderLink|shader_diffuse_bumpmapping(Cg)}}
!diffuse_bumpmapping
+
|-
!igel457
+
| {{TableHead}}  | [[shader_surface_scattering(ARB)|Surface Scattering (ARB)]] von [[Benutzer:dj3hut1|dj3hut1]] {{ShaderLevel|3}}
!Wendet diffuses Bumpmapping auf eine beliebige Oberfläche an.<br>
+
| {{Table150R2}} | [[Bild:Scattering_s.jpg|150px|150px]]
''Applies diffuse bumpmapping to a surface.''
+
|-
![[Bild:shader_diffuse_bumpmapping_cg.jpg|150px|150px]]
+
| {{TableCell}}  | Der Shader bestimmt die Distanz, die Licht durch ein Material zurücklegt. Auf diese Weise wird die Lichtdurchlässigkeit bestimmt. {{ShaderLink|shader_surface_scattering(ARB)}}
 +
|-
 +
| {{TableHead}}  | [[shader_texturing(ARB)|Texturing (ARB)]] von [[Benutzer:dj3hut1|dj3hut1]] {{ShaderLevel|1}}
 +
| {{Table150R2}} | [[Bild:Texarb_textured_s.png|166px|150px]]
 +
|-
 +
| {{TableCell}}  | Demonstriert eine einfache Texturierung. {{ShaderLink|shader_texturing(ARB)}}
 +
|-
 +
| {{TableHead}}  | [[shader_phong_per_pixel(ARB)|Phong per Pixel (ARB)]] von [[Benutzer:dj3hut1|dj3hut1]] {{ShaderLevel|1}}
 +
| {{Table150R2}} | [[Bild:Phong_arb_s.png|150px|150px]]
 +
|-
 +
| {{TableCell}}  | Per-Pixel-Beleuchtung. {{ShaderLink|shader_phong_per_pixel(ARB)}}
 
|}
 
|}
 +
 +
 +
==Vorlage==
 +
Die Shadersammlung braucht deine Hilfe um zu wachsen. Wenn du einen Shader bereitstellen könntest wäre dies ein toller Dienst für die Community.
 +
 +
Folgende Schritte müssen gemacht werden um einen Shader einzutragen:
 +
# Erstelle mit Hilfe der [[Shaderartikelvorlage]] einen neuen Artikel. Dazu den wiki-Code der Vorlage einfach kopieren und in den neuen Artikel einfügen. Der Artikelname sollte mit dem Präfix <tt>shader_</tt> beginnen, z.B. <tt>shader_Wasser2d</tt> für einen 2D Wassershader.
 +
# Da Shader zu 90% optische Effekte bewirken, sollte (mindestens) ein aussagekräftiges Beispielbild im Shaderartikel hinterlegt werden. Eines der Bilder sollte dann auch hier in der Liste verlinkt werden.
 +
# Füge deinen Shader in die Shadersammlung ein. Verwende dazu dieses Template:<br><tt> |-</tt><br><tt> | <nowiki>{{TableHead}}  | [[shader_Wasser2d|2D Wassershader]] von [[Benutzer:DeinName|DeinName]]</nowiki></tt><br><tt> | <nowiki>{{Table150R2}} | [[Bild:Wassershader2D.jpg|150px|150px]]</nowiki></tt><br><tt> |-</tt><br><tt> | <nowiki>{{TableCell}}</nowiki>  | Einige Sätze zur Beschreibung des Shaders. <nowiki>{{ShaderLink|shader_Wasser2d}}</nowiki></tt><br><tt> </tt><br><tt><nowiki>'''Extensions:'''<br></nowiki></tt><br><tt>Liste von notwendigen Extensions.</tt><br><tt> |-</tt>
 +
# Keine Angst, es muss nicht alles auf Anhieb perfekt sein.
 +
 +
Falls du Fragen oder Probleme mit der Vorlage hast, im [[DGL-Chat]] oder [http://www.delphigl.com/forum/ Forum] hilft man immer gerne.

Version vom 6. Januar 2010, 17:10 Uhr

Was sind Shader?

Die traditionelle Funktionspipeline der OpenGL ist sehr beschränkt, neuere Algorithmen erfordern eine viel höhere Flexibilität. Shader sind kleine Programme die es erlauben Teile der Funktionspipeline völlig frei zu programmieren. Dies bietet völlig neue Möglichkeiten. Auf der einen Seite sind Shader für Einsteiger eine gewisse Hürde, auf der anderen Seite können sie viele Dinge aber auch enorm vereinfachen. Aus diesem Grund wurde in OpenGL 3.1 sowie OpenGL ES 2.0 wurde die feste Funktionspipeline entfernt, so dass Shader dort verpflichtend sind.

Der Artikel Shader gibt einen ausführlichen Überblick zum Thema sowie eine Linksammlung für den Einstieg.

Shader hinzufügen

Die Shadersammlung braucht deine Hilfe um zu wachsen. Wenn du einen Shader bereitstellen könntest wäre dies ein toller Dienst für die Community.

Wer einen Shader zur Shadersammlung hinzufügen möchte, findet am Ende dieses Seite eine Vorlage.

Schwierigkeitsgrad

Es ist nicht leicht einen Schwierigkeitsgrad für Shader anzugeben, trotzdem haben wir dies einmal versucht. Der Schwierigkeitsgrad kann zumindest für Einsteiger einen groben Hinweis geben was man sich vielleicht mal anschauen könnte.

ShaderLevel1.jpg
Der Shader ist für Einsteiger geeignet. Um den Shader herum wird keine zusätzliche Infrastruktur benötigt.
ShaderLevel2.jpg
Der Shader ist für Einsteiger geeignet, benötigt aber etwas zusätzliche Infrastruktur. Etwa benötigt ein Post-Processing-Shader ein FrameBufferObject, für Bumpmapping wird eine Normalmap benötigt.
ShaderLevel3.jpg
Mittlerer Schwierigkeitsgrad. Der Shader ist etwas komplizierter und/oder benötigt viel zusätzliche Infrastruktur.
ShaderLevel4.jpg
Hoher Schwierigkeitsgrad. Der Shader ist kompliziert und/oder verwendet intensiv Extensions.
ShaderLevel5.jpg
Extremer Schwierigkeitsgrad...alles was es sonst noch gibt.

GLSL-Shader

Die hier gelisteten Shader sind in Kategorien aufgeteilt. Weitere Kategorien dürfen bei Bedarf einfach ergänzt werden.

Beleuchtung und Texturen

Diese Kategorie umfasst alles vom einfachen Fixed-Function-Pipeline-Ersatz über PerPixel-Licht und Bumpmapping bis zu ShadowMaps. Der Shader-Einsteiger wird in dieser Kategorie sicherlich fündig.

Verysimple von damadmax
ShaderLevel1.jpg
(kein Bild vorhanden)
Ein einfacher Shader, welcher eine Textur an Vertices bindet. Dieser Shader baut damit das Standardverhalten der festen Pipeline nach.
Per Pixel-Beleuchtung von Ireyon
ShaderLevel1.jpg
shader ppl.png
Shader, der Per Pixel beleuchtet.
Per Pixel-Beleuchtung2 von Olee
ShaderLevel1.jpg
PPLShader.jpg
Beleuchtet Flächen nach Pixeln anstatt wie OpenGl-Licht je Vertex. Erlaubt unendlich weit entferntes Licht und beachtet glFog.

Post-Processing

Post-Processing-Shader zeichnen sich dadurch aus, dass sie auf die gesamte Szene angewendet werden nachdem diese bereits gerendert wurde. Üblicherweise wird die Szene zuerst mit einem FramebufferObject (FBO) in eine Textur gerendert. Anschließend wird diese Textur auf ein bildschirmfüllendes Quad gespannt und mit dem Post-Processing-Shader gerendert.

Sepia-Shader von Markus
ShaderLevel2.jpg
shader sepia nachher.jpg
Post-Processing-Shader, welcher einen Sepia-Farbfilter auf die Szene anwendet.
Radial Blur von Markus
ShaderLevel2.jpg
shader radial blur nachher.jpg
Post-Processing-Shader, welcher die Szene ausgehend von einem beliebigen Punkt verwischt.
Blur-Shader von Skeptiker und Coolcat
ShaderLevel3.jpg
Shader blur seerose blured small.jpg
Post-Processing-Shader, welcher die Szene insgesamt verwischt. Dieser Shader kann beispielsweise genutzt werden um einen Glow-Effekt zu erreichen.

Geometrie

Hier finden sich Shader die die Geometrie entweder komplett neu erzeugen oder stark verändern. Es muss nicht unbedingt Geometryshader oder Instancing sein, auch mit dem Vertexshader kann man schon viel anstellen. Ein klassisches Beispiel ist die Mesh-Animation.

Heightmap-Terrain von Coolcat
ShaderLevel3.jpg
Terrain.jpg
Shader für ein Heightmap-Terrain der ShaderModel 4.0 Features nutzt. Das Terrain wird zur Laufzeit fast vollständig aus der Heightmap generiert, was ordentlich Speicherplatz spart. Im Fragmentshader werden drei Texturlayer mit Hilfe einer Alphamap interpoliert

Extensions:
GL_EXT_gpu_shader4

Instancing-Shader von Coolcat
ShaderLevel4.jpg
shader Instancing.jpg
Dieser Shader zeigt die Benutzung von GL_ARB_draw_instanced. Ein häufiger Anwendungsfall ist das rendern vieler gleichartiger Objekte. Die Extension beschleunigt derartige Anwendungen, in dem die Anzahl der API-Aufrufe und die Menge redundanter Daten reduziert wird.

Extensions:
GL_ARB_draw_instanced
GL_EXT_gpu_shader4
GL_EXT_texture_buffer_object
GL_ARB_texture_float

Tesselation-Shader von dj3hut1
ShaderLevel4.jpg
Tesselation s.png
Dieser Shader nutzt einen Geometry Shader um ein Dreieck zu tesselieren.

Extensions:
GL_ARB_geometry_shader4

Normal Debugging-Shader von dj3hut1
ShaderLevel4.jpg
Normal debug s.png
Nützlicher Shader um ohne viel Aufwand die Normalen eines Modells anzuzeigen.

Extensions:
GL_ARB_geometry_shader4

Partikel

Natürlich kann man auch bei einem Partikelsystem Shader einsetzen. Mit etwas Geschick kann man die gesamte Berechnung sogar vollständig auf die Grafikkarte verlagern um die CPU zu entlasten.

GPU Partikelsystem von Coolcat
ShaderLevel5.jpg
Partikel-Gravitation.jpg
Ein GPU-Partikelsystem welches insbesondere auf SM4 Features wie Geometryshader und Transform-Feedback setzt. So ist auch eine Partikel-Partikel-Interaktion mit über 200.000 Partikeln ist kein Problem.

Extensions:
GL_EXT_geometry_shader4
GL_NV_transform_feedback
GL_EXT_gpu_shader4
GL_EXT_texture_buffer_object
GL_ARB_texture_float
GL_EXT_texture_integer

Sonstiges

Hier kommt alles rein was sonst nirgendwo rein passt und eine neue Kategorie nicht lohnenswert ist.

Game of Life von dj3hut1
ShaderLevel3.jpg
Game of life s.png
Simuliert das altbekannte 'Game of Life' im Shader.
Pseudozufallsgenerator von Coolcat
ShaderLevel4.jpg
shader Zufallsgenerator.png
Generierung von Pseudozufallszahlen im Shader mit GL_EXT_gpu_shader4. Außerdem eine Beispielanwendung: Ein reproduzierbares pesudozufälliges Verwirbelfeld für ein GPU-Partikelsystem.

Extensions:
GL_EXT_gpu_shader4

Non-GLSL-Shader

In diesem Abschnitt findet ihr Shader die mit einer anderen Technik als GLSL geschrieben wurden.

Diffuse Bumpmapping (NVIDIA-Cg) von igel457
ShaderLevel2.jpg
shader diffuse bumpmapping cg.jpg
Wendet diffuses Bumpmapping auf eine beliebige Oberfläche an.
Surface Scattering (ARB) von dj3hut1
ShaderLevel3.jpg
Scattering s.jpg
Der Shader bestimmt die Distanz, die Licht durch ein Material zurücklegt. Auf diese Weise wird die Lichtdurchlässigkeit bestimmt.
Texturing (ARB) von dj3hut1
ShaderLevel1.jpg
Texarb textured s.png
Demonstriert eine einfache Texturierung.
Phong per Pixel (ARB) von dj3hut1
ShaderLevel1.jpg
Phong arb s.png
Per-Pixel-Beleuchtung.


Vorlage

Die Shadersammlung braucht deine Hilfe um zu wachsen. Wenn du einen Shader bereitstellen könntest wäre dies ein toller Dienst für die Community.

Folgende Schritte müssen gemacht werden um einen Shader einzutragen:

  1. Erstelle mit Hilfe der Shaderartikelvorlage einen neuen Artikel. Dazu den wiki-Code der Vorlage einfach kopieren und in den neuen Artikel einfügen. Der Artikelname sollte mit dem Präfix shader_ beginnen, z.B. shader_Wasser2d für einen 2D Wassershader.
  2. Da Shader zu 90% optische Effekte bewirken, sollte (mindestens) ein aussagekräftiges Beispielbild im Shaderartikel hinterlegt werden. Eines der Bilder sollte dann auch hier in der Liste verlinkt werden.
  3. Füge deinen Shader in die Shadersammlung ein. Verwende dazu dieses Template:
    |-
    | {{TableHead}} | [[shader_Wasser2d|2D Wassershader]] von [[Benutzer:DeinName|DeinName]]
    | {{Table150R2}} | [[Bild:Wassershader2D.jpg|150px|150px]]
    |-
    | {{TableCell}} | Einige Sätze zur Beschreibung des Shaders. {{ShaderLink|shader_Wasser2d}}

    '''Extensions:'''<br>
    Liste von notwendigen Extensions.
    |-
  4. Keine Angst, es muss nicht alles auf Anhieb perfekt sein.

Falls du Fragen oder Probleme mit der Vorlage hast, im DGL-Chat oder Forum hilft man immer gerne.