mirror of
https://github.com/ppy/osu.git
synced 2025-01-19 01:03:53 +08:00
d3380631e8
This commit allows loading, storing, and displaying a preferred audio device from config even when it is unavailable.
66 lines
2.1 KiB
C#
66 lines
2.1 KiB
C#
// Copyright (c) 2007-2017 ppy Pty Ltd <contact@ppy.sh>.
|
|
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
|
|
using osu.Framework.Allocation;
|
|
using osu.Framework.Audio;
|
|
using osu.Framework.Graphics;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
|
|
namespace osu.Game.Overlays.Options.Sections.Audio
|
|
{
|
|
public class AudioDevicesOptions : OptionsSubsection
|
|
{
|
|
protected override string Header => "Devices";
|
|
|
|
private AudioManager audio;
|
|
private OptionDropDown<string> dropdown;
|
|
|
|
[BackgroundDependencyLoader]
|
|
private void load(AudioManager audio)
|
|
{
|
|
this.audio = audio;
|
|
}
|
|
|
|
protected override void Dispose(bool isDisposing)
|
|
{
|
|
base.Dispose(isDisposing);
|
|
|
|
audio.OnNewDevice -= onDeviceChanged;
|
|
audio.OnLostDevice -= onDeviceChanged;
|
|
}
|
|
|
|
private void updateItems()
|
|
{
|
|
var deviceItems = new List<KeyValuePair<string, string>>();
|
|
deviceItems.Add(new KeyValuePair<string, string>("Default", string.Empty));
|
|
deviceItems.AddRange(audio.AudioDeviceNames.Select(d => new KeyValuePair<string, string>(d, d)));
|
|
|
|
var preferredDeviceName = audio.AudioDevice.Value;
|
|
if (!deviceItems.Any(kv => kv.Value == preferredDeviceName))
|
|
deviceItems.Add(new KeyValuePair<string, string>(preferredDeviceName, preferredDeviceName));
|
|
|
|
dropdown.Items = deviceItems;
|
|
}
|
|
|
|
private void onDeviceChanged(string name) => updateItems();
|
|
|
|
protected override void LoadComplete()
|
|
{
|
|
base.LoadComplete();
|
|
|
|
Children = new Drawable[]
|
|
{
|
|
dropdown = new OptionDropDown<string>()
|
|
{
|
|
Bindable = audio.AudioDevice
|
|
},
|
|
};
|
|
|
|
updateItems();
|
|
|
|
audio.OnNewDevice += onDeviceChanged;
|
|
audio.OnLostDevice += onDeviceChanged;
|
|
}
|
|
}
|
|
} |