Changeset 6320 for code/branches/presentation2/src/orxonox/sound
- Timestamp:
- Dec 11, 2009, 2:05:00 AM (15 years ago)
- Location:
- code/branches/presentation2/src/orxonox/sound
- Files:
-
- 4 edited
Legend:
- Unmodified
- Added
- Removed
-
code/branches/presentation2/src/orxonox/sound/AmbientSound.cc
r6307 r6320 58 58 { 59 59 registerVariable(volume_, ObjectDirection::ToClient, new NetworkCallback<BaseSound>(static_cast<BaseSound*>(this), &BaseSound::volumeChanged)); 60 // registerVariable(source_, ObjectDirection::ToClient, new NetworkCallback<BaseSound>(static_cast<BaseSound*>(this), &BaseSound::sourceChanged));61 60 registerVariable(ambientSource_, ObjectDirection::ToClient, new NetworkCallback<AmbientSound>(this, &AmbientSound::ambientSourceChanged)); 62 61 registerVariable(bLooping_, ObjectDirection::ToClient, new NetworkCallback<BaseSound>(static_cast<BaseSound*>(this), &BaseSound::loopingChanged)); 63 62 registerVariable(pitch_, ObjectDirection::ToClient, new NetworkCallback<BaseSound>(static_cast<BaseSound*>(this), &BaseSound::pitchChanged)); 64 registerVariable((int&)(BaseSound::state_), ObjectDirection::ToClient );63 registerVariable((int&)(BaseSound::state_), ObjectDirection::ToClient, new NetworkCallback<BaseSound>(static_cast<BaseSound*>(this), &BaseSound::stateChanged)); 65 64 } 66 65 … … 84 83 SoundManager::getInstance().registerAmbientSound(this); 85 84 } 85 else 86 BaseSound::play(); 86 87 } 87 88 … … 97 98 SoundManager::getInstance().unregisterAmbientSound(this); 98 99 } 100 else 101 BaseSound::stop(); 99 102 } 100 103 … … 110 113 SoundManager::getInstance().pauseAmbientSound(this); 111 114 } 115 else 116 BaseSound::pause(); 112 117 } 113 118 … … 136 141 } 137 142 138 void AmbientSound::changedActivity() 143 void AmbientSound::changedActivity() 139 144 { 140 145 SUPER(AmbientSound, changedActivity); -
code/branches/presentation2/src/orxonox/sound/BaseSound.cc
r6307 r6320 221 221 alSourcePause(this->audioSource_); 222 222 } 223 224 void BaseSound::stateChanged() 225 { 226 CCOUT(0) << "changed state to " << this->state_ << endl; 227 switch( this->state_ ) 228 { 229 case Playing: 230 this->play(); 231 break; 232 case Paused: 233 this->pause(); 234 break; 235 case Stopped: 236 default: 237 this->stop(); 238 break; 239 } 240 } 223 241 } -
code/branches/presentation2/src/orxonox/sound/BaseSound.h
r6307 r6320 59 59 virtual void pause(); 60 60 61 bool isPlaying() { return this->state_ == Playing; }62 bool isPaused() { return this->state_ == Paused; }63 bool isStopped() { return this->state_ == Stopped; }61 bool isPlaying() const { return this->state_ == Playing; } 62 bool isPaused() const { return this->state_ == Paused; } 63 bool isStopped() const { return this->state_ == Stopped; } 64 64 65 65 void setPlaying(bool val) … … 84 84 void setPitch(float pitch); 85 85 inline void pitchChanged(){ this->setPitch(this->pitch_); } 86 87 void stateChanged(); 86 88 87 89 //ALuint getALAudioSource(void); -
code/branches/presentation2/src/orxonox/sound/WorldSound.cc
r6307 r6320 60 60 registerVariable(source_, ObjectDirection::ToClient, new NetworkCallback<BaseSound>(static_cast<BaseSound*>(this), &BaseSound::sourceChanged)); 61 61 registerVariable(bLooping_, ObjectDirection::ToClient, new NetworkCallback<BaseSound>(static_cast<BaseSound*>(this), &BaseSound::loopingChanged)); 62 registerVariable((int&)(BaseSound::state_), ObjectDirection::ToClient );62 registerVariable((int&)(BaseSound::state_), ObjectDirection::ToClient, new NetworkCallback<BaseSound>(static_cast<BaseSound*>(this), &BaseSound::stateChanged)); 63 63 registerVariable(pitch_, ObjectDirection::ToClient, new NetworkCallback<BaseSound>(static_cast<BaseSound*>(this), &BaseSound::pitchChanged)); 64 64 }
Note: See TracChangeset
for help on using the changeset viewer.