Metaball
aus Wikipedia, der freien Enzyklopädie
Ein Metaball ist das Ergebnis eines Algorithmus, der eine dehnbare Oberfläche erzeugt, die die Form einer Kugel (bei genau einem) oder eine Menge von ineinander gehenden Kugeln erzeugt. Der Algorithmus wurde in den frühen 1980ern von Jim Blinn entwickelt.
Ein Metaball ist als eine Funktion in n Dimensionen definiert, für die üblichen drei Dimensionen also entsprechend f(x,y,z). Um ein Volumen zu erzeugen wird ein Schwellenwert gewählt.
definiert dann, ob der von n Metaballs definierte Körper am Punkt (x,y,z) gefüllt ist.
Eine typische Metaball-Funktion ist
wobei (x0,y0,z0) das Zentrum des Balles angibt und (x,y,z) den zu untersuchenden Punkt. f(x,y,z) gibt dann also die Stärke des Balles an diesem Punkt zurück, ist die Summe der Stärken aller Bälle an diesem Punkt größer als der Schwellenwert, so ist der Körper dort gefüllt. Da die Funktion auf Grund der Division rechenintensiv ist, werden auch polynomale Annäherungen verwendet.
Es gibt viele Wege, Metaballs zu rendern, die beiden gebräuchlichsten sind Raycasting und der Marching Cubes-Algorithmus.
[Bearbeiten] Literatur
- Blinn, James F. "A Generalization of Algebraic Surface Drawing." ACM Transactions on Graphics 1(3), July 1982, pp. 235–256.