Развернуть столкновение между двумя движущимися сферами?

Я пытаюсь выяснить функцию для обнаружения столкновения между двумя движущимися сферами, как объяснено в ЭТОЙ СТАТЬЕ, но я понятия не имею, на каком языке приведен пример в этой статье, поэтому я не знаю, как мне перевести его на C# (язык, на котором я программирую)

Может ли кто-то либо:

  • Подскажите на каком языке пример кода?
  • Переведите пример кода на C#
  • Или объясните мне, кто новичок в этом виде программирования, как работает Sphere-Sphere Sweep Collision, чтобы я мог попытаться реализовать это сам

Я благодарен за любой ответ, так как я застрял с этим некоторое время сейчас.


Вот пример кода на пока неопознанном языке:

#include "vector.h"

template< class T >

inline void SWAP( T& a, T& b )
//swap the values of a and b

{



const T temp = a;
a = b;
b = temp;
}

// Return true if r1 and r2 are real
inline bool QuadraticFormula
(
const SCALAR a,
const SCALAR b,
const SCALAR c,
SCALAR& r1,  //first
SCALAR& r2   //and second roots
)

{




const SCALAR q = b*b - 4*a*c; 
if( q >= 0 )

{




const SCALAR sq = sqrt(q);
const SCALAR d = 1 / (2*a);
r1 = ( -b + sq ) * d;
r2 = ( -b - sq ) * d;
return true;//real roots

}

else

{




return false;//complex roots

}

}

const bool SphereSphereSweep
(
const SCALAR    ra, //radius of sphere A
const VECTOR&   A0, //previous position of sphere A
const VECTOR&   A1, //current position of sphere A
const SCALAR    rb, //radius of sphere B
const VECTOR&   B0, //previous position of sphere B
const VECTOR&   B1, //current position of sphere B
SCALAR&  u0,    //normalized time of first collision
SCALAR&  u1 //normalized time of second collision

)

{



const VECTOR va = A1 - A0;
//vector from A0 to A1

const VECTOR vb = B1 - B0;
//vector from B0 to B1

const VECTOR AB = B0 - A0;
//vector from A0 to B0

const VECTOR vab = vb - va;
//relative velocity (in normalized time)

const SCALAR rab = ra + rb;

const SCALAR a = vab.dot(vab);
//u*u coefficient

const SCALAR b = 2*vab.dot(AB);
//u coefficient

const SCALAR c = AB.dot(AB) - rab*rab;
//constant term
//check if they're currently overlapping
if( AB.dot(AB) <= rab*rab )

{




u0 = 0;
u1 = 0;
return true;

}

//check if they hit each other 
// during the frame
if( QuadraticFormula( a, b, c, u0, u1 ) )
{




if( u0 > u1 )
SWAP( u0, u1 );
return true;

}

return false;

}

0 ответов

Другие вопросы по тегам