Metaball

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.

1 = zwei positive Metaballs verschmelzen ineinander, 2 = ein negativer Metaball drückt einen positiven ein

Ein Metaball ist als eine Funktion in Dimensionen definiert, für die üblichen drei Dimensionen also entsprechend . Um ein Volumen zu erzeugen wird ein Schwellenwert gewählt.

definiert dann, ob der von Metaballs definierte Körper am Punkt gefüllt ist.

Eine typische Metaball-Funktion ist

wobei das Zentrum des Balles angibt und den zu untersuchenden Punkt. 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 polynomiale Annäherungen verwendet.

Es gibt viele Wege, Metaballs zu rendern, die beiden gebräuchlichsten sind Raycasting und der Marching-Cubes-Algorithmus.

Literatur

  • James F. Blinn: A Generalization of Algebraic Surface Drawing. In: ACM Transactions on Graphics, 1(3), Juli 1982, S. 235–256.
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.