End-user process
- Open app
- Switch on 'Silent Mode'.
- Press 'Lock-button'
- App can still START playing a sound after hours have passed, not playing any audio in the interim.
Apps that do this
A lot of alarm apps have manage to do this & I dont think they are using silent audio to keep the app running as they do not sound if you actually exit the app with home.
- Alarm Clock Pro
- My Clock
- Wave Alarm
- Alarmed
- iHome
- ...
...Are they keeping a loop running after being locked some how or it a notification(which cant play sound in silent) starting the app back up to play the audio, or some other method?
Current Methods Implemented
AVAudioPlayer using:
AudioSessionInitialize(nil, nil, nil, nil);
AudioSessionSetActive(YES);
UInt32 sessionCategory = kAudioSessionCategory_MediaPlayback;
AudioSessionSetProperty (kAudioSessionProperty_AudioCategory, sizeof(sessionCategory),&sessionCategory);
And setting Info.plist to:
Required background modes(UIBackGroundModes) - App plays audio (audio)
At Present
I can play audio even in silent when the app is running and on screen. If the audio is already running the app can be closed with home button and audio will run. BUT if the app is not playing audio, and the screen is locked, all threads are killed and audio is never played. How do theses apps manage to work around this?
Possible approaches Found So Far
A. Use 'beginBackgroundTaskWithExpirationHandler:' with an infinite loop to keep app running indefinitely.
Pros:
- Looks like you can make this work in a lot of situations, even when the user presses home.
Cons:
- This goes against apple policies as far as I can tell.
- will use more resources
Comments:
I've almost got this to work and might with some tweaking. This does not seem to be what all these other alarms are doing as they do not keep on running if you press home BTN. Which suggest that they use some method that gives them permission to run while locked but not in the BG. (Which is what I need)
Also, When you ask how much time you have left running you get aprox 10 min. By dropping an infinite loop in there the numbers will actually run down to 0 and then go into the negatives for hours on end.(tested) Im not sure how this would behave in the real world or in terms of app acceptance.
B. Use a silent audio loop to pose as a continus audio playing media center
Pros:
- Worked when locked, and will keep up running in most situations.
Cons:
- Can fail if interrupted by another media center and in some other occasions.
- Can also go agains apple policy.
Comments:
This can work I a lot of situations but is by far not ideal. And since Like I say again, there has to be another method that is not documented.
Conclussions Thus Far
Testing with the listed APPs suggests that they are not using any of the two methods I just described. Method 'A' seems to be closer but if implemented would not behave how these apps behave.
I used a apple developer ticket to get more info, I'll post any new findings along those means as well.
Thank You
Any insight is appreciated, and for your participation thus far.
See Question&Answers more detail:
os