| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150 |
- using Avalonia.Controls;
- using Avalonia.Controls.Primitives;
- using Avalonia.Input;
- using Avalonia.Interactivity;
- using Avalonia.LogicalTree;
- using Ryujinx.Ava.Input;
- using Ryujinx.Ava.UI.Helpers;
- using Ryujinx.Ava.UI.ViewModels;
- using Ryujinx.Input;
- using Ryujinx.Input.Assigner;
- using Key = Ryujinx.Common.Configuration.Hid.Key;
- namespace Ryujinx.Ava.UI.Views.Settings
- {
- public partial class SettingsHotkeysView : UserControl
- {
- private ButtonKeyAssigner _currentAssigner;
- private readonly IGamepadDriver _avaloniaKeyboardDriver;
- public SettingsHotkeysView()
- {
- InitializeComponent();
- foreach (ILogical visual in SettingButtons.GetLogicalDescendants())
- {
- if (visual is ToggleButton button and not CheckBox)
- {
- button.IsCheckedChanged += Button_IsCheckedChanged;
- }
- }
- _avaloniaKeyboardDriver = new AvaloniaKeyboardDriver(this);
- }
- protected override void OnPointerReleased(PointerReleasedEventArgs e)
- {
- base.OnPointerReleased(e);
- if (!_currentAssigner?.ToggledButton?.IsPointerOver ?? false)
- {
- _currentAssigner.Cancel();
- }
- }
- private void MouseClick(object sender, PointerPressedEventArgs e)
- {
- bool shouldUnbind = e.GetCurrentPoint(this).Properties.IsMiddleButtonPressed;
- _currentAssigner?.Cancel(shouldUnbind);
- PointerPressed -= MouseClick;
- }
- private void Button_IsCheckedChanged(object sender, RoutedEventArgs e)
- {
- if (sender is ToggleButton button)
- {
- if ((bool)button.IsChecked)
- {
- if (_currentAssigner != null && button == _currentAssigner.ToggledButton)
- {
- return;
- }
- if (_currentAssigner == null)
- {
- _currentAssigner = new ButtonKeyAssigner(button);
- this.Focus(NavigationMethod.Pointer);
- PointerPressed += MouseClick;
- var keyboard = (IKeyboard)_avaloniaKeyboardDriver.GetGamepad("0");
- IButtonAssigner assigner = new KeyboardKeyAssigner(keyboard);
- _currentAssigner.ButtonAssigned += (sender, e) =>
- {
- if (e.ButtonValue.HasValue)
- {
- var viewModel = (DataContext) as SettingsViewModel;
- var buttonValue = e.ButtonValue.Value;
- switch (button.Name)
- {
- case "ToggleVSyncMode":
- viewModel.KeyboardHotkey.ToggleVSyncMode = buttonValue.AsHidType<Key>();
- break;
- case "Screenshot":
- viewModel.KeyboardHotkey.Screenshot = buttonValue.AsHidType<Key>();
- break;
- case "ShowUI":
- viewModel.KeyboardHotkey.ShowUI = buttonValue.AsHidType<Key>();
- break;
- case "Pause":
- viewModel.KeyboardHotkey.Pause = buttonValue.AsHidType<Key>();
- break;
- case "ToggleMute":
- viewModel.KeyboardHotkey.ToggleMute = buttonValue.AsHidType<Key>();
- break;
- case "ResScaleUp":
- viewModel.KeyboardHotkey.ResScaleUp = buttonValue.AsHidType<Key>();
- break;
- case "ResScaleDown":
- viewModel.KeyboardHotkey.ResScaleDown = buttonValue.AsHidType<Key>();
- break;
- case "VolumeUp":
- viewModel.KeyboardHotkey.VolumeUp = buttonValue.AsHidType<Key>();
- break;
- case "VolumeDown":
- viewModel.KeyboardHotkey.VolumeDown = buttonValue.AsHidType<Key>();
- break;
- case "CustomVSyncIntervalIncrement":
- viewModel.KeyboardHotkey.CustomVSyncIntervalIncrement = buttonValue.AsHidType<Key>();
- break;
- case "CustomVSyncIntervalDecrement":
- viewModel.KeyboardHotkey.CustomVSyncIntervalDecrement = buttonValue.AsHidType<Key>();
- break;
- }
- }
- };
- _currentAssigner.GetInputAndAssign(assigner, keyboard);
- }
- else
- {
- if (_currentAssigner != null)
- {
- _currentAssigner.Cancel();
- _currentAssigner = null;
- button.IsChecked = false;
- }
- }
- }
- else
- {
- _currentAssigner?.Cancel();
- _currentAssigner = null;
- }
- }
- }
- public void Dispose()
- {
- _currentAssigner?.Cancel();
- _currentAssigner = null;
- _avaloniaKeyboardDriver.Dispose();
- }
- }
- }
|