mirror of
https://github.com/owntone/owntone-server.git
synced 2025-01-14 16:25:03 -05:00
Maintain per-speaker volume information
This commit is contained in:
parent
6f7b12b1f2
commit
9bd6d459a2
31
src/player.c
31
src/player.c
@ -182,6 +182,7 @@ static struct raop_device *dev_list;
|
|||||||
/* Device status */
|
/* Device status */
|
||||||
static enum laudio_state laudio_status;
|
static enum laudio_state laudio_status;
|
||||||
static int laudio_selected;
|
static int laudio_selected;
|
||||||
|
static int laudio_volume;
|
||||||
static int raop_sessions;
|
static int raop_sessions;
|
||||||
|
|
||||||
/* Commands */
|
/* Commands */
|
||||||
@ -1208,7 +1209,7 @@ device_remove(struct raop_device *dev)
|
|||||||
speaker_deselect_raop(dev);
|
speaker_deselect_raop(dev);
|
||||||
|
|
||||||
/* Save device volume */
|
/* Save device volume */
|
||||||
ret = db_speaker_save(dev->id, 0, master_volume);
|
ret = db_speaker_save(dev->id, 0, dev->volume);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
DPRINTF(E_LOG, L_PLAYER, "Could not save state for speaker %s\n", dev->name);
|
DPRINTF(E_LOG, L_PLAYER, "Could not save state for speaker %s\n", dev->name);
|
||||||
|
|
||||||
@ -1260,6 +1261,9 @@ device_add(struct player_command *cmd)
|
|||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
selected = 0;
|
selected = 0;
|
||||||
|
|
||||||
|
/* Force master volume for now */
|
||||||
|
rd->volume = master_volume;
|
||||||
|
|
||||||
if (dev_autoselect && selected)
|
if (dev_autoselect && selected)
|
||||||
speaker_select_raop(rd);
|
speaker_select_raop(rd);
|
||||||
|
|
||||||
@ -1791,7 +1795,7 @@ playback_start_bh(struct player_command *cmd)
|
|||||||
/* Start laudio first as it can fail, but can be stopped easily if needed */
|
/* Start laudio first as it can fail, but can be stopped easily if needed */
|
||||||
if (laudio_status == LAUDIO_OPEN)
|
if (laudio_status == LAUDIO_OPEN)
|
||||||
{
|
{
|
||||||
laudio_set_volume(master_volume);
|
laudio_set_volume(laudio_volume);
|
||||||
|
|
||||||
ret = laudio_start(pb_pos, last_rtptime + AIRTUNES_V2_PACKET_SAMPLES);
|
ret = laudio_start(pb_pos, last_rtptime + AIRTUNES_V2_PACKET_SAMPLES);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
@ -2271,7 +2275,7 @@ speaker_activate(struct raop_device *rd)
|
|||||||
|
|
||||||
if (player_state == PLAY_PLAYING)
|
if (player_state == PLAY_PLAYING)
|
||||||
{
|
{
|
||||||
laudio_set_volume(master_volume);
|
laudio_set_volume(laudio_volume);
|
||||||
|
|
||||||
ret = player_get_current_pos(&pos, &ts, 0);
|
ret = player_get_current_pos(&pos, &ts, 0);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
@ -2505,10 +2509,19 @@ speaker_set(struct player_command *cmd)
|
|||||||
static int
|
static int
|
||||||
volume_set(struct player_command *cmd)
|
volume_set(struct player_command *cmd)
|
||||||
{
|
{
|
||||||
|
struct raop_device *rd;
|
||||||
|
|
||||||
master_volume = cmd->arg.intval;
|
master_volume = cmd->arg.intval;
|
||||||
|
|
||||||
|
laudio_volume = master_volume;
|
||||||
|
|
||||||
cmd->raop_pending = raop_set_volume(master_volume, device_command_cb);
|
cmd->raop_pending = raop_set_volume(master_volume, device_command_cb);
|
||||||
laudio_set_volume(master_volume);
|
laudio_set_volume(laudio_volume);
|
||||||
|
|
||||||
|
for (rd = dev_list; rd; rd = rd->next)
|
||||||
|
{
|
||||||
|
rd->volume = master_volume;
|
||||||
|
}
|
||||||
|
|
||||||
if (cmd->raop_pending > 0)
|
if (cmd->raop_pending > 0)
|
||||||
return 1; /* async */
|
return 1; /* async */
|
||||||
@ -3338,13 +3351,13 @@ player(void *arg)
|
|||||||
/* Save selected devices */
|
/* Save selected devices */
|
||||||
db_speaker_clear_all();
|
db_speaker_clear_all();
|
||||||
|
|
||||||
ret = db_speaker_save(0, laudio_selected, master_volume);
|
ret = db_speaker_save(0, laudio_selected, laudio_volume);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
DPRINTF(E_LOG, L_PLAYER, "Could not save state for local audio\n");
|
DPRINTF(E_LOG, L_PLAYER, "Could not save state for local audio\n");
|
||||||
|
|
||||||
for (rd = dev_list; rd; rd = rd->next)
|
for (rd = dev_list; rd; rd = rd->next)
|
||||||
{
|
{
|
||||||
ret = db_speaker_save(rd->id, rd->selected, master_volume);
|
ret = db_speaker_save(rd->id, rd->selected, rd->volume);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
DPRINTF(E_LOG, L_PLAYER, "Could not save state for speaker %s\n", rd->name);
|
DPRINTF(E_LOG, L_PLAYER, "Could not save state for speaker %s\n", rd->name);
|
||||||
}
|
}
|
||||||
@ -3401,12 +3414,14 @@ player_init(void)
|
|||||||
|
|
||||||
rng_init(&shuffle_rng);
|
rng_init(&shuffle_rng);
|
||||||
|
|
||||||
ret = db_speaker_get(0, &laudio_selected, &master_volume);
|
ret = db_speaker_get(0, &laudio_selected, &laudio_volume);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
master_volume = 75;
|
laudio_volume = 75;
|
||||||
else if (laudio_selected)
|
else if (laudio_selected)
|
||||||
speaker_select_laudio(); /* Run the select helper */
|
speaker_select_laudio(); /* Run the select helper */
|
||||||
|
|
||||||
|
master_volume = laudio_volume;
|
||||||
|
|
||||||
audio_buf = evbuffer_new();
|
audio_buf = evbuffer_new();
|
||||||
if (!audio_buf)
|
if (!audio_buf)
|
||||||
{
|
{
|
||||||
|
@ -42,6 +42,7 @@ struct raop_device
|
|||||||
unsigned has_password:1;
|
unsigned has_password:1;
|
||||||
const char *password;
|
const char *password;
|
||||||
|
|
||||||
|
int volume;
|
||||||
struct raop_session *session;
|
struct raop_session *session;
|
||||||
|
|
||||||
struct raop_device *next;
|
struct raop_device *next;
|
||||||
|
Loading…
Reference in New Issue
Block a user