Dorian Fevrier's blog - Mot-clé - collisionJe m’appelle FEVRIER Dorian, je suis infographiste 3D passionné par mon métier, l’informatique en général, l’internet, la programmation et l’évolution de tout ce petit monde. Vous trouverez sur ce blog des tutoriaux, mes coups de cœurs, avis, etc.2024-01-02T23:48:05+01:00FEVRIER Dorianurn:md5:695d9c73474c33ce3dab043823509c4bDotclearRemplir un mesh de spheres dans Maya: La méthode d'un sénior!urn:md5:7e1c6717a192c8539f600af3b710ed132011-03-14T22:24:00+01:002023-03-13T22:24:09+01:00NarannScript et code3dastuceautodeskclosestPointOnMeshcodecollisionexplicationsfrparticulepythonremplirscriptsphere<p><img src="https://www.fevrierdorian.com/blog/public/billets/2011_03_12_remplir_un_mesh_de_spheres/remplir_un_mesh_de_spheres_tn2.png" alt="remplir_un_mesh_de_spheres_tn2.png" style="float:left; margin: 0 1em 1em 0;" title="remplir_un_mesh_de_spheres_tn2.png, mar. 2011" />Aujourd'hui, je ne suis pas peu fier de vous présenter la méthode d'un gros sénior dans le domaine du FX: <a href="http://www.djelloul-bekri.fr/">Djelloul Bekri</a>, qui, en plus d'être un mec adorable m'a donné et autorisé à diffuser son "trick" pour remplir le volume d'un mesh de spheres. :laClasse:</p>
<p>Un grand merci à lui donc car je pense que beaucoup de FX guys vont apprendre un truc aujourd'hui. Voir plusieurs tant cette méthode peut s'adapter à beaucoup de choses. :sauteJoie:</p> <h3>Sommaire</h3>
<ul>
<li><a href="https://www.fevrierdorian.com/blog/post/2011/03/14/Remplir-un-mesh-de-spheres-dans-Maya-La-methode-d-un-senior#ce_quon_cherche_a_faire">Ce qu'on cherche à faire</a></li>
<li><a href="https://www.fevrierdorian.com/blog/post/2011/03/14/Remplir-un-mesh-de-spheres-dans-Maya-La-methode-d-un-senior#le_principe">Le principe</a>
<ul>
<li><a href="https://www.fevrierdorian.com/blog/post/2011/03/14/Remplir-un-mesh-de-spheres-dans-Maya-La-methode-d-un-senior#remplir_un_mesh_de_particule">Remplir un mesh de particule</a></li>
<li><a href="https://www.fevrierdorian.com/blog/post/2011/03/14/Remplir-un-mesh-de-spheres-dans-Maya-La-methode-d-un-senior#recuperer_les_positions_des_particules">Récupérer les positions des particules</a></li>
<li><a href="https://www.fevrierdorian.com/blog/post/2011/03/14/Remplir-un-mesh-de-spheres-dans-Maya-La-methode-d-un-senior#calcul_du_rayon_maximal_de_chaque_particule">Calcul du rayon maximal de chaque particule</a></li>
<li><a href="https://www.fevrierdorian.com/blog/post/2011/03/14/Remplir-un-mesh-de-spheres-dans-Maya-La-methode-d-un-senior#determiner_la_plus_grosse_sphere">Déterminer la plus grosse sphère</a></li>
<li><a href="https://www.fevrierdorian.com/blog/post/2011/03/14/Remplir-un-mesh-de-spheres-dans-Maya-La-methode-d-un-senior#suppression_des_particules_inutiles">Suppression des particules "inutiles"</a></li>
<li><a href="https://www.fevrierdorian.com/blog/post/2011/03/14/Remplir-un-mesh-de-spheres-dans-Maya-La-methode-d-un-senior#et">Et...</a></li>
</ul></li>
<li><a href="https://www.fevrierdorian.com/blog/post/2011/03/14/Remplir-un-mesh-de-spheres-dans-Maya-La-methode-d-un-senior#das_code">Das Code!</a>
<ul>
<li><a href="https://www.fevrierdorian.com/blog/post/2011/03/14/Remplir-un-mesh-de-spheres-dans-Maya-La-methode-d-un-senior#en_brut">En brut</a></li>
<li><a href="https://www.fevrierdorian.com/blog/post/2011/03/14/Remplir-un-mesh-de-spheres-dans-Maya-La-methode-d-un-senior#les_details">Les détails</a></li>
</ul></li>
<li><a href="https://www.fevrierdorian.com/blog/post/2011/03/14/Remplir-un-mesh-de-spheres-dans-Maya-La-methode-d-un-senior#bekri_djelloul">BEKRI Djelloul</a></li>
</ul>
<center>:longBar:</center>
<h3>Ce qu'on cherche à faire <a id="ce_quon_cherche_a_faire"></a></h3>
<p>Et bien... Ça:</p>
<p><img src="https://www.fevrierdorian.com/blog/public/billets/2011_03_12_remplir_un_mesh_de_spheres/remplir_un_mesh_de_spheres001.png" alt="remplir_un_mesh_de_spheres001.png" style="display:table; margin:0 auto;" title="remplir_un_mesh_de_spheres001.png, mar. 2011" /></p>
<p><img src="https://www.fevrierdorian.com/blog/public/billets/2011_03_12_remplir_un_mesh_de_spheres/remplir_un_mesh_de_spheres007.png" alt="remplir_un_mesh_de_spheres007.png" style="display:table; margin:0 auto;" title="remplir_un_mesh_de_spheres007.png, mar. 2011" /></p>
<p><img src="https://www.fevrierdorian.com/blog/public/billets/2011_03_12_remplir_un_mesh_de_spheres/remplir_un_mesh_de_spheres005.png" alt="remplir_un_mesh_de_spheres005.png" style="display:table; margin:0 auto;" title="remplir_un_mesh_de_spheres005.png, mar. 2011" /></p>
<p>Avant de commencer, il faut savoir que les algorithmes permettant de mettre des sphères dans de la géométrie (sphere packing algorythms) sont des sujets de recherche fréquents:</p>
<ul>
<li><a href="http://cg.in.tu-clausthal.de/research/ist/index.shtml" hreflang="en">Inner Sphere Trees for 6-DOF Haptic Rendering</a></li>
<li><a href="http://cg.in.tu-clausthal.de/research/protosphere/index.shtml" hreflang="en">A GPU-Assisted Prototype Guided Sphere Packing Algorithm for Arbitrary Objects</a></li>
<li><a href="http://www.google.com/search?q=Sphere+Packing+Algorithm">Et Google...</a></li>
</ul>
<p>Et hop! Une petite vidéo du principe:</p>
<center><iframe width="560" height="315" src="https://www.youtube.com/embed/GIoB7Pa0SjE" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" allowfullscreen></iframe></center>
<blockquote><p>Merci à Adrien Herubel pour ces quelques liens. :)</p></blockquote>
<p>Ces algorithmes peuvent servir à pleins de chose. Un exemple assez précis est de "sortir" les lignes de force/d’énergie d'un mesh pour lui appliquer un rigging automatique:</p>
<ul>
<li><a href="http://www.tonychai.com/ART.html" hreflang="en">ART - Auto-Rigging Tool</a></li>
</ul>
<center><iframe src="https://player.vimeo.com/video/4390629?h=6a1760b2d8" width="640" height="356" frameborder="0" allow="autoplay; fullscreen; picture-in-picture" allowfullscreen></iframe></center>
<p>A vous de voir quoi en tirer. :sourit:</p>
<p>Je vais d'abords expliquer le principe. Ensuite je vous donnerai, en brut, le script de Djelloul que je commenterai, ligne à ligne. Si vous scritpez un peu, vous verrez qu'il y a énormément d'optimisations possibles mais ce n'était pas sa priorité lorsqu'il m'a montré ce script.</p>
<p>Cette méthode est donc un peu longue en temps machine. :seSentCon:</p>
<p>Mais si il vous en prend l'envie de vouloir optimiser ce code, n'hésitez pas à me l'envoyer. Je me ferai un plaisir de faire un lien et un commentaire ici même. :bravo:</p>
<center>:longBar:</center>
<h3>Le principe <a id="le_principe"></a></h3>
<p>Et bien oui, comme toute technique un chouilla compliqué, il y a de la théorie! :jdicajdirien:</p>
<p>Vous allez voir que le principe est assez simple et si vous pigez le truc, vous pourrez l'adapter à vos besoins.</p>
<h4>Remplir un mesh de particule <a id="remplir_un_mesh_de_particule"></a></h4>
<p>La première chose à faire est de remplir un mesh de particule.</p>
<p>Si vous suivez régulièrement mon blog, j'ai proposé <a href="https://www.fevrierdorian.com/blog/post/2010/09/22/Remplir-un-mesh-de-particule-dans-Maya-closestPointOnMesh-again">une solution</a> mais Djelloul, dans sa version (et surtout pour gagner du temps :laClasse: ) utilise <a href="http://download.autodesk.com/us/maya/2011help/CommandsPython/particleFill.html" hreflang="en">particleFill</a> qui remplit le mesh sélectionné de nParticle.</p>
<p><img src="https://www.fevrierdorian.com/blog/public/billets/2011_03_12_remplir_un_mesh_de_spheres/remplir_un_mesh_de_spheres004.png" alt="remplir_un_mesh_de_spheres004.png" style="display:table; margin:0 auto;" title="remplir_un_mesh_de_spheres004.png, mar. 2011" /></p>
<h4>Récupérer les positions des particules <a id="recuperer_les_positions_des_particules"></a></h4>
<p>On récupère la position dans l'espace de chacune des particules crées.</p>
<h4>Calcul du rayon maximal de chaque particule <a id="calcul_du_rayon_maximal_de_chaque_particule"></a></h4>
<p>Une fois qu'on a toutes les positions des particules, pour chacune d'elle, on va récupérer la taille maximale (le rayon) que pourrait atteindre une sphère placée sur cette particule, sans sortir de la géométrie.</p>
<p>Pour calculer cette taille, on va récupérer le point de la géométrie le plus proche de la particule courante. Et pour cela on va utiliser un node que vous connaissez peut être déjà. Je vous le donne en mille, il s'agit du <a href="http://download.autodesk.com/us/maya/2011help/Nodes/closestPointOnMesh.html">closestPointOnMesh</a>. Je ne vais pas réexpliquer le principe, je me suis déjà <a href="https://www.fevrierdorian.com/blog/post/2010/08/19/Orienter-les-particules-sur-la-normale-d-un-mesh-ou-d-une-surface-closestPointOnMesh">étalé</a> <a href="https://www.fevrierdorian.com/blog/post/2010/09/22/Remplir-un-mesh-de-particule-dans-Maya-closestPointOnMesh-again">dessus</a>.</p>
<p><img src="https://www.fevrierdorian.com/blog/public/billets/2011_03_12_remplir_un_mesh_de_spheres/Schema_001.png" alt="Schema_001.png" style="display:table; margin:0 auto;" title="Schema_001.png, mar. 2011" /></p>
<p>Arrivé ici, nous avons deux choses:</p>
<ul>
<li>Une liste de points dans l'espace (les particules).</li>
<li>Une liste de rayon.</li>
</ul>
<p>Et bien entendu, ces deux listes font la même taille (un rayon par particule). Si vous n'avez pas compris ça, il peut être intéressant de relire des quelques points plus haut. :siffle:</p>
<p>On peut donc maintenant considérer qu'un ensemble "point+rayon" est une sphère.</p>
<h4>Déterminer la plus grosse sphère <a id="determiner_la_plus_grosse_sphere"></a></h4>
<p>Il faut bien un point de départ et dans le cas de cette algorithme, tout commence par la sphère la plus grosse.</p>
<p>Pour savoir ça, on parcourt tous les points et on regarde leur rayon. On ne garde que le point ayant le rayon le plus gros.</p>
<p>Une fois tous les points parcourus, le point ayant le rayon le plus gros est considéré comme la sphère la plus grosse (si vous ne comprenez pas ça... :septic: ).</p>
<p>Notez aussi que c'est à cet endroit dans le mesh que (pardonnez moi l'expression) "l'espace est le plus grand".</p>
<h4>Suppression des particules "inutiles" <a id="suppression_des_particules_inutiles"></a></h4>
<p>Une fois qu'on sait quelle est la sphère (l'ensemble point-rayon) la plus grosse dans le mesh, on peut supprimer toute les autres sphères qui sont en collision avec elle.</p>
<p>L'avantage d'utiliser des sphères pour des tests de collision c'est qu'il suffit de deux points et de deux rayons (un par sphère) pour savoir si elles se touchent, c'est tout! <sup></sup></p>
<p>Ça tombe bien, c'est exactement ce que l'on a!</p>
<p>Vérifier ça est assez simple:</p>
<p><img src="https://www.fevrierdorian.com/blog/public/billets/2011_03_12_remplir_un_mesh_de_spheres/Schema_002.png" alt="Schema_002.png" style="display:table; margin:0 auto;" title="Schema_002.png, mar. 2011" /></p>
<p>Dans un premier temps, on récupère la distance entre les deux points (en jaune). Une <a href="http://www.google.com/search?q=distance+deux+points+3d">petite recherche sur google</a> et on trouve <a href="http://forums.futura-sciences.com/mathematiques-superieur/159674-distance-entre-points-un-repere-3d.html#postcount1225138">facilement</a> <a href="http://en.wikipedia.org/wiki/Euclidean_distance#Three_dimensions">la formule</a>:</p>
<blockquote><p>distance = sqrt( (pt1.x-pt2.x)² + (pt1.z-pt2.z)² + (pt1.z-pt2.z)² )</p></blockquote>
<p>sqrt(x) étant la racine carré de x.</p>
<p>Une fois qu'on a la distance, on additionne la taille des deux rayons et on compare!</p>
<p>Si la distance entre les deux centres des sphères est plus petite que la somme de leurs rayons, les sphères se touchent.</p>
<h4>Et... <a id="et"></a></h4>
<p>...Caetera! On recommence! :sourit:</p>
<p>En effet, tant qu'on a supprimé au moins un point, on recommence la boucle avec tousles points restants, et ce, jusqu'à ce qu'il ne reste aucun point à supprimer:</p>
<ul>
<li><a href="https://www.fevrierdorian.com/blog/post/2011/03/14/Remplir-un-mesh-de-spheres-dans-Maya-La-methode-d-un-senior#determiner_la_plus_grosse_sphere">Déterminer la plus grosse sphère</a></li>
<li><a href="https://www.fevrierdorian.com/blog/post/2011/03/14/Remplir-un-mesh-de-spheres-dans-Maya-La-methode-d-un-senior#suppression_des_particules_inutiles">Suppression des particules "inutiles"</a></li>
<li><a href="https://www.fevrierdorian.com/blog/post/2011/03/14/Remplir-un-mesh-de-spheres-dans-Maya-La-methode-d-un-senior#et">Etc...</a></li>
</ul>
<p>Arrivé ici vous devriez avoir une vision globale de "comment que ça fonctionne ce truc". :joue:</p>
<p>Mais sans plus tarder: Le code!</p>
<center>:longBar:</center>
<h3>Das Code! <a id="das_code"></a></h3>
<h4>En brut <a id="en_brut"></a></h4>
<p>Voici le code de Djelloul, brut de pomme! Fait avec ses petits doigts, sans modifs de ma part.</p>
<pre>[python]
from pymel.all import *
import maya.mel as mel
import maya.cmds as cmds
import time
step = 100
######################################
def mag(p1,p2):
return ((p1[0]-p2[0])**2+(p1[1]-p2[1])**2+(p1[2]-p2[2])**2)**.5
if(len(ls(sl=1))):
obj=ls(sl=1)[0]
try:
particleFill(rs=step,maxX=1,maxY=1,maxZ=1,minX=0,minY=0,minZ=0,pd=1,cp=0)
except:
pass
part = ls(sl=1)[0]
partShape = listRelatives(part,shapes=1)[0]
closest=createNode("closestPointOnMesh")
connectAttr(obj+".outMesh",closest+".inMesh")
points=getAttr(part+".position")
delete(part)
rayons=[]
for point in points:
setAttr(closest+".inPosition",point)
rayons.append(mag(point,getAttr(closest+".position")))
delete(closest)
newPoints,newRayons = [],[]
while len(points)>0:
print "%s points encore a traiter..." % len(points)
action,p,max,maxId = 0,[],-1,-1
for i in range(len(points)):
if rayons[i]>max:
max,p,maxId=rayons[i],points[i],i
del(points[maxId])
del(rayons[maxId])
newPoints.append(p)
newRayons.append(max*1.2)
i=0
while i<len(points):
if mag(p,points[i])<rayons[i]+max:
del(points[i])
del(rayons[i])
else:
i=i+1
#Attention ! Le mode de creation des nParticles par default doit etre "Points" !
part = nParticle(p=newPoints)[1]
setAttr(part+".particleRenderType",4)
setAttr(part+".ignoreSolverGravity",1)
addAttr(part,ln="radiusPP",dt="doubleArray")
setAttr(part+".radiusPP",newRayons,type="doubleArray")
print "Fini."
else:
print("Il faut selectionner un mesh !")
</pre>
<h4>Les détails <a id="les_details"></a></h4>
<p>Bon, le premier truc est de passer les nParticules par défaut sur "Points":</p>
<p><img src="https://www.fevrierdorian.com/blog/public/billets/2011_03_12_remplir_un_mesh_de_spheres/remplir_un_mesh_de_spheres008.png" alt="remplir_un_mesh_de_spheres008.png" style="display:table; margin:0 auto;" title="remplir_un_mesh_de_spheres008.png, mar. 2011" /></p>
<p>Vous pouvez l'essayer! Sélectionnez votre mesh et lancez le! (Si vous avez mis 100 en step, il vaut mieux être patient. Mettez 30 pour vos tests).</p>
<p>Pour la suite, je partirai de cette forme:</p>
<p><img src="https://www.fevrierdorian.com/blog/public/billets/2011_03_12_remplir_un_mesh_de_spheres/remplir_un_mesh_de_spheres001.png" alt="remplir_un_mesh_de_spheres001.png" style="display:table; margin:0 auto;" title="remplir_un_mesh_de_spheres001.png, mar. 2011" /></p>
<p>On commence par une petite déclaration d'une fonction qui renvoie la distance entre deux points.</p>
<pre>[python]
def mag(p1,p2):
return ((p1[0]-p2[0])**2+(p1[1]-p2[1])**2+(p1[2]-p2[2])**2)**.5
</pre>
<p>Si vous regardez bien, c'est la version Python de la formule que j'ai donné <a href="https://www.fevrierdorian.com/blog/post/2011/03/14/Remplir-un-mesh-de-spheres-dans-Maya-La-methode-d-un-senior#suppression_des_particules_inutiles">plus haut</a>.</p>
<pre>[python]
x**2
</pre>
<p>En Python, ça veut dire x² (au carré).</p>
<p>Et:</p>
<pre>[python]
x**0.5
</pre>
<p>Ça veut dire "racine carré".</p>
<p>En gros, chaque point (p1 et p2) est une liste de trois valeurs (x, y, z) et on s'en sert pour calculer la distance qui les sépares.</p>
<pre>[python]
if(len(ls(sl=1))):
obj=ls(sl=1)[0]
try:
particleFill(rs=step,maxX=1,maxY=1,maxZ=1,minX=0,minY=0,minZ=0,pd=1,cp=0)
except:
pass
</pre>
<p>Ici on s'assure que l'objet que l'on souhaite remplir est sélectionné et on lui applique un <a href="http://download.autodesk.com/us/maya/2011help/CommandsPython/particleFill.html" hreflang="en">particleFill</a> qui le remplit de nParticle (notez que c'est ici qu'est utilisé la variable <em>step</em>):</p>
<p><img src="https://www.fevrierdorian.com/blog/public/billets/2011_03_12_remplir_un_mesh_de_spheres/remplir_un_mesh_de_spheres004.png" alt="remplir_un_mesh_de_spheres004.png" style="display:table; margin:0 auto;" title="remplir_un_mesh_de_spheres004.png, mar. 2011" /></p>
<pre>[python]
part = ls(sl=1)[0]
partShape = listRelatives(part,shapes=1)[0]
</pre>
<p>Quand on créé un système de particule, Maya le sélectionne automatiquement. Ici, il récupère la sélection ("part"). La variable "partShape" ne sera pas utilisée dans la suite du script.</p>
<pre>[python]
closest=createNode("closestPointOnMesh")
connectAttr(obj+".outMesh",closest+".inMesh")
</pre>
<p>On créé le node de closestPointOnMesh et on lui connecte la géométrie qu'on souhaite remplir.</p>
<pre>[python]
points=getAttr(part+".position")
delete(part)
</pre>
<p>On récupère la position de toute les particules du système dans une variable ("points"), puis on supprime le système de particule.</p>
<p>Vous comprenez donc que l'intérêt d'utiliser le particleFill est uniquement de récupérer, sans trop se casser le c** une liste de positions (x, y, z) qui soit "dans le mesh".</p>
<pre>[python]
rayons=[]
for point in points:
setAttr(closest+".inPosition",point)
rayons.append(mag(point,getAttr(closest+".position")))
delete(closest)
</pre>
<p>Cette boucle parcourt tous les points récupérés plus haut et demande au node de closestPointOnMesh quelle est la position (sur la surface du mesh) la plus proche de ce point. La distance (entre le point d'origine et le point le plus proche sur la surface) est ensuite calculée (via la procédure "mag") et est stockée dans la liste des rayons. (Il fait ça en une ligne donc n'hésitez pas à relire le code! :dentcasse: )</p>
<pre>[python]
newPoints,newRayons = [],[]
</pre>
<p>Il initialise deux listes (points et rayons) qui seront les listes des points et rayons restants (ceux qui vont vraiment servir).</p>
<p>Et maintenant, accrochez vous car on rentre dans le gros de l'algo! :gniarkgniark:</p>
<pre>[python]
while len(points)>0:
print "%s points encore a traiter..." % len(points)
p,max,maxId = [],-1,-1
</pre>
<p>Début de la boucle. On initialise trois variables:</p>
<ul>
<li>"p" qui sera le point le plus "gros" (ayant le rayon le plus gros).</li>
<li>"max", idem que pour point mais pour le rayon.</li>
<li>"maxId", l'index de l'ensemble point-rayon qui est le plus gros (rappelez vous, les deux listes font la même taille).</li>
</ul>
<pre>[python]
for i in range(len(points)):
if rayons[i]>max:
max,p,maxId=rayons[i],points[i],i
</pre>
<p>Cette boucle ne fait que rechercher (parmis tout les points) le point le plus gros et le stocke dans les variables initialisées plus haut.</p>
<p>A la fin de la boucle, max, p, et maxId appartiennent à la sphère (l'ensemble point-rayon toujours) la plus grosse. Celle qu'on va garder!</p>
<pre>[python]
del(points[maxId])
del(rayons[maxId])
newPoints.append(p)
newRayons.append(max*1.2)
</pre>
<p>Ici on "déplace" en quelque sorte le point le plus gros vers la nouvelle liste ("newPoints" et "newRayons"):</p>
<ul>
<li>On le supprime de la liste principale.</li>
<li>On l'ajoute à la nouvelle liste.</li>
</ul>
<p>Djelloul choisit de multiplier la taille du rayon par 1.2 pour compenser le fait que les sphères semblent ne pas se toucher.</p>
<pre>[python]
i=0
while i<len(points):
if mag(p,points[i])<rayons[i]+max:
del(points[i])
del(rayons[i])
else:
i=i+1
</pre>
<p>Là, on arrive à la fin de l'algo: On parcourt tous les points restants, on fait, sur chacun d'eux, <a href="https://www.fevrierdorian.com/blog/post/2011/03/14/Remplir-un-mesh-de-spheres-dans-Maya-La-methode-d-un-senior#suppression_des_particules_inutiles">un test de collision</a> avec la sphère la plus grosse (qu'on a récupéré juste au dessus).</p>
<p>Si il y a collision, on supprime le point. :grenadelauncher: (Et on "valide" la variable "action" pour que la boucle continue).</p>
<blockquote><p>Notez qu'on n'incrémente pas "i" si on supprime les sphères des listes car tous les index se décalent de un à cet endroit. L'index actuel doit donc être revérifié.</p></blockquote>
<pre>[python]
#Attention ! Le mode de creation des nParticles par default doit etre "Points" !
part = nParticle(p=newPoints)[1]
setAttr(part+".particleRenderType",4)
setAttr(part+".ignoreSolverGravity",1)
addAttr(part,ln="radiusPP",dt="doubleArray")
setAttr(part+".radiusPP",newRayons,type="doubleArray")
print "Fini."
</pre>
<p>C'est la dernière partie du script:</p>
<ul>
<li>On recréé un système de particule en lui donnant les points qu'on a conservé de l'ancien système (les nouveaux points en quelque sorte).</li>
<li>On met le display de particule en sphère, désactive la gravité.</li>
<li>On ajoute un attribut de "rayon per particle".</li>
<li>On donne à ce nouvel attribut les valeurs des rayons conservé de l'ancien système.</li>
</ul>
<pre>[python]
else:
print("Il faut selectionner un mesh !")
</pre>
<p>Ce dernier point ferme la boucle ouverte tout au début. :sourit:</p>
<p>Et voilà! :bravo:</p>
<p><img src="https://www.fevrierdorian.com/blog/public/billets/2011_03_12_remplir_un_mesh_de_spheres/remplir_un_mesh_de_spheres005.png" alt="remplir_un_mesh_de_spheres005.png" style="display:table; margin:0 auto;" title="remplir_un_mesh_de_spheres005.png, mar. 2011" /></p>
<p>Rappelez vous que cette méthode n'est pas très optimisée. Soyez donc un peu patient. :siffle:</p>
<center>:longBar:</center>
<h3>BEKRI Djelloul <a id="bekri_djelloul"></a></h3>
<p>Et parce que je pouvais pas finir ce tuto sans un dernier remercient à celui qui en est le principal créateur.</p>
<p>Un grand merci à Djelloul donc. N'hésitez pas à parcourir ces différentes pages pour avoir une idée de ses compétences. :sourit:</p>
<ul>
<li><a href="http://www.djelloul-bekri.fr/">Son site</a></li>
<li><a href="http://www.linkedin.com/pub/djelloul-bekri/4/70/b1a">Son LinkedIn</a></li>
<li><a href="http://www.imdb.com/name/nm1806860/">Son IMDB</a></li>
</ul>
<p>J'espère que ce tuto était clair et que vous avez appris des choses aujourd'hui. N'hésitez pas à laisser un commentaire si je n'ai pas été assez précis ou que certains points vous semblent encore flou.</p>