aboutsummaryrefslogtreecommitdiffstats
path: root/src/volume.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/volume.c')
-rw-r--r--src/volume.c16
1 files changed, 11 insertions, 5 deletions
diff --git a/src/volume.c b/src/volume.c
index 7906acbba..d38a2c2c8 100644
--- a/src/volume.c
+++ b/src/volume.c
@@ -248,6 +248,8 @@ int getAlsaVolumeLevel() {
long min = volume_alsaMin;
int err;
+ snd_mixer_handle_events(volume_alsaMixerHandle);
+
if((err = snd_mixer_selem_get_playback_volume(volume_alsaElem,
SND_MIXER_SCHN_FRONT_LEFT,&level))<0) {
ERROR("problems getting alsa volume: %s\n",snd_strerror(err));
@@ -255,8 +257,12 @@ int getAlsaVolumeLevel() {
}
snd_mixer_selem_get_playback_volume(volume_alsaElem,
- SND_MIXER_SCHN_FRONT_LEFT,&level);
- ret = (int)(100*(((float)(level-min))/(max-min))+0.5);
+ SND_MIXER_SCHN_FRONT_LEFT,&level);
+ ret = ((volume_alsaSet/100.0)*(max-min)+min)+0.5;
+ if(volume_alsaSet>0 && ret==level) {
+ ret = volume_alsaSet;
+ }
+ else ret = (int)(100*(((float)(level-min))/(max-min))+0.5);
return ret;
}
@@ -269,6 +275,8 @@ int changeAlsaVolumeLevel(FILE * fp, int change, int rel) {
long min = volume_alsaMin;
int err;
+ snd_mixer_handle_events(volume_alsaMixerHandle);
+
if((err = snd_mixer_selem_get_playback_volume(volume_alsaElem,
SND_MIXER_SCHN_FRONT_LEFT,&level))<0) {
myfprintf(fp,"%s problems getting volume\n",
@@ -282,9 +290,7 @@ int changeAlsaVolumeLevel(FILE * fp, int change, int rel) {
if(volume_alsaSet >= 0 && level==test) {
vol = volume_alsaSet;
}
- else {
- vol = 100.0*(((float)(level-min))/(max-min));
- }
+ else vol = 100.0*(((float)(level-min))/(max-min));
vol+=change;
}
else