Métaballe

Les métaballes (de l'anglais metaballs) sont une technique utilisée en infographie pour créer des formes organiques ou représenter des fluides. En français, on trouve également la dénomination « objets mous ». Les metaballs sont une variante des soft objects mais le nom s'est imposé dans la littérature et dans les logiciels. Ce concept a été inventé par Jim Blinn[1] au début des années 1980.

1: Interaction de 2 métaballes positives.
2: Indentation d’une métaballe positive par une métaballe négative.

Chaque balle est définie comme une fonction mathématique à N dimensions. Les plus courantes sont en trois dimensions, on définit alors la fonction . Cette fonction retourne un scalaire et permet de définir un champ scalaire. Une valeur de seuil est ensuite choisie pour délimiter la surface. Il est possible de mélanger plusieurs balles qui vont mutuellement s'influencer et contribuer aux valeurs du champ scalaire.

indique si le point se trouve à l'intérieur du volume confiné par la surface.

Exemples de fonctions

Une fonction typique pour des métaballes est , où est le centre de la balle. La division rend cependant cette fonction assez lente à calculer. On peut utiliser à la place des approximations polynômiales.

Voilà quelques propriétés que peut avoir cette fonction :

  • si l'on cherche à faire des sphères, il faut que la fonction ne dépende que de la distance : .
  • si l'on cherche à créer une surface sans ressaut, il faut que la fonction soit continue.
  • si l'on cherche à créer une surface lisse (sans rupture de pente), il faut que la fonction soit à dérivée continue.
  • si l'on cherche à créer une surface avec des reflets continus, il faut que la fonction soit à dérivée seconde continue.

Pour pouvoir accélérer les calculs, il peut être intéressant d'avoir une fonction nulle au-delà d'une certaine distance, pour que les métaballes n'influent l'une sur l'autre qu'à une distance raisonnable. Dans ce cas pour avoir de « jolies » métaballes (continues, lisses et sans rupture des reflets) avec des polynômes, la fonction la plus simple est : si sinon.

Plusieurs méthodes existent pour afficher des métaballes. Elles dépendent du résultat désiré :

  • force brute discrète : on évalue un grand nombre de points (x, y, z) et on affiche le résultat en fonction de l'appartenance au volume
  • lancer de rayon : on projette un rayon dans la scène et on calcule les intersections avec la surface de l'objet
  • marching cubes : on divise la scène en une multitude de cubes ; chaque cube et ses valeurs du produit scalaire aux sommets sont analysés et des triangles sont générés en fonction de 256 configurations possibles.

Variantes

Une des nombreuses et des plus rapides méthode de calcul et d'affichage de metaballes 2D.

Les métaballes existent en deux dimensions, utilisant alors une superposition de sprites modifiés (addition et posterisation par exemple) ou l'algorithme des marching squares pour l'affichage de la surface pleine. Ces métaballes sont bien moins gourmandes à calculer que la version en trois dimensions, et permettent un plus grand nombre d'améliorations, pour un résultat bien évidemment moins réaliste. Un effet de bump peut être ajouté pour donner une impression de 3D.

Les métaballes étant calculées via la production d'un champ scalaire, des variantes sont apparues comme les métatores, métaplans, ainsi qu'une variété d'objets plus ou moins faciles à définir mathématiquement de manière implicite.

Les métaballes ressemblent à des sphères qui se mélangent doucement, mais en changeant la norme avec laquelle on travaille on peut obtenir des ellipsoïdes, des cubes, des parallélépipèdes rectangles ou des cylindres. Pour cela on peut utiliser les mêmes fonctions de la distance , mais en prenant non pas la distance euclidienne mais la distance associée à la norme 1 ou à d'autres normes qui vont alors déformer l'espace. Il est même tout à fait possible de mélanger dans un même champ des métaballes et des métacubes ou autre métavolume.

définit une métaballes proche d'un métacube.

Références

  1. (en) J. F. Blinn, « A Generalization of Algebraic Surface Drawing », ACM Transactions on Graphics, vol. 1, no 3, , p. 235–256 (DOI 10.1145/357306.357310)

Liens externes

  • Portail de l’informatique
Cet article est issu de Wikipedia. Le texte est sous licence Creative Commons - Attribution - Partage dans les Mêmes. Des conditions supplémentaires peuvent s'appliquer aux fichiers multimédias.