mirror of
https://github.com/owntone/owntone-server.git
synced 2025-01-24 13:13:17 -05:00
Add support for max volume for AirPlay devices (raop)
This commit is contained in:
parent
258163e6ce
commit
23a7e82a1f
@ -95,7 +95,7 @@ library {
|
||||
|
||||
# Local audio output
|
||||
audio {
|
||||
# AirTunes name - used in the speaker list in Remote
|
||||
# Name - used in the speaker list in Remote
|
||||
nickname = "Computer"
|
||||
# Audio device name for local audio output
|
||||
# card = "default"
|
||||
@ -104,8 +104,11 @@ audio {
|
||||
# mixer = ""
|
||||
}
|
||||
|
||||
# Airport Express device
|
||||
#apex "ApEx" {
|
||||
# AirTunes password
|
||||
# AirPlay/Airport Express device settings
|
||||
#airplay "My AirPlay speaker" {
|
||||
# forked-daapd's volume goes to 11! If that's more than you can handle
|
||||
# you can set a lower value here
|
||||
# max_volume = 11
|
||||
# AirPlay password
|
||||
# password = "s1kr3t"
|
||||
#}
|
||||
|
@ -92,9 +92,10 @@ static cfg_opt_t sec_audio[] =
|
||||
CFG_END()
|
||||
};
|
||||
|
||||
/* ApEx device section structure */
|
||||
static cfg_opt_t sec_apex[] =
|
||||
/* AirPlay/ApEx device section structure */
|
||||
static cfg_opt_t sec_airplay[] =
|
||||
{
|
||||
CFG_INT("max_volume", 11, CFGF_NONE),
|
||||
CFG_STR("password", NULL, CFGF_NONE),
|
||||
CFG_END()
|
||||
};
|
||||
@ -105,7 +106,7 @@ static cfg_opt_t toplvl_cfg[] =
|
||||
CFG_SEC("general", sec_general, CFGF_NONE),
|
||||
CFG_SEC("library", sec_library, CFGF_NONE),
|
||||
CFG_SEC("audio", sec_audio, CFGF_NONE),
|
||||
CFG_SEC("apex", sec_apex, CFGF_MULTI | CFGF_TITLE),
|
||||
CFG_SEC("airplay", sec_airplay, CFGF_MULTI | CFGF_TITLE),
|
||||
CFG_END()
|
||||
};
|
||||
|
||||
|
@ -3798,7 +3798,7 @@ static void
|
||||
raop_device_cb(const char *name, const char *type, const char *domain, const char *hostname, int family, const char *address, int port, struct keyval *txt)
|
||||
{
|
||||
struct raop_device *rd;
|
||||
cfg_t *apex;
|
||||
cfg_t *airplay;
|
||||
const char *p;
|
||||
char *at_name;
|
||||
char *password;
|
||||
@ -3904,9 +3904,9 @@ raop_device_cb(const char *name, const char *type, const char *domain, const cha
|
||||
{
|
||||
DPRINTF(E_LOG, L_PLAYER, "AirPlay device %s is password-protected\n", name);
|
||||
|
||||
apex = cfg_gettsec(cfg, "apex", at_name);
|
||||
if (apex)
|
||||
password = cfg_getstr(apex, "password");
|
||||
airplay = cfg_gettsec(cfg, "airplay", at_name);
|
||||
if (airplay)
|
||||
password = cfg_getstr(airplay, "password");
|
||||
|
||||
if (!password)
|
||||
DPRINTF(E_LOG, L_PLAYER, "No password given in config for AirPlay device %s\n", name);
|
||||
|
26
src/raop.c
26
src/raop.c
@ -85,6 +85,9 @@
|
||||
#define RAOP_MD_DELAY_STARTUP 15360
|
||||
#define RAOP_MD_DELAY_SWITCH (RAOP_MD_DELAY_STARTUP * 2)
|
||||
|
||||
/* This is an arbitrary value which just needs to be kept in sync with the config */
|
||||
#define RAOP_CONFIG_MAX_VOLUME 11
|
||||
|
||||
struct raop_v2_packet
|
||||
{
|
||||
uint8_t clear[AIRTUNES_V2_PKT_LEN];
|
||||
@ -2231,9 +2234,26 @@ raop_metadata_send(int id, uint64_t rtptime, uint64_t offset, int startup)
|
||||
|
||||
/* Volume handling */
|
||||
static float
|
||||
raop_volume_convert(int volume)
|
||||
raop_volume_convert(int volume, char *name)
|
||||
{
|
||||
float raop_volume;
|
||||
cfg_t *airplay;
|
||||
int max_volume;
|
||||
|
||||
max_volume = RAOP_CONFIG_MAX_VOLUME;
|
||||
|
||||
airplay = cfg_gettsec(cfg, "airplay", name);
|
||||
if (airplay)
|
||||
max_volume = cfg_getint(airplay, "max_volume");
|
||||
|
||||
if ((max_volume < 1) || (max_volume > RAOP_CONFIG_MAX_VOLUME))
|
||||
{
|
||||
DPRINTF(E_LOG, L_RAOP, "Config has bad max_volume (%d) for device %s, using default instead\n", max_volume, name);
|
||||
|
||||
max_volume = RAOP_CONFIG_MAX_VOLUME;
|
||||
}
|
||||
|
||||
DPRINTF(E_DBG, L_RAOP, "Setting max_volume for device %s to %d\n", name, max_volume);
|
||||
|
||||
/* RAOP volume
|
||||
* -144.0 is off
|
||||
@ -2242,7 +2262,7 @@ raop_volume_convert(int volume)
|
||||
if (volume == 0)
|
||||
raop_volume = -144.0;
|
||||
else
|
||||
raop_volume = -30.0 + ((float)volume * 30.0) / 100.0;
|
||||
raop_volume = -30.0 + ((float)max_volume * (float)volume * 30.0) / (100.0 * RAOP_CONFIG_MAX_VOLUME);
|
||||
|
||||
return raop_volume;
|
||||
}
|
||||
@ -2262,7 +2282,7 @@ raop_set_volume_internal(struct raop_session *rs, int volume, evrtsp_req_cb cb)
|
||||
return -1;
|
||||
}
|
||||
|
||||
raop_volume = raop_volume_convert(volume);
|
||||
raop_volume = raop_volume_convert(volume, rs->devname);
|
||||
|
||||
/* Don't let locales get in the way here */
|
||||
ret = evbuffer_add_printf(evbuf, "volume: %d.%06d\r\n", (int)raop_volume, -(int)(1000000.0 * (raop_volume - (int)raop_volume)));
|
||||
|
Loading…
x
Reference in New Issue
Block a user