diff options
Diffstat (limited to 'linden/indra/llaudio/audioengine.cpp')
-rw-r--r-- | linden/indra/llaudio/audioengine.cpp | 184 |
1 files changed, 158 insertions, 26 deletions
diff --git a/linden/indra/llaudio/audioengine.cpp b/linden/indra/llaudio/audioengine.cpp index 5fb38c0..239981b 100644 --- a/linden/indra/llaudio/audioengine.cpp +++ b/linden/indra/llaudio/audioengine.cpp | |||
@@ -51,9 +51,6 @@ extern void request_sound(const LLUUID &sound_guid); | |||
51 | 51 | ||
52 | LLAudioEngine* gAudiop = NULL; | 52 | LLAudioEngine* gAudiop = NULL; |
53 | 53 | ||
54 | // Maximum amount of time we wait for a transfer to complete before starting | ||
55 | // off another one. | ||
56 | const F32 MAX_CURRENT_TRANSFER_TIME = 60.f; | ||
57 | 54 | ||
58 | // | 55 | // |
59 | // LLAudioEngine implementation | 56 | // LLAudioEngine implementation |
@@ -77,7 +74,8 @@ void LLAudioEngine::setDefaults() | |||
77 | 74 | ||
78 | mListenerp = NULL; | 75 | mListenerp = NULL; |
79 | 76 | ||
80 | mMuted = FALSE; | 77 | mMuted = false; |
78 | mUserData = NULL; | ||
81 | 79 | ||
82 | mLastStatus = 0; | 80 | mLastStatus = 0; |
83 | 81 | ||
@@ -98,16 +96,20 @@ void LLAudioEngine::setDefaults() | |||
98 | mInternetStreamGain = 0.125f; | 96 | mInternetStreamGain = 0.125f; |
99 | mNextWindUpdate = 0.f; | 97 | mNextWindUpdate = 0.f; |
100 | 98 | ||
99 | mInternetStreamMedia = NULL; | ||
100 | mInternetStreamURL.clear(); | ||
101 | |||
101 | for (U32 i = 0; i < LLAudioEngine::AUDIO_TYPE_COUNT; i++) | 102 | for (U32 i = 0; i < LLAudioEngine::AUDIO_TYPE_COUNT; i++) |
102 | mSecondaryGain[i] = 1.0f; | 103 | mSecondaryGain[i] = 1.0f; |
103 | } | 104 | } |
104 | 105 | ||
105 | 106 | ||
106 | BOOL LLAudioEngine::init(const S32 num_channels) | 107 | bool LLAudioEngine::init(const S32 num_channels, void* userdata) |
107 | { | 108 | { |
108 | setDefaults(); | 109 | setDefaults(); |
109 | 110 | ||
110 | mNumChannels = num_channels; | 111 | mNumChannels = num_channels; |
112 | mUserData = userdata; | ||
111 | 113 | ||
112 | allocateListener(); | 114 | allocateListener(); |
113 | 115 | ||
@@ -126,6 +128,9 @@ void LLAudioEngine::shutdown() | |||
126 | delete gAudioDecodeMgrp; | 128 | delete gAudioDecodeMgrp; |
127 | gAudioDecodeMgrp = NULL; | 129 | gAudioDecodeMgrp = NULL; |
128 | 130 | ||
131 | // Clean up wind source | ||
132 | cleanupWind(); | ||
133 | |||
129 | // Clean up audio sources | 134 | // Clean up audio sources |
130 | source_map::iterator iter_src; | 135 | source_map::iterator iter_src; |
131 | for (iter_src = mAllSources.begin(); iter_src != mAllSources.end(); iter_src++) | 136 | for (iter_src = mAllSources.begin(); iter_src != mAllSources.end(); iter_src++) |
@@ -146,22 +151,146 @@ void LLAudioEngine::shutdown() | |||
146 | S32 i; | 151 | S32 i; |
147 | for (i = 0; i < MAX_CHANNELS; i++) | 152 | for (i = 0; i < MAX_CHANNELS; i++) |
148 | { | 153 | { |
149 | if (mChannels[i]) | 154 | delete mChannels[i]; |
150 | { | 155 | mChannels[i] = NULL; |
151 | delete mChannels[i]; | ||
152 | mChannels[i] = NULL; | ||
153 | } | ||
154 | } | 156 | } |
155 | 157 | ||
156 | // Clean up buffers | 158 | // Clean up buffers |
157 | for (i = 0; i < MAX_BUFFERS; i++) | 159 | for (i = 0; i < MAX_BUFFERS; i++) |
158 | { | 160 | { |
159 | if (mBuffers[i]) | 161 | delete mBuffers[i]; |
162 | mBuffers[i] = NULL; | ||
163 | } | ||
164 | |||
165 | delete mInternetStreamMedia; | ||
166 | mInternetStreamMedia = NULL; | ||
167 | mInternetStreamURL.clear(); | ||
168 | } | ||
169 | |||
170 | |||
171 | // virtual | ||
172 | void LLAudioEngine::startInternetStream(const std::string& url) | ||
173 | { | ||
174 | llinfos << "entered startInternetStream()" << llendl; | ||
175 | |||
176 | if (!mInternetStreamMedia) | ||
177 | { | ||
178 | LLMediaManager* mgr = LLMediaManager::getInstance(); | ||
179 | if (mgr) | ||
160 | { | 180 | { |
161 | delete mBuffers[i]; | 181 | mInternetStreamMedia = mgr->createSourceFromMimeType(LLURI(url).scheme(), "audio/mpeg"); // assumes that whatever media implementation supports mp3 also supports vorbis. |
162 | mBuffers[i] = NULL; | 182 | llinfos << "mInternetStreamMedia is now " << mInternetStreamMedia << llendl; |
183 | } | ||
184 | } | ||
185 | |||
186 | if(!mInternetStreamMedia) | ||
187 | return; | ||
188 | |||
189 | if (!url.empty()) { | ||
190 | llinfos << "Starting internet stream: " << url << llendl; | ||
191 | mInternetStreamURL = url; | ||
192 | mInternetStreamMedia->navigateTo ( url ); | ||
193 | llinfos << "Playing....." << llendl; | ||
194 | mInternetStreamMedia->addCommand(LLMediaBase::COMMAND_START); | ||
195 | mInternetStreamMedia->updateMedia(); | ||
196 | } else { | ||
197 | llinfos << "setting stream to NULL"<< llendl; | ||
198 | mInternetStreamURL.clear(); | ||
199 | mInternetStreamMedia->addCommand(LLMediaBase::COMMAND_STOP); | ||
200 | mInternetStreamMedia->updateMedia(); | ||
201 | } | ||
202 | //#endif | ||
203 | } | ||
204 | |||
205 | // virtual | ||
206 | void LLAudioEngine::stopInternetStream() | ||
207 | { | ||
208 | llinfos << "entered stopInternetStream()" << llendl; | ||
209 | |||
210 | if(mInternetStreamMedia) | ||
211 | { | ||
212 | if( ! mInternetStreamMedia->addCommand(LLMediaBase::COMMAND_STOP)){ | ||
213 | llinfos << "attempting to stop stream failed!" << llendl; | ||
214 | } | ||
215 | mInternetStreamMedia->updateMedia(); | ||
216 | } | ||
217 | |||
218 | mInternetStreamURL.clear(); | ||
219 | } | ||
220 | |||
221 | // virtual | ||
222 | void LLAudioEngine::pauseInternetStream(int pause) | ||
223 | { | ||
224 | llinfos << "entered pauseInternetStream()" << llendl; | ||
225 | |||
226 | if(!mInternetStreamMedia) | ||
227 | return; | ||
228 | |||
229 | if(pause) | ||
230 | { | ||
231 | if(! mInternetStreamMedia->addCommand(LLMediaBase::COMMAND_PAUSE)) | ||
232 | { | ||
233 | llinfos << "attempting to pause stream failed!" << llendl; | ||
163 | } | 234 | } |
235 | } else { | ||
236 | if(! mInternetStreamMedia->addCommand(LLMediaBase::COMMAND_START)) | ||
237 | { | ||
238 | llinfos << "attempting to unpause stream failed!" << llendl; | ||
239 | } | ||
240 | } | ||
241 | mInternetStreamMedia->updateMedia(); | ||
242 | } | ||
243 | |||
244 | // virtual | ||
245 | void LLAudioEngine::updateInternetStream() | ||
246 | { | ||
247 | if (mInternetStreamMedia) | ||
248 | mInternetStreamMedia->updateMedia(); | ||
249 | } | ||
250 | |||
251 | // virtual | ||
252 | int LLAudioEngine::isInternetStreamPlaying() | ||
253 | { | ||
254 | if (!mInternetStreamMedia) | ||
255 | return 0; | ||
256 | |||
257 | if (mInternetStreamMedia->getStatus() == LLMediaBase::STATUS_STARTED) | ||
258 | { | ||
259 | return 1; // Active and playing | ||
260 | } | ||
261 | |||
262 | if (mInternetStreamMedia->getStatus() == LLMediaBase::STATUS_PAUSED) | ||
263 | { | ||
264 | return 2; // paused | ||
164 | } | 265 | } |
266 | |||
267 | return 0; // Stopped | ||
268 | } | ||
269 | |||
270 | // virtual | ||
271 | void LLAudioEngine::getInternetStreamInfo(char* artist, char* title) | ||
272 | { | ||
273 | artist[0] = 0; | ||
274 | title[0] = 0; | ||
275 | } | ||
276 | |||
277 | // virtual | ||
278 | void LLAudioEngine::setInternetStreamGain(F32 vol) | ||
279 | { | ||
280 | mInternetStreamGain = vol; | ||
281 | |||
282 | if(!mInternetStreamMedia) | ||
283 | return; | ||
284 | |||
285 | vol = llclamp(vol, 0.f, 1.f); | ||
286 | mInternetStreamMedia->setVolume(vol); | ||
287 | mInternetStreamMedia->updateMedia(); | ||
288 | } | ||
289 | |||
290 | // virtual | ||
291 | const std::string& LLAudioEngine::getInternetStreamURL() | ||
292 | { | ||
293 | return mInternetStreamURL; | ||
165 | } | 294 | } |
166 | 295 | ||
167 | 296 | ||
@@ -449,6 +578,8 @@ void LLAudioEngine::idle(F32 max_decode_time) | |||
449 | // missed picking it up in all the places that can add | 578 | // missed picking it up in all the places that can add |
450 | // or request new data. | 579 | // or request new data. |
451 | startNextTransfer(); | 580 | startNextTransfer(); |
581 | |||
582 | updateInternetStream(); | ||
452 | } | 583 | } |
453 | 584 | ||
454 | 585 | ||
@@ -758,7 +889,7 @@ void LLAudioEngine::triggerSound(const LLUUID &audio_uuid, const LLUUID& owner_i | |||
758 | LLUUID source_id; | 889 | LLUUID source_id; |
759 | source_id.generate(); | 890 | source_id.generate(); |
760 | 891 | ||
761 | LLAudioSource *asp = new LLAudioSource(source_id, owner_id, gain); | 892 | LLAudioSource *asp = new LLAudioSource(source_id, owner_id, gain, type); |
762 | gAudiop->addAudioSource(asp); | 893 | gAudiop->addAudioSource(asp); |
763 | if (pos_global.isExactlyZero()) | 894 | if (pos_global.isExactlyZero()) |
764 | { | 895 | { |
@@ -1207,18 +1338,18 @@ void LLAudioEngine::assetCallback(LLVFS *vfs, const LLUUID &uuid, LLAssetType::E | |||
1207 | // | 1338 | // |
1208 | 1339 | ||
1209 | 1340 | ||
1210 | LLAudioSource::LLAudioSource(const LLUUID& id, const LLUUID& owner_id, const F32 gain) | 1341 | LLAudioSource::LLAudioSource(const LLUUID& id, const LLUUID& owner_id, const F32 gain, const S32 type) |
1211 | : mID(id), | 1342 | : mID(id), |
1212 | mOwnerID(owner_id), | 1343 | mOwnerID(owner_id), |
1213 | mPriority(0.f), | 1344 | mPriority(0.f), |
1214 | mGain(gain), | 1345 | mGain(gain), |
1215 | mType(type), | 1346 | mType(type), |
1216 | mAmbient(FALSE), | 1347 | mAmbient(false), |
1217 | mLoop(FALSE), | 1348 | mLoop(false), |
1218 | mSyncMaster(FALSE), | 1349 | mSyncMaster(false), |
1219 | mSyncSlave(FALSE), | 1350 | mSyncSlave(false), |
1220 | mQueueSounds(FALSE), | 1351 | mQueueSounds(false), |
1221 | mPlayedOnce(FALSE), | 1352 | mPlayedOnce(false), |
1222 | mChannelp(NULL), | 1353 | mChannelp(NULL), |
1223 | mCurrentDatap(NULL), | 1354 | mCurrentDatap(NULL), |
1224 | mQueuedDatap(NULL) | 1355 | mQueuedDatap(NULL) |
@@ -1364,7 +1495,8 @@ bool LLAudioSource::play(const LLUUID &audio_uuid) | |||
1364 | bool LLAudioSource::isDone() | 1495 | bool LLAudioSource::isDone() |
1365 | { | 1496 | { |
1366 | const F32 MAX_AGE = 60.f; | 1497 | const F32 MAX_AGE = 60.f; |
1367 | const F32 MAX_UNPLAYED_AGE = 30.f; | 1498 | const F32 MAX_UNPLAYED_AGE = 15.f; |
1499 | |||
1368 | if (isLoop()) | 1500 | if (isLoop()) |
1369 | { | 1501 | { |
1370 | // Looped sources never die on their own. | 1502 | // Looped sources never die on their own. |
@@ -1542,8 +1674,8 @@ LLAudioBuffer *LLAudioSource::getCurrentBuffer() | |||
1542 | LLAudioChannel::LLAudioChannel() : | 1674 | LLAudioChannel::LLAudioChannel() : |
1543 | mCurrentSourcep(NULL), | 1675 | mCurrentSourcep(NULL), |
1544 | mCurrentBufferp(NULL), | 1676 | mCurrentBufferp(NULL), |
1545 | mLoopedThisFrame(FALSE), | 1677 | mLoopedThisFrame(false), |
1546 | mWaiting(FALSE), | 1678 | mWaiting(false), |
1547 | mSecondaryGain(1.0f) | 1679 | mSecondaryGain(1.0f) |
1548 | { | 1680 | { |
1549 | } | 1681 | } |
@@ -1609,8 +1741,8 @@ bool LLAudioChannel::updateBuffer() | |||
1609 | } | 1741 | } |
1610 | 1742 | ||
1611 | // | 1743 | // |
1612 | // The source changed what buffer it's playing. Whe need to clean up the | 1744 | // The source changed what buffer it's playing. We need to clean up |
1613 | // existing fmod channel | 1745 | // the existing channel |
1614 | // | 1746 | // |
1615 | cleanup(); | 1747 | cleanup(); |
1616 | 1748 | ||