Skip to content
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

Modify audio output device system/master volume on Windows #2005

Open
zebranine opened this issue Mar 11, 2024 · 5 comments
Open

Modify audio output device system/master volume on Windows #2005

zebranine opened this issue Mar 11, 2024 · 5 comments
Labels
feature waiting Waiting for more information from reporter windows

Comments

@zebranine
Copy link

Feature request

First post here so congratulations and thanks for this awesome offering.

It seems that volume commands from MPD clients (MALP, MPDCtrl) influence only the MPD output volume and not the output device's system/master volume level on the Windows host machine. If there is a way to do this I have not found it.

Since we are using the MPD server machine as an HTPC, the device volume may be left at an arbitrarily low level by the last user and this then caps the output from MPD. Only a manual adjustment of the device volume via the usual Windows controls resolves the issue.

I have various workarounds but direct setting of the Windows device volume by MPD would be ideal.

Thanks for your time.

@MaxKellermann
Copy link
Member

I don't understand what you are doing, partly because you did not say anything about your setup, and partly because I have never used Windows, and I don't know what "system/master volume" is.

@MaxKellermann MaxKellermann added feature waiting Waiting for more information from reporter labels Mar 11, 2024
@zebranine
Copy link
Author

I have a Windows 11 PC hosting MPD as a service, various clients (Windows, Android).

Client volume changes seem to modify only the MPD application volume, rather than the host audio device volume at the operating system level.

This means that if the Windows audio device used by MPD is set at 25% volume (in the Windows mixer), MPD can only reach maximum 25% of potential system volume even when it is set internally to 100% volume.

The OS mixer volume overrides the MPD application volume. This could be overcome if MPD set the Windows mixer level for the audio device directly.

Screenshot of client displaying MPD vol vs OS audio device vol:

3

@zebranine
Copy link
Author

zebranine commented Mar 14, 2024

Found a partial solution.

MPD will control Windows Mixer master volume if mpd.conf audio_output settings specify the following:

type "wasapi"
exclusive "yes"

This, however, means no other programs can use the audio device, so not ideal.

@bigboipete
Copy link

bigboipete commented Nov 11, 2024

If I get your description right, the observed behavior makes totally sense to me:

If you transfer it to the analogue world, see it as a chain of two volume knobs. First is the player and second (aka closest to the audio output) is the Windows mixer. If you set the second/last volume in the chain down to 25% you can crank the first volume as much as you want, you are always limited by the second volume.

From an audio-chain perspective this is reasonable, because a "volume knob" should modify volume for the respective device/player it "belongs" to and not touch any master volume. It's up to the user to bring these two volumes in a balance to preserve headroom for the player's (aka first) "volume knob".

But in software you can certainly wire any setup, that's desired.

@zebranine
Copy link
Author

I certainly don't say the behaviour is wrong but rather that this is a use case specific scenario where more than one configuration is desirable.

In our case the device is used for multiple purposes but only ever one at a time so it makes sense for individual applications to operate at 'full' volume and simplify the control of volume (via various remotes) to alter only the master volume.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feature waiting Waiting for more information from reporter windows
Projects
None yet
Development

No branches or pull requests

3 participants