deb99d2cae
* avalonia part 1 * remove vulkan ui backend * move ui common files to ui common project * get name for oading screen from device * rebase. * review 1 * review 1.1 * review * cleanup * addressed review * use cancellation token * review * review * rebased * cancel library loading when closing window * remove star image, use fonticon instead * delete render control frame buffer when game ends. change position of fav star * addressed @Thog review * ensure the right ui is downloaded in updates * fix crash when showing not supported dialog during controller request * add prefix to artifact names * Auto-format Avalonia project * Fix input * Fix build, simplify app disposal * remove nv stutter thread * addressed review * add missing change * maintain window size if new size is zero length * add game, handheld, docked to local * reverse scale main window * Update de_DE.json * Update de_DE.json * Update de_DE.json * Update italian json * Update it_IT.json * let render timer poll with no wait * remove unused code * more unused code * enabled tiered compilation and trimming * check if window event is not closed before signaling * fix atmospher case * locale fix * locale fix * remove explicit tiered compilation declarations * Remove ) it_IT.json * Remove ) de_DE.json * Update it_IT.json * Update pt_BR locale with latest strings * Remove ')' * add more strings to locale * update locale * remove extra slash * remove extra slash * set firmware version to 0 if key's not found * fix * revert timer changes * lock on object instead * Update it_IT.json * remove unused method * add load screen text to locale * drop swap event * Update de_DE.json * Update de_DE.json * do null check when stopping emulator * Update de_DE.json * Create tr_TR.json * Add tr_TR * Add tr_TR + Turkish * Update it_IT.json * Update Ryujinx.Ava/Input/AvaloniaMappingHelper.cs Co-authored-by: Ac_K <Acoustik666@gmail.com> * Apply suggestions from code review Co-authored-by: Ac_K <Acoustik666@gmail.com> * Apply suggestions from code review Co-authored-by: Ac_K <Acoustik666@gmail.com> * addressed review * Update Ryujinx.Ava/Ui/Backend/OpenGl/OpenGlRenderTarget.cs Co-authored-by: gdkchan <gab.dark.100@gmail.com> * use avalonia's inbuilt renderer on linux * removed whitespace * workaround for queue render crash with vsync off * drop custom backend * format files * fix not closing issue * remove warnings * rebase * update avalonia library * Reposition the Text and Button on About Page * Assign build version * Remove appveyor text Co-authored-by: gdk <gab.dark.100@gmail.com> Co-authored-by: Niwu34 <67392333+Niwu34@users.noreply.github.com> Co-authored-by: Antonio Brugnolo <36473846+AntoSkate@users.noreply.github.com> Co-authored-by: aegiff <99728970+aegiff@users.noreply.github.com> Co-authored-by: Ac_K <Acoustik666@gmail.com> Co-authored-by: MostlyWhat <78652091+MostlyWhat@users.noreply.github.com>
108 lines
3.7 KiB
C#
108 lines
3.7 KiB
C#
using Gtk;
|
|
using Ryujinx.HLE.Ui;
|
|
using Ryujinx.Input.GTK3;
|
|
using Ryujinx.Ui.Widgets;
|
|
using System.Threading;
|
|
|
|
namespace Ryujinx.Ui.Applet
|
|
{
|
|
/// <summary>
|
|
/// Class that forwards key events to a GTK Entry so they can be processed into text.
|
|
/// </summary>
|
|
internal class GtkDynamicTextInputHandler : IDynamicTextInputHandler
|
|
{
|
|
private readonly Window _parent;
|
|
private readonly OffscreenWindow _inputToTextWindow = new OffscreenWindow();
|
|
private readonly RawInputToTextEntry _inputToTextEntry = new RawInputToTextEntry();
|
|
|
|
private bool _canProcessInput;
|
|
|
|
public event DynamicTextChangedHandler TextChangedEvent;
|
|
public event KeyPressedHandler KeyPressedEvent;
|
|
public event KeyReleasedHandler KeyReleasedEvent;
|
|
|
|
public bool TextProcessingEnabled
|
|
{
|
|
get
|
|
{
|
|
return Volatile.Read(ref _canProcessInput);
|
|
}
|
|
|
|
set
|
|
{
|
|
Volatile.Write(ref _canProcessInput, value);
|
|
}
|
|
}
|
|
|
|
public GtkDynamicTextInputHandler(Window parent)
|
|
{
|
|
_parent = parent;
|
|
_parent.KeyPressEvent += HandleKeyPressEvent;
|
|
_parent.KeyReleaseEvent += HandleKeyReleaseEvent;
|
|
|
|
_inputToTextWindow.Add(_inputToTextEntry);
|
|
|
|
_inputToTextEntry.TruncateMultiline = true;
|
|
|
|
// Start with input processing turned off so the text box won't accumulate text
|
|
// if the user is playing on the keyboard.
|
|
_canProcessInput = false;
|
|
}
|
|
|
|
[GLib.ConnectBefore()]
|
|
private void HandleKeyPressEvent(object o, KeyPressEventArgs args)
|
|
{
|
|
var key = (Ryujinx.Common.Configuration.Hid.Key)GTK3MappingHelper.ToInputKey(args.Event.Key);
|
|
|
|
if (!(KeyPressedEvent?.Invoke(key)).GetValueOrDefault(true))
|
|
{
|
|
return;
|
|
}
|
|
|
|
if (_canProcessInput)
|
|
{
|
|
_inputToTextEntry.SendKeyPressEvent(o, args);
|
|
_inputToTextEntry.GetSelectionBounds(out int selectionStart, out int selectionEnd);
|
|
TextChangedEvent?.Invoke(_inputToTextEntry.Text, selectionStart, selectionEnd, _inputToTextEntry.OverwriteMode);
|
|
}
|
|
}
|
|
|
|
[GLib.ConnectBefore()]
|
|
private void HandleKeyReleaseEvent(object o, KeyReleaseEventArgs args)
|
|
{
|
|
var key = (Ryujinx.Common.Configuration.Hid.Key)GTK3MappingHelper.ToInputKey(args.Event.Key);
|
|
|
|
if (!(KeyReleasedEvent?.Invoke(key)).GetValueOrDefault(true))
|
|
{
|
|
return;
|
|
}
|
|
|
|
if (_canProcessInput)
|
|
{
|
|
// TODO (caian): This solution may have problems if the pause is sent after a key press
|
|
// and before a key release. But for now GTK Entry does not seem to use release events.
|
|
_inputToTextEntry.SendKeyReleaseEvent(o, args);
|
|
_inputToTextEntry.GetSelectionBounds(out int selectionStart, out int selectionEnd);
|
|
TextChangedEvent?.Invoke(_inputToTextEntry.Text, selectionStart, selectionEnd, _inputToTextEntry.OverwriteMode);
|
|
}
|
|
}
|
|
|
|
public void SetText(string text, int cursorBegin)
|
|
{
|
|
_inputToTextEntry.Text = text;
|
|
_inputToTextEntry.Position = cursorBegin;
|
|
}
|
|
|
|
public void SetText(string text, int cursorBegin, int cursorEnd)
|
|
{
|
|
_inputToTextEntry.Text = text;
|
|
_inputToTextEntry.SelectRegion(cursorBegin, cursorEnd);
|
|
}
|
|
|
|
public void Dispose()
|
|
{
|
|
_parent.KeyPressEvent -= HandleKeyPressEvent;
|
|
_parent.KeyReleaseEvent -= HandleKeyReleaseEvent;
|
|
}
|
|
}
|
|
} |