#0 

07-10-2009 14:36:32

capry
Membre
Date d'inscription: 14-02-2009
Messages: 83

Bonjour à tous,
Voici un moment que je ne suis plus venu sur le forum, car je continuais à programmer un peu, jusqu'à être confonté à un nouveau problème.
Voilà, je fais un jeu avec Irrlicht, et j'aurais besoin de savoir si Irrlicht permettais de savoir lorsque 2 mesh entre en collision, pour que je puisse faire par exemple un :


if(mesh1->isCollideWith(mesh2))
etc...


Ma question est simple mais j'ai beau avoir chercher dans la doc et beaucoup sur les forums je n'ai pas trouver de réponse.
Pouvez-vous m'aider ?

Merci d'avance

Capry

Hors ligne


#1 

07-10-2009 16:41:15

Hawk
Membre
Lieu: Wissous
Date d'inscription: 08-11-2008
Messages: 91
Site web

J'ai pas mal travaillé sur ce problème moi aussi pour mon jeu, et je pense avoir pour toi une piste intéressante.

Dans le ISceneCollisionManager, il existe une fonction qui est

Code:

getCollisionPoint(const core::line3d< f32 > &ray, ITriangleSelector *selector, core::vector3df &outCollisionPoint, core::triangle3df &outTriangle).

L'idée est que tu fais partir un rayon de ton mesh1 (const core::line3d< f32 > &ray), et tu testes si il entre en collision avec le ITriangleSelector de ton mesh 2. Si oui, la fonction renvoie true, ainsi que le point de collision, et le triangle d'intersection (les deux derniers arguments).

Après, la version 1.6 d'irrlicht a fait des progrès dans ce domaine, en particulier, cette fonction renvoie désormais un pointeur vers le mesh qui est touché par le ray. Dans ce cas, tu peux regrouper tous tes mesh dans un seul gros TriangleSelector, et utiliser la fonction pour savoir avec quel mesh tu collisionne. Du coup, tu pourrais faire un truc du genre.
mesh2 = mesh1->getCollision()

Je te conseille d'attendre encore un petit peu, je pense que la doc (et surtout l'API) de la 1.6 va bientôt remplacer celle de la 1.5.1 sur le site officiel pour avoir plus d'aide sur ce sujet.

PS : Quand je dis mesh, je veux bien sûr parler de MeshSceneNode...

Dernière modification par Hawk (07-10-2009 16:42:09)

Hors ligne


#2 

08-10-2009 19:07:14

capry
Membre
Date d'inscription: 14-02-2009
Messages: 83

Merci pour ta réponse. l'idée est bonne j'y avais déjà pensé, mais faire une ligne à partir de mon mesh1 n'est pas assez précis car il faudrais que mon mesh2 touche la ligne. Or il peut quand même toucher le mesh1 sans toucher la ligne !
Sinon j'avais aussi eu l'idée d'utiliser la classe : irr::core::aabbox3d< T > avec la fonction :
bool     intersectsWithBox (const aabbox3d< T > &other) const

Sauf que celle-ci me renvoi true (même si les deux mesh sont très éloigné et qu'il y à  normalement 0% de chance que leur boite englobante se touchent). Si vous avez aussi une idée sur ce point ce serais pas mal, car ça me semblais une bonne solution...

Hors ligne


#3 

09-10-2009 00:07:08

Hawk
Membre
Lieu: Wissous
Date d'inscription: 08-11-2008
Messages: 91
Site web

J'ai découvert autre chose sur la 1.6 qui pourrait être utile.
Le "ISceneNodeAnimatorCollisionResponse" dispose maintenant d'une fonction "getCollisionNode" pour savoir avec qui le node qui a cet animator collisionne.
Une idée serait, je pense, de mettre tous les meshs dans un grand triangle selector, que tu pourrais utiliser pour le AnimatorCollisionResponse.
Je sais pas si je suis très clair, et je suis pas sûr que ça marche, mais c'est une piste à creuser. Tu peux trouver de la doc la dessus avec la 1.6 (en fait, la doc n'est pas sur le site, mais elle est dans le package Irrlicht 1.6 !)

Pour tes Box, c'est étrange que ça collisionne. Je n'ai jamais essayé cette solution, donc je ne sais pas pourquoi ça fait ça.

Dernière modification par Hawk (09-10-2009 00:07:34)

Hors ligne


#4 

09-10-2009 13:35:11

capry
Membre
Date d'inscription: 14-02-2009
Messages: 83

ah merci, je vais tester ta solution, à défaut d'en avoir d'autre.
Je vais voir ce que je peux faire avec ça...

EDIT :

Euh... là j'ai un joli problème. Pour utiliser la nouvelle fonction j'ai dû passer à Irrlicht 1.6. Au moment de tout recompiler il me dis que j'ai une erreur (dans un autre fichier) :

[...] no matching function for call to `irr::scene::ISceneCollisionManager::getCollisionPoint(irr::core::line3d<irr::f32>&, irr::scene::ITriangleSelector*, irr::core::vector3df&, irr::core::triangle3df&, irr::scene::ISceneNode*&)'

[...]
candidates are: virtual bool irr::scene::ISceneCollisionManager::getCollisionPoint(const irr::core::line3d<irr::f32>&, irr::scene::ITriangleSelector*, irr::core::vector3df&, irr::core::triangle3df&, const irr::scene::ISceneNode*&)


Alors là je ne comprends plus rien *_*. Les deux fonctions sont strictement identiques sauf le "const" devant le premier et dernier paramètre. De plus j'ai beau remettre la version 1.5 d'Irrlicht maintenant il me fait la même erreur alors qu'avant non... I need help please =S

Dernière modification par capry (09-10-2009 15:19:33)

Hors ligne


#5 

09-10-2009 15:35:08

Hawk
Membre
Lieu: Wissous
Date d'inscription: 08-11-2008
Messages: 91
Site web

J'ai eu ce problème aussi, en fait, il faut envoyer un pointeur vers ISceneNode constant pour que ça marche.
Donc juste avant, tu fais un const irr::sceneISceneNode* node= 0, et tu envoie le node comme paramètre.
Moi je l'ai fais et ça marche.

Hors ligne


#6 

09-10-2009 17:21:10

capry
Membre
Date d'inscription: 14-02-2009
Messages: 83

bah nan toujours le même résultat =S

Hors ligne


#7 

09-10-2009 17:34:52

Hawk
Membre
Lieu: Wissous
Date d'inscription: 08-11-2008
Messages: 91
Site web

Etrange.
Moi j'ai ça dans mon code :

Code c++ :

irr::core::vector3df outPoint;
irr::core::triangle3df outTriangle;
const irr::scene::ISceneNode* node = 0;
irr::core::line3df ray = irr::core::line3df(begin, begin + irr::core::vector3df(dir.X, 0, dir.Z));
if (colmgr_->getCollisionPoint(ray, fieldTriangleSelector_,outPoint,outTriangle,node))
{
...
}


Et ça marche très bien avec la 1.6 !

Hors ligne


#8 

28-10-2009 10:14:12

capry
Membre
Date d'inscription: 14-02-2009
Messages: 83

c'est bon j'ai résolu le problème, j'ai mis tout recompiler et ça à marcher ><. Je suis sur dev et des fois ça arrive qu'un recompilage du programme résolve les problèmes. Bien maintenant que je suis bien à la 1.6, il me reste maintenant à bien détecter les collisions. Seulement voilà, j'ai utilisé la méthode avec "getCollisionNode()" du "ISceneNodeAnimatorCollisionResponse" mais là lorsque je fais

Code c++ :



if(collisionResponse->getCollisionNode() == node1)
[...]


La condition n'est jamais vraie =S. Même si les nodes entre en collision la condition ne va jamais se faire. C'est l'opposé de l'autre problème cette fois, lol.
Peut-être ais-je mal définis la variable "collisionResponse" :

Code c++ :


ITriangleSelector * triangles = sceneManager->createOctTreeTriangleSelector(mesh2,node2);
collisionResponse = m_sceneManager->createCollisionResponseAnimator(triangles,node2);



Merci de m'aider encore pour ce problème...

Hors ligne


#9 

28-10-2009 10:24:41

TUpac
Habitué
Date d'inscription: 08-09-2009
Messages: 387
Corrections: 1

Salut perso quand j'ai ce genre de soucis je fais un

Code:

std::cout << collisionResponse->getCollisionNode() << ":" << node1 << std::endl;

à chaque frame.
Ca me permet de mieux comprendre si la collision fonctionne ou si mon pointeur "node1" est mal référencé.


"Si vous ne partagez pas votre stabilité avec les pauvres, les pauvres partageront leur instabilité avec vous."

Hors ligne


#10 

29-10-2009 11:52:37

capry
Membre
Date d'inscription: 14-02-2009
Messages: 83

Si je fais ça je vois que les deux me renvoie une chaine bizarre avec 0x[...] mais le [...] est différent pour les deux. Le collisionResponse->getCollisionNode() renvoi toujours "0x3fa71e4c" ou "0x3dc2d82d" (1 fois sur 2 en fait) alors que "node1" me renvoi "0xa6e8518". C'est grave docteur ? Comment corriger ça ?

Hors ligne


#11 

29-10-2009 16:00:52

TUpac
Habitué
Date d'inscription: 08-09-2009
Messages: 387
Corrections: 1

Le code ne dis rien (c'est l'adresse mémoire de l'objet en héxa) ca veux juste dire que la collision fonctionnne puisque collision->getnode change. Donc commence par vérifier si node1 est bien référencé. Essaye de modifier un de ses paramêtres pour être sur que le pointeur est à jour.


"Si vous ne partagez pas votre stabilité avec les pauvres, les pauvres partageront leur instabilité avec vous."

Hors ligne


#12 

02-01-2010 15:35:03

Ilovechocolat
Abonné
Date d'inscription: 07-10-2009
Messages: 125

désolé de remonter ce topic mais moi, la méthode getCollisionNode() me renvoie un pointeur vers le mesh lié au collisionResponseAnimator (sauf quand celui ci est dans le vide, la ca me renvoie rien) ...
[EDIT]désolé, en fait les adresses était quasi identiques alors je me suis trompé, c'est bien vers un node différent que pointe le node que me renvoie getCollisionNode() mais je n'arrive pas a l'identifier, ce n'est ni celui de la salle, ni celui de mon zombie ni celui de la chaise au fond de la scene.
quand j'éssais de déplacer le node renvoyé par getCollisionNode(), le compilo me dit ça :

Code:

impossible de convertir un pointeur 'this' de 'const irr::scene::ISceneNode' en 'irr::scene::ISceneNode &'.

Dernière modification par Ilovechocolat (02-01-2010 15:51:21)

Hors ligne


#13 

02-01-2010 16:53:08

TUpac
Habitué
Date d'inscription: 08-09-2009
Messages: 387
Corrections: 1

Ca serait plus simple avec la ligne concernée ainsi que le code précédent ...
désolé tongue

je ne vois pas ce qui est 'this' à ce moment ...

Dernière modification par TUpac (02-01-2010 16:54:28)


"Si vous ne partagez pas votre stabilité avec les pauvres, les pauvres partageront leur instabilité avec vous."

Hors ligne


#14 

02-01-2010 17:38:37

Ilovechocolat
Abonné
Date d'inscription: 07-10-2009
Messages: 125

j'avais oublié une partie de l'erreur :

Code:

error C2662: 'irr::scene::ISceneNode::setPosition' : impossible de convertir un pointeur 'this' de 'const irr::scene::ISceneNode' en 'irr::scene::ISceneNode &'

apparemment l'erreur est dans la fonction setPosition, voici la ligne de code :

Code:

collisionReponse->getCollisionNode()->setPosition(irr::core::vector3df(0,0,0));

[EDIT]je viens de me rendre compte que le fonction getCollisionNode ne marche que quand on a utilisé la fonction createOctTreeTriangleSelector et pas avec createTriangleSelectorFromBoundingBox.
Si quelqu'un connait un moyen d'y remédier.

Dernière modification par Ilovechocolat (04-01-2010 18:04:29)

Hors ligne


Options Liens officiels Caractéristiques Statistiques Communauté
Corrections
irrlicht
irrklang
irredit
irrxml
xhtml 1.0
css 2.1
Propulsé par FluxBB
Traduit par FluxBB.fr
883 membres
1429 sujets
11121 messages
Dernier membre inscrit: Saidov17
90 invités en ligne
Aucun membre connecté
RSS Feed