123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129 |
- #include "Animation3D.h"
- #include "Model3D.h"
- using namespace Framework;
- void Animation3D::deleteKnochenData( KnochenData *d )
- {
- if( d->next != 0 )
- deleteKnochenData( d->next );
- delete d;
- }
- Animation3D::Animation3D()
- {
- for( int i = 0; i < MAX_KNOCHEN_ANZ; i++ )
- kd[ i ] = 0;
- maxTime = 0;
- ref = 1;
- }
- Animation3D::~Animation3D()
- {
- for( int i = 0; i < MAX_KNOCHEN_ANZ; i++ )
- deleteKnochenData( kd[ i ] );
- }
- void Animation3D::addKeyFrame( int kId, double time, Vec3<float> pos, Vec3<float> rot )
- {
- KnochenData *d = kd[ kId ];
- if( !d )
- {
- kd[ kId ] = new KnochenData();
- kd[ kId ]->next = 0;
- kd[ kId ]->time = time;
- kd[ kId ]->pos = pos;
- kd[ kId ]->rot = rot;
- return;
- }
- while( d->next )
- d = d->next;
- d->next = new KnochenData();
- d->next->next = 0;
- d->next->time = time;
- d->next->pos = pos;
- d->next->rot = rot;
- }
- void Animation3D::apply( Skelett *zS, double &timeOffset, double sec ) const
- {
- if( zS->k )
- apply( zS->k, timeOffset, sec );
- timeOffset += sec;
- if( timeOffset > maxTime )
- timeOffset -= maxTime;
- }
- void Animation3D::apply( Knochen *zK, double timeOffset, double sec ) const
- {
- if( zK->geschwister )
- apply( zK->geschwister, timeOffset, sec );
- if( zK->kinder )
- apply( zK->kinder, timeOffset, sec );
- KnochenData *d = kd[ zK->id ];
- if( d )
- {
- while( timeOffset > d->time )
- {
- timeOffset -= d->time;
- d = d->next;
- if( !d )
- d = kd[ zK->id ];
- }
- while( sec > 0 )
- {
- double left = d->time - timeOffset;
- if( left > 0 )
- {
- float proc = (float)MIN( sec / left, 1 );
- zK->pos += ( d->pos - zK->pos ) * proc;
- zK->winkel += ( d->rot - zK->winkel ) * proc;
- sec -= left;
- }
- else
- {
- zK->pos = d->pos;
- zK->winkel = d->rot;
- sec -= d->time;
- }
- timeOffset = 0;
- d = d->next;
- if( !d )
- d = kd[ zK->id ];
- }
- }
- }
- Animation3D *Animation3D::getThis()
- {
- ref++;
- return this;
- }
- Animation3D *Animation3D::release()
- {
- if( --ref == 0 )
- delete this;
- return 0;
- }
|