-
Notifications
You must be signed in to change notification settings - Fork 13
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
Android receiver possible? #5
Comments
First thing: Would you like to stream audio from the mobile to the wavesync (to get multiroom audio controlled conveniently from mobile) - or receive the audio on the mobile and play it. I would seriously LOVE the ability to stream from my mobile - I currently use a bluetooth dongle, capture it's output and synchronise audio using rpis - hacky. Bluetooth dongle is simpler to use for my family than mobile-controlled sound daemons - which can hook up to spotify or play local collection. I don't have a usecase for streaming TO THE android really - but can imagine it might be useful. Both cases have different problems. ;-) Android as a sourceNTP is not problem in this case at all. System adds a delay to have enough time to synchronise audio in a laggy network. Mobile connected to any NTP should be accurate to within +/- 50ms without problems - probably better. System uses higher delay (200ms, or 1 second) - and this could be increased and work with mobile accuracy of even +/- 1s. The problem might be with intercepting the audio stream on a non-rooted Android device - but that might have got better since I've checked it. "HiFy" app for example (not really popular) is supposed to connect spotify (not sure why explicitly that) to AirPlay. There's a "AirAudio" app - but requires root. If accepting "root" requirement - this is certainly doable. If not - it needs some checks. It would still be usable for me with required root. It's certainly doable as a music "player" but I'm not sure you'd want to write own player; that would rather be counterproductive, it has to be simple and integrate with the environment. I considered porting this to "termux" and staying with Python too, but there's problem with interception and audio at all. Android could talk directly to receivers (be a wavesync server) or talk to the server (which currently talks to Pulseaudio using Unix socket - this could be changed easily) - and let the server chunk the audio. Android as a player / receiverThe receivers need to have the time synchronised much more accurately. In local environment you could probably force NTP packets leaving on port 123 to reach your server instead. Still I believe most mobiles are synchronized to within 1-5ms and this should suffice in most natural conditions. No problems with intercepting audio though - not sure if no problems with output buffer control. Android controlI considered adding REST interface to wavesync server and doing a simple app to control volume in different rooms. My volume knob in kitchen is quite unreachable. I manage with SSH, my wife not really. |
When receiving, the working root solution, could be to use AirAudio, do a DLNA server on pulseaudio and push audio to wavesync... When streaming TO the android: Receivers currently receive the server time automatically every 1-second in status frame - in local network this MIGHT be just enough (pings will be usually <1ms anyway). Adding a time-ping feature is not a big problem probably, but maybe not necessary. Server currently doesn't receive data from receivers. |
Thanks for the big write-up, really appreciated :) Also, sorry for not being super clear about it but yeah, I was thinking *Android as a player / receiver". The app could also include a simple control interface, that shouldn't be to big of a deal especially if you provide a nice REST interface. As you aren't to concerned about NTP and seem to not have any other immediate concerns for a receiver I guess this will be a upcoming project of mine unless someone else wants to work on it. As such I can't promise to have something to show off anytime soon. |
No prob at all. Glad you found it somehow useful. I won't be able to pickup a Android project by myself but can offer any help necessary. Weird solutions include also https://github.com/termux/play-audio and https://steemit.com/utopian-io/@rufans/how-to-play-mp3-files-from-command-line-with-termux |
I like this project for its simplicity/minimalism and think a android client would be kinda neat.
Even though I don't really want to get back into android development, this could be something I might actually tackle.
Before doing so I thought I'd ask if there are any major concerns from your side.
I do know python quite well and think that re-implementing the client logic in java/kotlin shouldn't be to hard (I say that without having read the code yet).
The only immediate concern I have is the whole NTP thing.
On android there's no "easy" way of changing the NTP server in use.
Apparently it can be done through adb but that's not really user-friendly.
Do you think it would be possible to extend wavesync in such a manner that clients´:
I've never worked on anything which requires perfect synchronization so I'm not sure if there's a fatal flaw in my logic.
The text was updated successfully, but these errors were encountered: