owntone-server/docs/control-clients/mobile.md

142 lines
5.7 KiB
Markdown

# Mobile Remote Control
To control OwnTone from your mobile device, you can use:
- [The web interface](#the-web-interface)
- [(iOS) The Remote app from Apple](#apple-remote-app-ios)
- [(Android) An iTunes/Apple Music remote app](#remotes-for-itunesapple-music-android)
- [A MPD client app](#mpd-client-apps)
The web interface is the most feature complete, but apps may have UX advantages.
The table below shows how some features compare.
| Feature | Remote | MPD client | Web |
| ------------------------------------- | ---------- | ---------- | ---------- |
| Browse library | yes | yes | yes |
| Control playback and queue | yes | yes | yes |
| Artwork | yes | yes | yes |
| Individual speaker selection | yes | some | yes |
| Individual speaker volume | yes | no | yes |
| Volume control using phone buttons | no | ? | no |
| Listen on phone | no | some | yes |
| Access non-library Spotify tracks | no | no | yes |
| Edit and save m3u playlists | no | some | yes |
While OwnTone supports playing tracks from Spotify, there is no support for
Spotify Connect, so you can't control from the Spotify app.
## The web interface
See [web interface](web.md).
## Apple Remote app (iOS)
Remote gets a list of output devices from the server; this list includes any
and all devices on the network we know of that advertise AirPlay: AirPort
Express, Apple TV, … It also includes the local audio output, that is, the
sound card on the server (even if there is no sound card).
OwnTone remembers your selection and the individual volume for each
output device; selected devices will be automatically re-selected, except if
they return online during playback.
### Pairing
1. Open the [web interface](web.md) at either [http://owntone.local:3689](http://owntone.local:3689)
or `http://SERVER-IP-ADDRESS:3689`
2. Start Remote, go to Settings, Add Library
3. Enter the pair code in the web interface (reload the browser page if
it does not automatically pick up the pairing request)
If Remote does not connect to OwnTone after you entered the pairing code
something went wrong. Check the log file to see the error message. Here are
some common reasons:
- You did not enter the correct pairing code
You will see an error in the log about pairing failure with a HTTP response code
that is *not* 0.
Solution: Try again.
- No response from Remote, possibly a network issue
If you see an error in the log with either:
- a HTTP response code that is 0
- "Empty pairing request callback"
it means that OwnTone could not establish a connection to Remote. This
might be a network issue, your router may not be allowing multicast between the
Remote device and the host OwnTone is running on.
Solution 1: Sometimes it resolves the issue if you force Remote to quit, restart
it and do the pairing process again. Another trick is to establish some other
connection (eg SSH) from the iPod/iPhone/iPad to the host.
Solution 2: Check your router settings if you can whitelist multicast addresses
under IGMP settings. For Apple Bonjour, setting a multicast address of
224.0.0.251 and a netmask of 255.255.255.255 should work.
- Otherwise try using `avahi-browse` for troubleshooting:
- in a terminal, run:
```shell
avahi-browse -r -k _touch-remote._tcp
```
- start Remote, goto Settings, Add Library
- after a couple seconds at most, you should get something similar to this:
```shell
+ ath0 IPv4 59eff13ea2f98dbbef6c162f9df71b784a3ef9a3 _touch-remote._tcp local
= ath0 IPv4 59eff13ea2f98dbbef6c162f9df71b784a3ef9a3 _touch-remote._tcp local
hostname = [Foobar.local]
address = [192.168.1.1]
port = [49160]
txt = ["DvTy=iPod touch" "RemN=Remote" "txtvers=1" "RemV=10000" "Pair=FAEA410630AEC05E" "DvNm=Foobar"]
```
Hit Ctrl+C to terminate `avahi-browse`.
- To check for network issues you can try to connect to the server address and
port with [`nc`](https://en.wikipedia.org/wiki/Netcat) or
[`telnet`](https://en.wikipedia.org/wiki/Telnet) commands.
## Remotes for iTunes/Apple Music (Android)
The below Android remote apps work with OwnTone.
| Client | Developer | Type | Working (vers.) |
| ------------------------ | ----------- | ------ | --------------- |
| Retune | SquallyDoc | Remote | Yes (3.5.23) |
| TunesRemote+ | Melloware | Remote | Yes (2.5.3) |
| Remote for iTunes | Hyperfine | Remote | Yes |
For usage and troubleshooting details, see the instructions for [Apple Remote](#apple-remote-app-ios).
## MPD client apps
There's a range of MPD clients available from app store that also work with
OwnTone e.g. MPD Pilot, MaximumMPD, Rigelian and Stylophone.
The better ones support local playback, speaker control, artwork and automatic
discovery of OwnTone's MPD server.
By default OwnTone listens on port 6600 for MPD clients. You can change
this in the configuration file.
Due to some differences between OwnTone and MPD not all commands will act the
same way they would running MPD:
- crossfade, mixrampdb, mixrampdelay and replaygain will have no effect
- single, repeat: unlike MPD, OwnTone does not support setting single and repeat
separately on/off, instead repeat off, repeat all and repeat single are
supported. Thus setting single on will result in repeat single, repeat on
results in repeat all.