-
Notifications
You must be signed in to change notification settings - Fork 171
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Audio does not resume after it has been suspended by iOS (iPhone 5s & iOS 7.1) #65
Comments
I believe I figured this one out... In OALSuspendHandler.m, setInterrupted:value method, there is a function call to objc_msgsend(). I assume this was used since the name of the receiving class/target and the selector are determined at runtime. Unfortunately, the parameter, in this case interruptLock, is always received as false on the receiving selector even if interruptLock was set to true. Again, I don't see this happening on the other test phones I have, just on the iPhone 5s with 7.1 (and 7.1.1). In order to workaround this problem, I changed my version of OALSuspendHandler.m setInterrupted:value. I replaced:
with
The same problem may exist with the use of objc_msgsend() function in the setManuallySuspended:value within the same class. I'm not a contributor, so if any of the active contributors to this project wants to verify my results and incorporate this change, feel free to do so. Cheers! |
…ended by iOS (iPhone 5s & iOS 7.1) kstenerud#65
Hey @kstenerud, have you had an opportunity to look into this by chance? You and I were e-mailing about a very similar issue last month (Gmail thread titled "ObjectAL + iOS interruptions"), but we never did solve it. I'm wondering if the solution proposed above works? @gelano, @besbes: Are you guys still successfully using this solution? Can it safely be merged into ObjectAL? |
@picobots: yes, we're using this workaround. Didn't observe any problems with it so far. |
Hi @picobots, could you make a PR with this fix? I'll push it to the main branch for everyone. |
Sure, I definitely could. But it looks like @besbes already has a fork with the solution committed: @besbes, maybe you could just submit a PR? Credit where credit is due :) |
@picobots @kstenerud I created a PR with this fix. Thanks for the support! |
Merged. Thanks! |
I just noticed another "disappearing sound effects" bug, this time on iOS 6 (on an iPad 2). It's pretty much the same as what's described here: https://groups.google.com/d/msg/objectal-for-iphone/ubRWltp_i1Q/GR0FWSW6vi0J Steps to reproduce:
@kstenerud: The link above is a pretty old issue, did you ever solve that in the past? Is it possible that this new interruption bug fix reintroduced an old iOS 6 bug? Sub-question: Perhaps the old code should still be in place for iOS 6 and below, with this new code only for iOS 7+? @besbes and @gelano: Can either of you confirm that you're also seeing disappearing sound effects on iOS 6 as described above? |
More information: Sound effects also seem to disappear on iOS 6 if the audio is interrupted (e.g., by a FaceTime call). I could've sworn this used to work with ObjectAL and iOS 6, didn't it? I'm wondering if this new iOS 7 fix just isn't "iOS 6 safe". |
Environment: iOS 7.1, iPhone 5s
Based on the OALAudioTrack sample code and using either the bleeding edge or 2.2 version for iOS, audio output does not resume after audio is interrupted by either Siri, dictation (via keyboard), phone call, or alarm. I have also tried the last commit changes on OALAudioTrack.m which does not resolve this problem.
Reproducibility: 100% on iPhone 5s with iOS 7.1
Other environments tested:
The only output in the console window is as follows:
2014-04-21 21:11:13.684 {App Name Omitted}[8559:60b] !!! _NSLayoutTreeGetBaselineOffsetForGlyphAtIndex invalid glyph index 0
Note: Using OALSimpleAudio sample code generates an exception.
Let me know if I need to provide any additional information to help. Thanks.
The text was updated successfully, but these errors were encountered: