From d9603f72f305843bb0fafd17a41bcdcd7239ad9d Mon Sep 17 00:00:00 2001 From: Susko3 Date: Mon, 11 Nov 2024 16:53:59 +0000 Subject: [PATCH 1/2] Use SDL3 text editing events on windows `StartTextInput()` and `ResetIme()` are kept as they improve and can co-exist with SDL3 logic. --- .../Platform/Windows/SDL3WindowsWindow.cs | 111 ------------------ 1 file changed, 111 deletions(-) diff --git a/osu.Framework/Platform/Windows/SDL3WindowsWindow.cs b/osu.Framework/Platform/Windows/SDL3WindowsWindow.cs index 7c065b98f2..d04ea28ba1 100644 --- a/osu.Framework/Platform/Windows/SDL3WindowsWindow.cs +++ b/osu.Framework/Platform/Windows/SDL3WindowsWindow.cs @@ -2,12 +2,9 @@ // See the LICENCE file in the repository root for full licence text. using System; -using System.Diagnostics; using System.Drawing; -using System.Runtime.CompilerServices; using System.Runtime.InteropServices; using System.Runtime.Versioning; -using osu.Framework.Allocation; using osu.Framework.Input.Handlers.Mouse; using osu.Framework.Platform.SDL3; using osu.Framework.Platform.Windows.Native; @@ -62,36 +59,6 @@ public override void Create() Native.Input.SetWindowFeedbackSetting(WindowHandle, feedbackType, false); } - public override unsafe void Run() - { - SDL_SetWindowsMessageHook(&messageHook, ObjectHandle.Handle); - base.Run(); - } - - [UnmanagedCallersOnly(CallConvs = new[] { typeof(CallConvCdecl) })] - private static unsafe SDLBool messageHook(IntPtr userdata, MSG* msg) - { - var handle = new ObjectHandle(userdata); - if (handle.GetTarget(out SDL3WindowsWindow window)) - return window.handleEventFromHook(*msg); - - return true; - } - - private SDLBool handleEventFromHook(MSG msg) - { - switch (msg.message) - { - case Imm.WM_IME_STARTCOMPOSITION: - case Imm.WM_IME_COMPOSITION: - case Imm.WM_IME_ENDCOMPOSITION: - handleImeMessage(msg.hwnd, msg.message, msg.lParam); - break; - } - - return true; - } - protected override void HandleEventFromFilter(SDL_Event evt) { switch (evt.Type) @@ -125,8 +92,6 @@ private void warpCursorFromFocusLoss() } } - #region IME handling - public override void StartTextInput(bool allowIme) { base.StartTextInput(allowIme); @@ -135,82 +100,6 @@ public override void StartTextInput(bool allowIme) public override void ResetIme() => ScheduleCommand(() => Imm.CancelComposition(WindowHandle)); - protected override void HandleTextInputEvent(SDL_TextInputEvent evtText) - { - string? sdlResult = evtText.GetText(); - Debug.Assert(sdlResult != null); - - // Block SDL text input if it was already handled by `handleImeMessage()`. - // SDL truncates text over 32 bytes and sends it as multiple events. - // We assume these events will be handled in the same `pollSDLEvents()` call. - if (lastImeResult?.Contains(sdlResult) == true) - { - // clear the result after this SDL event loop finishes so normal text input isn't blocked. - EventScheduler.AddOnce(() => lastImeResult = null); - return; - } - - // also block if there is an ongoing composition (unlikely to occur). - if (imeCompositionActive) return; - - base.HandleTextInputEvent(evtText); - } - - protected override void HandleTextEditingEvent(SDL_TextEditingEvent evtEdit) - { - // handled by custom logic below - } - - /// - /// Whether IME composition is active. - /// - /// Used for blocking SDL IME results since we handle those ourselves. - private bool imeCompositionActive; - - /// - /// The last IME result. - /// - /// - /// Used for blocking SDL IME results since we handle those ourselves. - /// Cleared when the SDL events are blocked. - /// - private string? lastImeResult; - - private void handleImeMessage(IntPtr hWnd, uint uMsg, long lParam) - { - switch (uMsg) - { - case Imm.WM_IME_STARTCOMPOSITION: - imeCompositionActive = true; - ScheduleEvent(() => TriggerTextEditing(string.Empty, 0, 0)); - break; - - case Imm.WM_IME_COMPOSITION: - using (var inputContext = new Imm.InputContext(hWnd, lParam)) - { - if (inputContext.TryGetImeResult(out string? resultText)) - { - lastImeResult = resultText; - ScheduleEvent(() => TriggerTextInput(resultText)); - } - - if (inputContext.TryGetImeComposition(out string? compositionText, out int start, out int length)) - { - ScheduleEvent(() => TriggerTextEditing(compositionText, start, length)); - } - } - - break; - - case Imm.WM_IME_ENDCOMPOSITION: - imeCompositionActive = false; - ScheduleEvent(() => TriggerTextEditing(string.Empty, 0, 0)); - break; - } - } - - #endregion - protected override void HandleTouchFingerEvent(SDL_TouchFingerEvent evtTfinger) { if (evtTfinger.TryGetTouchName(out string? name) && name == "pen") From 15c612fe868c72aa8ef31bdd97b01d918ecae733 Mon Sep 17 00:00:00 2001 From: Susko3 Date: Mon, 11 Nov 2024 16:54:05 +0000 Subject: [PATCH 2/2] Remove unnecessary virtual & protected modifiers --- osu.Framework/Platform/SDL3/SDL3Window.cs | 4 ++-- osu.Framework/Platform/SDL3/SDL3Window_Input.cs | 12 ++++-------- 2 files changed, 6 insertions(+), 10 deletions(-) diff --git a/osu.Framework/Platform/SDL3/SDL3Window.cs b/osu.Framework/Platform/SDL3/SDL3Window.cs index 5944581b10..77c0f4fc3f 100644 --- a/osu.Framework/Platform/SDL3/SDL3Window.cs +++ b/osu.Framework/Platform/SDL3/SDL3Window.cs @@ -501,11 +501,11 @@ protected virtual void HandleEvent(SDL_Event e) break; case SDL_EventType.SDL_EVENT_TEXT_EDITING: - HandleTextEditingEvent(e.edit); + handleTextEditingEvent(e.edit); break; case SDL_EventType.SDL_EVENT_TEXT_INPUT: - HandleTextInputEvent(e.text); + handleTextInputEvent(e.text); break; case SDL_EventType.SDL_EVENT_KEYMAP_CHANGED: diff --git a/osu.Framework/Platform/SDL3/SDL3Window_Input.cs b/osu.Framework/Platform/SDL3/SDL3Window_Input.cs index 5c340f8e37..7709f531eb 100644 --- a/osu.Framework/Platform/SDL3/SDL3Window_Input.cs +++ b/osu.Framework/Platform/SDL3/SDL3Window_Input.cs @@ -472,18 +472,18 @@ private void handleMouseMotionEvent(SDL_MouseMotionEvent evtMotion) MouseMoveRelative?.Invoke(new Vector2(evtMotion.xrel * Scale, evtMotion.yrel * Scale)); } - protected virtual void HandleTextInputEvent(SDL_TextInputEvent evtText) + private void handleTextInputEvent(SDL_TextInputEvent evtText) { string? text = evtText.GetText(); Debug.Assert(text != null); - TriggerTextInput(text); + TextInput?.Invoke(text); } - protected virtual void HandleTextEditingEvent(SDL_TextEditingEvent evtEdit) + private void handleTextEditingEvent(SDL_TextEditingEvent evtEdit) { string? text = evtEdit.GetText(); Debug.Assert(text != null); - TriggerTextEditing(text, evtEdit.start, evtEdit.length); + TextEditing?.Invoke(text, evtEdit.start, evtEdit.length); } private void handleKeyboardEvent(SDL_KeyboardEvent evtKey) @@ -713,15 +713,11 @@ private void updateConfineMode() /// public event Action? TextInput; - protected void TriggerTextInput(string text) => TextInput?.Invoke(text); - /// /// Invoked when an IME text editing event occurs. /// public event TextEditingDelegate? TextEditing; - protected void TriggerTextEditing(string text, int start, int length) => TextEditing?.Invoke(text, start, length); - /// public event Action? KeymapChanged;