From: ehofman Date: Mon, 26 Oct 2009 10:47:31 +0000 (+0000) Subject: re-enable sound positioning and velocity, test for NaN's and print a message when... X-Git-Url: https://git.mxchange.org/?a=commitdiff_plain;h=84dc82506a2b57ab1871ba313072238bc38d47af;p=simgear.git re-enable sound positioning and velocity, test for NaN's and print a message when it happens (debugging, should be removed later on). --- diff --git a/simgear/sound/sample_group.cxx b/simgear/sound/sample_group.cxx index f9813fec..d3ee7fb7 100644 --- a/simgear/sound/sample_group.cxx +++ b/simgear/sound/sample_group.cxx @@ -26,40 +26,6 @@ #include -#if defined (__APPLE__) -# ifdef __GNUC__ -# if ( __GNUC__ >= 3 ) && ( __GNUC_MINOR__ >= 3 ) -// # include -inline int (isnan)(double r) { return !(r <= 0 || r >= 0); } -# else - // any C++ header file undefines isinf and isnan - // so this should be included before - // the functions are STILL in libm (libSystem on mac os x) -extern "C" int isnan (double); -extern "C" int isinf (double); -# endif -# else -// inline int (isinf)(double r) { return isinf(r); } -// inline int (isnan)(double r) { return isnan(r); } -# endif -#endif - -#if defined (__FreeBSD__) -# if __FreeBSD_version < 500000 - extern "C" { - inline int isnan(double r) { return !(r <= 0 || r >= 0); } - } -# endif -#endif - -#if defined (__CYGWIN__) -# include -#endif - -#if defined(__MINGW32__) -# define isnan(x) _isnan(x) -#endif - #include "soundmgr_openal.hxx" #include "sample_group.hxx" @@ -195,6 +161,7 @@ void SGSampleGroup::update( double dt ) { sample->no_valid_source(); _smgr->release_source( source ); _smgr->release_buffer( sample ); + remove( sample->get_sample_name() ); } } testForALError("update"); @@ -392,15 +359,23 @@ void SGSampleGroup::update_sample_config( SGSoundSample *sample ) { if ( sample->is_valid_source() ) { unsigned int source = sample->get_source(); -#if 0 +#if 1 if ( _tied_to_listener && _smgr->has_changed() ) { alSourcefv( source, AL_POSITION, _smgr->get_position().data() ); - alSourcefv( source, AL_DIRECTION, _smgr->get_direction().data() ); alSourcefv( source, AL_VELOCITY, _smgr->get_velocity().data() ); +#if 0 + alSourcefv( source, AL_DIRECTION, _smgr->get_direction().data() ); +#endif } else { +float *pos = sample->get_position(); +if (isnan(pos[0]) || isnan(pos[1]) || isnan(pos[2])) printf("NaN detected in source position\n"); alSourcefv( source, AL_POSITION, sample->get_position() ); - alSourcefv( source, AL_DIRECTION, sample->get_orientation() ); +float *vel = sample->get_velocity(); +if (isnan(vel[0]) || isnan(vel[1]) || isnan(vel[2])) printf("NaN detected in source velocity\n"); alSourcefv( source, AL_VELOCITY, sample->get_velocity() ); +#if 0 + alSourcefv( source, AL_DIRECTION, sample->get_orientation() ); +#endif } #else alSourcefv( source, AL_POSITION, SGVec3f::zeros().data() ); diff --git a/simgear/sound/soundmgr_openal.cxx b/simgear/sound/soundmgr_openal.cxx index 37b138c5..bfe0a2e7 100644 --- a/simgear/sound/soundmgr_openal.cxx +++ b/simgear/sound/soundmgr_openal.cxx @@ -254,9 +254,14 @@ void SGSoundMgr::update_late( double dt ) { alListenerf( AL_GAIN, _volume ); #if 0 alListenerfv( AL_ORIENTATION, _at_up_vec ); +#endif +double *pos = _position.data(); +if (isnan(pos[0]) || isnan(pos[1]) || isnan(pos[2])) printf("NaN detected in listener position\n"); alListenerfv( AL_POSITION, toVec3f(_position).data() ); + +double *vel = _velocity.data(); +if (isnan(vel[0]) || isnan(vel[1]) || isnan(vel[2])) printf("NaN detected in listener velocity\n"); alListenerfv( AL_VELOCITY, toVec3f(_velocity).data() ); -#endif // alDopplerVelocity(340.3); // TODO: altitude dependent testForALError("update"); _changed = false; diff --git a/simgear/sound/xmlsound.cxx b/simgear/sound/xmlsound.cxx index 39cfdfe0..9e3ae813 100644 --- a/simgear/sound/xmlsound.cxx +++ b/simgear/sound/xmlsound.cxx @@ -101,9 +101,6 @@ SGXmlSound::init(SGPropertyNode *root, SGPropertyNode *node, } else { _mode = SGXmlSound::ONCE; - - if ( strcmp(mode_str, "") ) - SG_LOG(SG_GENERAL,SG_INFO, "Unknown sound mode for '" << _name << "', default to 'once'"); } _property = root->getNode(node->getStringValue("property", ""), true);