2017-04-22 15:38:04 +00:00
|
|
|
// Distributed under the MIT License (MIT) (see accompanying LICENSE file)
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "ImGuiInteroperability.h"
|
|
|
|
#include "Utilities/Arrays.h"
|
|
|
|
|
2020-02-03 20:11:04 +00:00
|
|
|
#include <Containers/Array.h>
|
|
|
|
|
2017-04-22 15:38:04 +00:00
|
|
|
|
|
|
|
// Collects and stores input state and updates for ImGui IO.
|
|
|
|
class FImGuiInputState
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
// Characters buffer.
|
2020-02-03 20:11:04 +00:00
|
|
|
using FCharactersBuffer = TArray<TCHAR, TInlineAllocator<8>>;
|
2017-04-22 15:38:04 +00:00
|
|
|
|
|
|
|
// Array for mouse button states.
|
|
|
|
using FMouseButtonsArray = ImGuiInterops::ImGuiTypes::FMouseButtonsArray;
|
|
|
|
|
|
|
|
// Array for key states.
|
|
|
|
using FKeysArray = ImGuiInterops::ImGuiTypes::FKeysArray;
|
|
|
|
|
|
|
|
// Pair of indices defining range in mouse buttons array.
|
|
|
|
using FMouseButtonsIndexRange = Utilities::TArrayIndexRange<FMouseButtonsArray, uint32>;
|
|
|
|
|
|
|
|
// Pair of indices defining range in keys array.
|
|
|
|
using FKeysIndexRange = Utilities::TArrayIndexRange<FKeysArray, uint32>;
|
|
|
|
|
|
|
|
// Create empty state with whole range instance with the whole update state marked as dirty.
|
|
|
|
FImGuiInputState();
|
|
|
|
|
|
|
|
// Get reference to input characters buffer.
|
|
|
|
const FCharactersBuffer& GetCharacters() const { return InputCharacters; }
|
|
|
|
|
|
|
|
// Add a character to the characters buffer. We can store and send to ImGui up to 16 characters per frame. Any
|
|
|
|
// character beyond that limit will be discarded.
|
|
|
|
// @param Char - Character to add
|
|
|
|
void AddCharacter(TCHAR Char);
|
|
|
|
|
|
|
|
// Get reference to the array with key down states.
|
|
|
|
const FKeysArray& GetKeys() const { return KeysDown; }
|
|
|
|
|
|
|
|
// Get possibly empty range of indices bounding dirty part of the keys array.
|
|
|
|
const FKeysIndexRange& GetKeysUpdateRange() const { return KeysUpdateRange; }
|
|
|
|
|
|
|
|
// Change state of the key in the keys array and expand range bounding dirty part of the array.
|
2018-05-17 22:25:47 +00:00
|
|
|
// @param KeyEvent - Key event representing the key
|
2017-04-22 15:38:04 +00:00
|
|
|
// @param bIsDown - True, if key is down
|
2018-05-17 22:25:47 +00:00
|
|
|
void SetKeyDown(const FKeyEvent& KeyEvent, bool bIsDown) { SetKeyDown(ImGuiInterops::GetKeyIndex(KeyEvent), bIsDown); }
|
|
|
|
|
|
|
|
// Change state of the key in the keys array and expand range bounding dirty part of the array.
|
|
|
|
// @param Key - Keyboard key
|
|
|
|
// @param bIsDown - True, if key is down
|
|
|
|
void SetKeyDown(const FKey& Key, bool bIsDown) { SetKeyDown(ImGuiInterops::GetKeyIndex(Key), bIsDown); }
|
2017-04-22 15:38:04 +00:00
|
|
|
|
|
|
|
// Get reference to the array with mouse button down states.
|
|
|
|
const FMouseButtonsArray& GetMouseButtons() const { return MouseButtonsDown; }
|
|
|
|
|
|
|
|
// Get possibly empty range of indices bounding dirty part of the mouse buttons array.
|
|
|
|
const FMouseButtonsIndexRange& GetMouseButtonsUpdateRange() const { return MouseButtonsUpdateRange; }
|
|
|
|
|
|
|
|
// Change state of the button in the mouse buttons array and expand range bounding dirty part of the array.
|
2018-05-17 22:25:47 +00:00
|
|
|
// @param MouseEvent - Mouse event representing mouse button
|
2017-04-22 15:38:04 +00:00
|
|
|
// @param bIsDown - True, if button is down
|
2018-05-17 22:25:47 +00:00
|
|
|
void SetMouseDown(const FPointerEvent& MouseEvent, bool bIsDown) { SetMouseDown(ImGuiInterops::GetMouseIndex(MouseEvent), bIsDown); }
|
|
|
|
|
|
|
|
// Change state of the button in the mouse buttons array and expand range bounding dirty part of the array.
|
|
|
|
// @param MouseButton - Mouse button key
|
|
|
|
// @param bIsDown - True, if button is down
|
|
|
|
void SetMouseDown(const FKey& MouseButton, bool bIsDown) { SetMouseDown(ImGuiInterops::GetMouseIndex(MouseButton), bIsDown); }
|
2017-04-22 15:38:04 +00:00
|
|
|
|
|
|
|
// Get mouse wheel delta accumulated during the last frame.
|
|
|
|
float GetMouseWheelDelta() const { return MouseWheelDelta; }
|
|
|
|
|
|
|
|
// Add mouse wheel delta.
|
|
|
|
// @param DeltaValue - Mouse wheel delta to add
|
|
|
|
void AddMouseWheelDelta(float DeltaValue) { MouseWheelDelta += DeltaValue; }
|
|
|
|
|
2019-08-01 20:41:12 +00:00
|
|
|
// Get the mouse position.
|
2017-04-22 15:38:04 +00:00
|
|
|
const FVector2D& GetMousePosition() const { return MousePosition; }
|
|
|
|
|
2019-08-01 20:41:12 +00:00
|
|
|
// Set the mouse position.
|
|
|
|
// @param Position - Mouse position
|
2017-04-22 15:38:04 +00:00
|
|
|
void SetMousePosition(const FVector2D& Position) { MousePosition = Position; }
|
|
|
|
|
2017-09-21 21:09:03 +00:00
|
|
|
// Check whether input has active mouse pointer.
|
|
|
|
bool HasMousePointer() const { return bHasMousePointer; }
|
|
|
|
|
|
|
|
// Set whether input has active mouse pointer.
|
|
|
|
// @param bHasPointer - True, if input has active mouse pointer
|
2018-05-17 22:25:47 +00:00
|
|
|
void SetMousePointer(bool bInHasMousePointer) { bHasMousePointer = bInHasMousePointer; }
|
2017-09-21 21:09:03 +00:00
|
|
|
|
2019-08-01 20:41:12 +00:00
|
|
|
// Check whether touch input is in progress. True, after touch is started until one frame after it has ended.
|
|
|
|
// One frame delay is used to process mouse release in ImGui since touch-down is simulated with mouse-down.
|
|
|
|
bool IsTouchActive() const { return bTouchDown || bTouchProcessed; }
|
|
|
|
|
|
|
|
// Check whether touch input is down.
|
|
|
|
bool IsTouchDown() const { return bTouchDown; }
|
|
|
|
|
|
|
|
// Set whether touch input is down.
|
|
|
|
// @param bIsDown - True, if touch is down (or started) and false, if touch is up (or ended)
|
|
|
|
void SetTouchDown(bool bIsDown) { bTouchDown = bIsDown; }
|
|
|
|
|
|
|
|
// Get the touch position.
|
|
|
|
const FVector2D& GetTouchPosition() const { return TouchPosition; }
|
|
|
|
|
|
|
|
// Set the touch position.
|
|
|
|
// @param Position - Touch position
|
|
|
|
void SetTouchPosition(const FVector2D& Position) { TouchPosition = Position; }
|
|
|
|
|
2017-08-19 20:19:38 +00:00
|
|
|
// Get Control down state.
|
|
|
|
bool IsControlDown() const { return bIsControlDown; }
|
|
|
|
|
|
|
|
// Set Control down state.
|
|
|
|
// @param bIsDown - True, if Control is down
|
|
|
|
void SetControlDown(bool bIsDown) { bIsControlDown = bIsDown; }
|
|
|
|
|
|
|
|
// Get Shift down state.
|
|
|
|
bool IsShiftDown() const { return bIsShiftDown; }
|
|
|
|
|
|
|
|
// Set Shift down state.
|
|
|
|
// @param bIsDown - True, if Shift is down
|
|
|
|
void SetShiftDown(bool bIsDown) { bIsShiftDown = bIsDown; }
|
|
|
|
|
|
|
|
// Get Alt down state.
|
|
|
|
bool IsAltDown() const { return bIsAltDown; }
|
|
|
|
|
|
|
|
// Set Alt down state.
|
|
|
|
// @param bIsDown - True, if Alt is down
|
|
|
|
void SetAltDown(bool bIsDown) { bIsAltDown = bIsDown; }
|
|
|
|
|
2024-11-23 22:43:08 +00:00
|
|
|
// TODO: Update gamepad navigation to use new ImGuiKey API
|
|
|
|
/*
|
2018-05-17 22:25:47 +00:00
|
|
|
// Change state of the navigation input associated with this gamepad key.
|
|
|
|
// @param KeyEvent - Key event with gamepad key input
|
|
|
|
// @param bIsDown - True, if key is down
|
|
|
|
void SetGamepadNavigationKey(const FKeyEvent& KeyEvent, bool bIsDown) { ImGuiInterops::SetGamepadNavigationKey(NavigationInputs, KeyEvent.GetKey(), bIsDown); }
|
2017-04-22 15:38:04 +00:00
|
|
|
|
2018-05-17 22:25:47 +00:00
|
|
|
// Change state of the navigation input associated with this gamepad axis.
|
|
|
|
// @param AnalogInputEvent - Analogue input event with gamepad axis input
|
|
|
|
// @param Value - Analogue value that should be set for this axis
|
|
|
|
void SetGamepadNavigationAxis(const FAnalogInputEvent& AnalogInputEvent, float Value) { ImGuiInterops::SetGamepadNavigationAxis(NavigationInputs, AnalogInputEvent.GetKey(), Value); }
|
2024-11-23 22:43:08 +00:00
|
|
|
*/
|
2017-04-22 15:38:04 +00:00
|
|
|
|
2018-05-10 11:15:14 +00:00
|
|
|
// Check whether keyboard navigation is enabled.
|
2018-05-17 22:25:47 +00:00
|
|
|
bool IsKeyboardNavigationEnabled() const { return bKeyboardNavigationEnabled; }
|
2018-05-10 11:15:14 +00:00
|
|
|
|
|
|
|
// Set whether keyboard navigation is enabled.
|
|
|
|
// @param bEnabled - True, if navigation is enabled
|
|
|
|
void SetKeyboardNavigationEnabled(bool bEnabled) { bKeyboardNavigationEnabled = bEnabled; }
|
|
|
|
|
2018-05-17 22:25:47 +00:00
|
|
|
// Check whether gamepad navigation is enabled.
|
|
|
|
bool IsGamepadNavigationEnabled() const { return bGamepadNavigationEnabled; }
|
|
|
|
|
|
|
|
// Set whether gamepad navigation is enabled.
|
|
|
|
// @param bEnabled - True, if navigation is enabled
|
|
|
|
void SetGamepadNavigationEnabled(bool bEnabled) { bGamepadNavigationEnabled = bEnabled; }
|
|
|
|
|
|
|
|
// Check whether gamepad is attached.
|
|
|
|
bool HasGamepad() const { return bHasGamepad; }
|
|
|
|
|
|
|
|
// Set whether gamepad is attached.
|
|
|
|
// @param bInHasGamepad - True, if gamepad is attached
|
|
|
|
void SetGamepad(bool bInHasGamepad) { bHasGamepad = bInHasGamepad; }
|
|
|
|
|
2019-06-23 19:29:25 +00:00
|
|
|
// Reset the whole input state and mark it as dirty.
|
|
|
|
void Reset()
|
|
|
|
{
|
|
|
|
ResetKeyboard();
|
|
|
|
ResetMouse();
|
2024-11-23 22:43:08 +00:00
|
|
|
// TODO: Update gamepad navigation to use new ImGuiKey API
|
|
|
|
//ResetGamepadNavigation();
|
2019-06-23 19:29:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Reset the keyboard input state and mark it as dirty.
|
|
|
|
void ResetKeyboard()
|
|
|
|
{
|
|
|
|
ClearCharacters();
|
|
|
|
ClearKeys();
|
|
|
|
ClearModifierKeys();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Reset the mouse input state and mark it as dirty.
|
|
|
|
void ResetMouse()
|
|
|
|
{
|
|
|
|
ClearMouseButtons();
|
|
|
|
ClearMouseAnalogue();
|
|
|
|
}
|
|
|
|
|
2024-11-23 22:43:08 +00:00
|
|
|
// TODO: Update gamepad navigation to use new ImGuiKey API
|
|
|
|
/*
|
2019-06-23 19:29:25 +00:00
|
|
|
// Reset the gamepad navigation state.
|
|
|
|
void ResetGamepadNavigation()
|
|
|
|
{
|
|
|
|
ClearNavigationInputs();
|
|
|
|
}
|
2024-11-23 22:43:08 +00:00
|
|
|
*/
|
2018-05-17 22:25:47 +00:00
|
|
|
|
|
|
|
// Clear part of the state that is meant to be updated in every frame like: accumulators, buffers, navigation data
|
|
|
|
// and information about dirty parts of keys or mouse buttons arrays.
|
|
|
|
void ClearUpdateState();
|
|
|
|
|
2022-02-25 21:40:13 +00:00
|
|
|
TMap<uint32, FKeyEvent> KeyDownEvents;
|
|
|
|
TMap<uint32, FKeyEvent> KeyUpEvents;
|
2024-11-23 22:43:08 +00:00
|
|
|
TMap<uint32, FPointerEvent> MouseButtonDownEvents;
|
|
|
|
TMap<uint32, FPointerEvent> MouseButtonUpEvents;
|
2022-02-25 21:40:13 +00:00
|
|
|
|
2017-04-22 15:38:04 +00:00
|
|
|
private:
|
|
|
|
|
2024-11-23 22:43:08 +00:00
|
|
|
void SetKeyDown(ImGuiKey KeyIndex, bool bIsDown);
|
2018-05-17 22:25:47 +00:00
|
|
|
void SetMouseDown(uint32 MouseIndex, bool IsDown);
|
|
|
|
|
2017-04-22 15:38:04 +00:00
|
|
|
void ClearCharacters();
|
2017-08-19 20:19:38 +00:00
|
|
|
void ClearKeys();
|
|
|
|
void ClearMouseButtons();
|
|
|
|
void ClearMouseAnalogue();
|
|
|
|
void ClearModifierKeys();
|
2017-04-22 15:38:04 +00:00
|
|
|
|
|
|
|
FVector2D MousePosition = FVector2D::ZeroVector;
|
2019-08-01 20:41:12 +00:00
|
|
|
FVector2D TouchPosition = FVector2D::ZeroVector;
|
2017-04-22 15:38:04 +00:00
|
|
|
float MouseWheelDelta = 0.f;
|
|
|
|
|
|
|
|
FMouseButtonsArray MouseButtonsDown;
|
|
|
|
FMouseButtonsIndexRange MouseButtonsUpdateRange;
|
|
|
|
|
|
|
|
FCharactersBuffer InputCharacters;
|
|
|
|
|
|
|
|
FKeysArray KeysDown;
|
|
|
|
FKeysIndexRange KeysUpdateRange;
|
2024-11-23 22:43:08 +00:00
|
|
|
|
2017-09-21 21:09:03 +00:00
|
|
|
bool bHasMousePointer = false;
|
2019-08-01 20:41:12 +00:00
|
|
|
bool bTouchDown = false;
|
|
|
|
bool bTouchProcessed = false;
|
2017-09-21 21:09:03 +00:00
|
|
|
|
2017-08-19 20:19:38 +00:00
|
|
|
bool bIsControlDown = false;
|
|
|
|
bool bIsShiftDown = false;
|
|
|
|
bool bIsAltDown = false;
|
2018-05-10 11:15:14 +00:00
|
|
|
|
|
|
|
bool bKeyboardNavigationEnabled = false;
|
2018-05-17 22:25:47 +00:00
|
|
|
bool bGamepadNavigationEnabled = false;
|
|
|
|
bool bHasGamepad = false;
|
2017-04-22 15:38:04 +00:00
|
|
|
};
|