Arbeit mit Texturen

Aus EEP Wiki
Wechseln zu: Navigation, Suche

In diesem Artikel wird der Umgang mit Texturen beschrieben. Das Anmelden von Texturen in der Datei texturen.txt und damit das Verfügbarmachen für den Home-Nostruktor beschreibt der Artikel Schritt für Schritt - Arbeiten mit dem Home-Nostruktor 13.0.

Texturen sind eine Zusammenstellung aus bearbeitetem Bild- und Fotomaterial bzw. eigens erstellten fotorealistischem Material. Die Texturen sind ein entscheidender Bestandteil, um unseren späteren Modell ein gutes und realistisches Aussehen zu verleihen. Der Einsatz von Texturen stellt ein Standardverfahren der Computergrafik zur Verbesserung der Qualität von dreidimensionalen Szenerien dar. Die grundlegende Motivation für den Einsatz von Texturen ist es, den Realismus in der Darstellung von komplexen Oberflächenstrukturen zu verbessern, ohne dabei die Komplexität des gegebenen polygonalen Modells zu erhöhen.

Für die Erstellung der Texturen ist der Einsatz von Grafik- bzw. Bildbearbeitungsprogrammen unverzichtbar. Im Kapitel "Empfohlene Zusatzsoftware" sind einige solcher Programme aufgelistet. Die dort erwähnten Programme werden als "Open Source" angeboten und machen somit eine kostspielige Investition in Kaufsoftware zumindest vorerst überflüssig. Die Arbeit mit Grafikprogrammen ist je nach Programmtyp und -tiefe teilweise sehr komplex. Es ist hier am Besten sich zu Beginn der Texturarbeit verschiedene Programme herunterzuladen und diese einfach auszuprobieren. Oftmals merkt man intuitiv recht schnell, welches Programm zu einem passt und welches eben eher weniger. Unser Kapitel zu "Arbeiten mit Texturen" wird den Teilsektor der Texturarbeit im HomeNos selbst behandeln. Für Hilfestellungen bei der Texturerstellung selbst stehen in den jeweiligen Grafikprogrammen Hilfetexte und teilweise auch Tutorials bereit.


Unterstütze Bilddateiformate

Der HomeNos unterstützt die Bilddateiformate

.tga (Truevision Advanced Raster Graphics Array),
.dds (Direct draw surface) und
.png (Portable network graphics)


Alle drei Dateiformate zeichnen sich dadurch aus, dass sie mit sogenannte Alphakanälen arbeiten und diese abspeichern können. Dies ist für die Arbeit an einem Modell sehr wichtig, wie wir uns in einem kurzen Beispiel ansehen. Wir erinnern uns vielleicht an unsere Stadthaustextur im Kapitel "Arbeiten mit .kon.Dateien". Im folgenden sehen wir einen Ausschnitt der Textur. Dort ist die Fensterreihe im ersten Stockwerk und die Eingangstür nun mit einem Alphakanal belegt, der grün dargestellt wird:

6.textur-mit-alpha.jpg

Der Texturausschnitt mit dem Alphakanal sieht auf eine .kon-Datei aufgebracht nun im 3D-Betrachter folgendermaßen aus:

6.textur-mit-alpha-3d-betrachter.jpg

und die gleiche .kon-Datei mit der Textur ohne Alphakanal:

6.textur-ohne-alpha-3d-betrachter.jpg

Denken wir nun daran, daß wir in unserem Stadthaus ggf. eine Inneneinrichtung modellieren möchten, die später im Modell sichtbar sein soll, können wir bereits erahnen wie wichtig die Unterstützung von Dateiformaten mit Alphakanal ist.

7.2. Anlegen von Texturen


Neue Texturen für unser Modell legen wir im .kon-Dateien-Dialog mit der Schaltfläche Img 25.jpg an. Wir erhalten nun folgendes Dialogfenster, in welchem wir die Eigenschaften der neuen Textur festlegen können:

6.textur-neuetextur-anlegen.jpg


Parameter und Kurzbeschreibungen

id()
Unter diesem Parameter wird die eindeutige Textur-ID angegeben. Nur Ganzzahlen sind möglich. Null vor einer Zahl (wie bei Namen) ist kein gültiger Wert. Dieser Parameter muss unbedingt angegeben werden. Bei der Anlage der  :::Textur über unser Dialogfeld wird die ID der Textur automatisch vergeben. Möchten wir - aus welchen Gründen auch immer - bestimmte ID-Werte vergeben, können wir auf das "händische" Anlegen einer Textur zurückgreifen, was wir :::im Kapitel "Die Vorbereitung" bereits besprochen haben.
name()
Name der Datei mit dem Texturbild ohne Endung (*.tga, *.dds, *png). Der Name kann alphanumerisch sein, darf aber keine Leerzeichen und Umlaute enthalten. Für die Übersicht sinnvoll ist ein Name, der der Texturen-ID entspricht. ::Dieser Parameter muss unbedingt angegeben werden. Der Name ergibt sich bei der automatischen Anlage der Textur über das Dialogfeld aus dem Dateinamen unserer Bilddatei, die wir über die Schaltfläche "Texture Bitmap" ::hinzufügen.
automipmap()
Gibt an, dass Mipmaplevel mit verringerter Auflösung automatisch erstellt worden sind. Es muss kein Wert übergeben werden, um das Mipmapping tatsächlich einzuschalten.
opacity()
Gibt an, dass und in welchem Grade eine Textur eine Fläche durchsichtig erscheinen lassen soll. Gültige Werte sind 0.0 (unsichtbar) bis 1.0 (opak). Dieser Parameter wird nur dann benutzt, wenn die Textur tatsächlich eine ::Opazität, also Transparenzgrad erhalten soll, wie z.B. bei Glasscheiben usw.
billboarding()
Mit diesem Parameter wird die Fläche der Polygone durchbrochen. Wird nur dann benutzt, wenn die Textur Durchbrüche aufweist (Fensteraussparungen, Geländerzwischenräume usw.)
repeat_s()
Wenn dieser Parameter vorhanden ist, werden die Texturen in X-Richtung wiederholt, sobald sie den Bereich 0.0 - 1.0 überschreiten. Zum Parameter wird kein Wert übergeben.
repeat_t()
Wenn dieser Parameter vorhanden ist, werden die Texturen in Y-Richtung wiederholt, sobald sie den Bereich 0.0f- 1.0 überschreiten. Zum Parameter wird kein Wert übergeben.
magfilter()
Gibt den Magnification-Filter an. Gültige Werte sind: 0 und 1. Dieser Parameter muss unbedingt angegeben werden!
minfilter()
Gibt den Minification-Filter an. Gültige Werte sind: 0, 1, 2, 3, 4, 5. Dieser Parameter muss unbedingt angegeben werden!
blaue Parameter = automatisch generiert [id()] bzw. von Dateiname der verwendeten Bilddatei [name()]
rote Parameter = im Texturdialog editierbar
schwarze Parameter = im automatisierten Verfahren nicht vorgesehen


Erklärungen zu den Texturparametern:


Mipmapping (automipmap)

Mipmapping bezeichnet eine Technik, bei der Texturen in größeren Entfernungen mit verringerter Auflösung dargestellt werden. Dies kann Flimmereffekte beseitigen und gibt bessere Kontrolle über die Darstellung von Objekten in größerer Entfernung. Mit dem Parameter automipmap() werden die Mipmap-Level automatisch berechnet, indem die Farbwerte jeweils vierer Texel zu einem verrechnet werden (Einfache Mittelung). Mit dem Schlüsselwort "MipMapLevel" hat man die Möglichkeit von Hand erzeugte Mipmaplevel anzugeben, allerdings wird dies nicht mehr praktiziert, da diese über das DDS-Tool automatisch erzeugt und mitgespeichert werden.


Opazität (opacity)

Diese Einstellung ist weit weniger universell verwendbar, als man vielleicht zunächst meinen könnte. Eine Textur mit einer Opazität = 1 wird zwar in Anteilen die Szenerie hinter ihr sichtbar sein lassen, jedoch betrifft das nur die Polygone, die zum Zeichenzeitpunkt der halb durchsichtigen Fläche bereits gezeichnet wurden. Da Modelle in der Regel nicht von hinten nach vorne gezeichnet werden wird das Bild nicht immer korrekt erscheinen. Diese Einstellung war ursprünglich nur für Rauchwolken gedacht.


Billboarding:

Texel mit der Farbe RGB: 0,0,0 (schwarz) werden nicht gezeichnet. Man sieht dann an diesen Stellen die Szenerie dahinter. Beim Auto-Mipmapping können hier Probleme auftreten, da vollautomatisch nicht immer korrekt bestimmt werden kann, ob ein Texel jetzt unsichtbar ist, oder nicht. Etwa, wenn zwei unsichtbare und zwei sichtbare zu einem verrechnet werden. Dieser Effekt bildet unschöne schwarze Ränder an den Stellen, wo die Grenze zwischen den sichtbaren Flächen und Durchbrüchen ist, kann aber sehr leicht vermieden werden.


Textuhrwiederholungen (repeat_s, repeat_ t)

Mit den Parametern repeat_s(), repeat_t() gibt man an, dass die Textur in X- bzw. Y-Richtung wiederholt werden soll, wenn die Texturkoordinaten den Bereich zwischen 0 und 1 überschreiten. Dies kann im Zusammenhang mit den Texturfiltern zu Problemen führen. Wenn beim Filtern Texelwerte herangezogen werden müssen, die jenseits der Texturgrenzen liegen. Hier können Streifen entstehen, die die Farbe der gegenüberliegenden Texturseite einmischen. Ohne "Repeat" hätten die verwendeten nicht existierenden Texel die Farben der letzten existierenden. Auch beim Einsatz des Billboardings kann es passieren, dass unsichtbare Texel an einem Texturrand wieder sichtbar werden. In solchen Fällen kann man entweder die Filtermethoden auf "NEAREST" stellen, auf die Wiederholung verzichten, oder aber die Textur so anordnen, dass auf beiden Seiten, dieselben Pixel verwendet werden. (Man kopiert hierzu die erste Pixelreihe der linken Seite und fügt diese auf der rechten Seite ein).


Texturfilter (magfilter, minfilter)

Grundsätzlich steht der Renderer vor dem Problem, dass er entscheiden muss, welches Bildelement (Texel) einer, durch die 3D->2D Projektion unter einem Pixel zu liegen kommenden texturierten Fläche, die Farbwerte für das Pixel liefern soll. Es gibt zwei Situationen.

•In der einen sind die texturierten Flächen soweit weg, dass mehrere Texel in ein Pixel fallen: Hier wird der sogenannte Minifikation-Filter aktiv.
•In der anderen überdeckt ein Texel mehrere Pixel: Hier wird die Darstellung durch den Magnifikationfilter beeinflusst.

Werte für den Magnifikationfilter:

0: GL_NEAREST, es wird das Texel die Farbe eines Pixels bestimmen, dessen Zentrum dem Pixelzentrum am nächsten liegt.
1: GL_LINEAR, es werden die vier einem Pixel zunächst liegenden Texel zur Farbbestimmung herangezogen


Werte für den Minifikationfilter:

0: GL_NEAREST, das dem Pixelmittelpunkt zunächst liegende Texel bestimmt die Farbe des Pixels.

1: GL_LINEAR, die vier dem Pixelmittelpunkt zunächst liegenden Texel werden zur Farbe des Pixels verrechnet.

2: GL_NEAREST_MIPMAP_NEAREST, wie GL_NEAREST, nur werden abhängig von der Entfernung Mipmaplevel zur Farbbestimmung benutzt.

3: GL_LINEAR_MIPMAP_NEAREST, es wird abhängig von der Entfernung ein Mipmaplevel benutzt, die endgültige Farbe des Pixels jedoch aus den vier Zunächstliegenden Texeln in dem Mipmaplevel gemittelt.

4: GL_NEAREST_MIPMAP_LINEAR, es werden die beiden am besten zu der Entfernung passenden Mipmaplevel benutzt. Relevant ist aber immer nur das Texel, was dem Pixelmittelpunkt am nächsten liegt.

5: GL_LINEAR_MIPMAP_LINEAR, es werden die beiden am besten zu der Entfernung passenden Mipmaplevel benutzt. Die Farbwerte die jeder Mipmaplevel beisteuert werden aus den dem Pixelzentrum nächstliegenden Texeln gemittelt.


repeat s+t max SUMME 15 aus s*t

2 tex 2mal rendern


7.3. Texturabbildung

Die Texturabbildung beschreibt die Art und Weise, wie eine gegebene Textur auf das darzustellende Objekt gelegt wird, das heißt die Zuordnung zwischen Texturkoordinaten und Objektkoordinaten.

Man unterscheidet nun nach der Anzahl der Texturkoordinaten:

•eindimensionale Texturen
•zweidimensionale Texturen
•dreidimensionale Texturen

Es werden allerdings hauptsächlich zweidimensionale Texturen eingesetzt, daher beschränken sich die folgenden Erläuterungen auf diesen Fall. Dabei haben die Texturkoordinaten zwei Dimensionen "u" und "v", die wir aber zum besseren Verständnis (wie im HomeNos ) als "x" und "y" bezeichnen wollen. Diese zwei Koordinaten geben eine relative Position auf unserer Textur an. Hier ein Beispiel einer zweidimensionale Textur - unsere Stadthaustextur:


1000-tga uv-dialog-schaubild zoom59.png

Abb.: Beispiel Haustextur mit u/v bzw. x/y-Texturkoordinaten

Diese Form des Koordinatensystems mag am Anfang etwas merkwürdig erscheinen, warum nicht einfach die Positionen in Pixeln angeben? Direct3D unterstützt Mip-Mapping, d.h. beim Laden der Texturen kann man Direct3D anweisen, von einer Textur mehrere kleinere Kopien, (sogenannte Mipmap-Level) zu erstellen, oder wenn bereits vorhanden im Speicher zu behalten (bei 256x256 also: 128x128, 64x64, 32x32, 16x16, 8x8, 4x4, 2x2, 1x1). Direct3D wählt je nach Entfernung des Polygons von der Kamera, welcher Textur-Mipmap-Level verwendet wird, da es absolut keinen Sinn macht, eine Textur von 256x256 zur Laufzeit auf eine Größe von ein paar Pixeln (bei weit entfernten Objekten) runterzurechnen. Das Ergebnis ist bei einer kleineren Textur bei großer Entfernung genau dasselbe, nur das wir durch die Abbildung der kleineren Textur viel Renderingzeit sparen.

Es ergeben sich nun bei der Abbildung einer zweidimensionalen Textur auf ein dreidimensionales Objekt folgende Probleme:<br<>

•Verzerrungen
•Streckungen und Stauchungen
•Wiederholungen von Texturen

Die Aufgabe der Abbildung ist es nun, für einen Punkt in Objektkoordinaten den passenden Punkt in Texturkoordinaten zu finden. Es gibt für die Abbildung von Texturen auf dreidimensionale polygonale Objekte zwei empirische Verfahren:

•Auffalten von benachbarten Polygonen in eine Ebene
•Zweiteilige Abbildung

Beim Auffalten des Objekts wird ein Polygon "n" solange um die Achse zwischen den Polygonen "n" und "n" -1 gedreht, bis die beiden Polygone in einer Ebene liegen. Dieser Vorgang wird für jedes Polygon des Objekts durchgeführt. Vor dem Auffalten des Polygons ist es allerdings notwendig, Informationen über die Nachbarschaftsbeziehungen zwischen den einzelnen Polygonen des Objekts zu speichern, da das Auffalten des Objekts nicht eindeutig ist. In der Folge kann die Textur direkt auf die Ebene projiziert werden und somit kann jedem Polygoneckpunkt eine Texturkoordinate zugeordnet werden. Bei Anwendung dieses Verfahrens kann es allerdings zu Diskontinuitäten der Texturdarstellung an den Polygonkanten kommen.


6.4. Texturierung im *.kon-Dialog des HomeNos

Die Texturierung einer geometrischen Figur nehmen wir mittelbar über den Vertexdialog Img 22.jpg des jeweiligen Einzelvertex der Figur oder aber unmittelbar direkt bei der Erstellung einer solchen geometrischen Figur vor. Wir erinnern uns hier an das Kapitel "Arbeit mit .kon-Dateien". Dort haben wir bereits die Methode der unmittelbaren Texturierung kennengelernt. Unmittelbar meint hier, daß wir die Texturkoordinaten direkt bei der Erstellung unseres Figur eingeben:


Unmittelbare Texturierung:

3.1 rechteckdialog homenos mit-beschr.jpg

Wie in der Grafik zu sehen ist, geben wir die Anfangswerte der Texturkoordinaten in X- und Y-Richtung in den Feldern "Textur X" bzw. "Textur Y" ein. In den beiden Felder rechts neben Textur X/Y finden wir Eingabefelder für die Länge und Höhe, d.h. für "Länge" = Länge der Strecke in X-Richtung und für "Höhe" = Länge der Strecke in Y-Richtung.

Wenn wir die Werte aus der Beispielgrafik betrachten, so kommen wir zu folgendem Ergebnis:

- In X-Richtung wird die Textur von Koordinate 0.0005 bis 0.9995 (0.0005 + 0.9990) aufgebracht

- In Y-Richtung wird die Textur von Koordinate 0.0005 bis 0.9995 (0.0005 + 0.9990) aufgebracht

Wünschen wir nun z.Bsp., daß die Textur in X-Richtung von der Mitte (0.5) bis zu dreivierteln (0.75) unserer Textur aufgebracht wird, und in Y-Richtung vom Anfang (0.0005) bis zur Mitte (0.5) der Textur, so geben wir folgendes in unser Dialogfeld ein:

[Anmerkung: Als Anfangs- und Endwert der Texturkoordinaten nehmen wir stets Werte etwas größer Null und etwas kleiner Eins. Denn würde die Textur direkt von Beginn unseres Bildes, d.h. von 0 bis 1 auf unserem Modell aufgebracht, kann es an der Rändern unserer geometrischen Figur zur Bildung von weißen Streifen kommen]

6.textur-aufbringen-bsp-1.jpg


"Mittelbare Texturierung

Wollen wir die Textur mittelbar, d.h nach der Erstellung unserer geometrischen Figur>/b> aufbringen, so tun wir dies über den Vertexdialog der jeweiligen Einzelpunkte/ Vertecies. Hierzu rufen wir uns den angesprochenen Vertexdialog des Punktes über die Schaltfläche Img 22.jpg auf, dem wir eine Texturkoordinate zuweisen möchten. Im Dialogfenster dort geben wir nun die direkten Koordinaten in X- und Y-Richtung ein. Dies tun wir in den Feldern <fonto color="blue">TexturX und TexturY. Im der nachfolgenden Beispielgrafik haben wir so den Vertex 1 (linker, unterer Vertex) mit den Koordinaten TexturX: 0.0039 und TexturY: 0.0005 versehen.

Die Texturkoordinaten können auch durch <fonot color="blue">direkte Auswahl eines Punktes auf dem Bild, im Dialog "Textur" gesetzt werden. Der Dialog "Textur" (rechts in der Grafik zu sehen) öffnet sich durch einen Mausklick auf das Bild in der "Texturvorschau". Die Texturkoordinate (TexturX/TexturY) selbst wird durch einen Doppelklick mit der linken Maustaste an der gewünschten Stelle des Bildes im Dialog "Textur" gesetzt. Für "genaues Treffen" eines Pixels im Bild steht die Zoom-Funktion im Dialog zur Verfügung.

6.4.texturierung kon-dialog zoom88.png


Abschlussbemerkung:

Für die Texturierung der geometrischen Figuren über den Dialog ist es sinnvoll, die Texturkoordinaten aus der Arbeit an der Textur im jeweiligen Grafikprogramm zu entnehmen. Ebenso kann es hilfreich sein, sich bei der Erstellung einer Textur vorab eine Art virtuelles gleichmaschiges Muster in Form eines Schachbretts zu erstellen. So kann man sich z.B. Texturschritte bzw. Koordinaten in X- und Y-Richtung von z.B 0.0 ,0.1, 0.2, 0.3, bis 1.0 festlegen. Dies erleichtert das spätere Aufbringen der Textur auf die jeweilige Figur, indem man für die X- und Y-Werte sodann die Koordinaten von z.B. 0.1,0.2, 0.3, etc. verwendet und diese ohne weitergehenden Berechnungen eingeben kann.


6.textur-maschena.jpg
Abb.: Beispiel gleichmaschiges Muster


Zurück zur Startseite