float llGetSoundLength(key id);
tracked
Cutie Crush
It's an age-old problem.. you're building a device to play some sounds in order. Because of SL's file-upload limitations, these files might be small sequential bits of a longer recording. Maybe it's music, maybe it's atmospheric sound effects, maybe a recorded speech. Doesn't matter.
With recent changes, NEW sound files can be 'up to' 30 seconds long, while older sounds were limited to 10 seconds maximum. But there's no reason that a sound file couldn't be 4 seconds, 1 second, 27 seconds, etc.
I propose a function be added, that would retrieve the playback length of a given sound (id), returning it as a float of fractional seconds.
This would allow scripts to know exactly how long of a delay to insert between playing sound A, and sound B, C, D, and so on.
Log In
Bleuhazenfurfle Resident
This request has been around the block a couple times… I myself have commented on this topic two or three times — at least — between here and the old Jira.
Quick search of my bookmarks turned up this:
Note Signal Linden's comments therein, and my vote is still for llRequestInventoryData, instead of a new command.
RestrainedRaptor Resident
You may want to check out the relatively unknown sound queue feature.
Cutie Crush
RestrainedRaptor Resident llSetSoundQueueing
"The sound queue is only 1 level deep - this means that beside the sound that is currently playing, there can only be 1 sound in reserve. The sound queue is first-come, first-serve. SVC-4260"
There's still no way to determine how long the sounds ARE.. and you can only stack one sound, with no feedback as to whether that sound has played yet.
So if you played Sound A, then triggered Sound B nine seconds later, then Sound C nine seconds after that, it'd work fine.. but the problem is, if the sounds were 10 seconds long.. around the time you played Sound 8, those 1-second mismatches would start stacking up, causing two 'play' events to execute while one sound was still playing.
That'll result in one sound getting missed.
This problem becomes more severe (and easier to understand) if someone loaded 30-second long sounds into this. By the time a 30 second sound had finished, the script would have executed 3 more 'play next sound' commands. The Queue, being only one sound deep, would play sound 1 (0), then 2 (9), then it would ignore the commands to play sounds 3 (18), and 4 (27). Once sound 2 started at (30), it would finally be able to queue a new sound, which would be 5 (commanded at 36 seconds), then it would ignore 6 (45), 7 (54).. it would then trigger sound 5 at (60), then it would cue up sound 9 (63), ignoring 10 (72), and 11 (80).
Then you'll face a race condition, whether sound 5 at (90), clearing the queue to receive sound 12 (90), or whether the cue command will come in just before the sound plays, causing 12 to be ignored in favor of waiting til 13 (99).
RestrainedRaptor Resident
Cutie Crush Ouch... Fair enough. I didn't read all the caveats. Once again, LSL is awful.
SL Feedback
tracked
SL Feedback
Hello, and thank you for your feature request regarding the function to retrieve the playback length of a given sound. This idea has been brought up in the past and is currently tracked. We understand the importance of this feature for creating seamless audio experiences in Second Life, whether it's for music, atmospheric sound effects, or character narration. While we have no estimate on when it may be implemented, please keep an eye on future updates. We appreciate your input and hope you continue to share your ideas to help improve Second Life. Thank you!
Crush Cutie
SL Feedback I am starting to really detest this AI.
It might as well just post "shut up now, we don't care".
Bleuhazenfurfle Resident
Crush Cutie: Am having trouble deciding if it's better or worse than the old one-click rubber stamp responses… At least this one gives the impression (even if just an illusion) that someone actually read it — especially for people new to the feedback forum. Us old-timers know they don't care already, but we shouldn't discourage the noobs. :P