mirror of
https://github.com/kevinporetti/UnrealImGui.git
synced 2025-01-18 00:10:32 +00:00
Updated the way keys are handled to the new way ImGui now deals with input even though old input API works and is somewhat functional I'd rather be inline with latest standards. Also added all known keys to proxy for passing to ImGui for IsKeyDown/IsKeyPressed/IsKeyReleased routines. Code's a ugly and architecture not exactly perfect but works for the most part, will revisit when I get some time.
This commit is contained in:
parent
d0034be488
commit
e96a11abcf
@ -79,12 +79,16 @@ FReply UImGuiInputHandler::OnKeyDown(const FKeyEvent& KeyEvent)
|
|||||||
InputState->SetKeyDown(KeyEvent, true);
|
InputState->SetKeyDown(KeyEvent, true);
|
||||||
CopyModifierKeys(KeyEvent);
|
CopyModifierKeys(KeyEvent);
|
||||||
|
|
||||||
|
InputState->KeyDownEvents.Add(KeyEvent.GetKeyCode(), KeyEvent);
|
||||||
|
|
||||||
return ToReply(bConsume);
|
return ToReply(bConsume);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
FReply UImGuiInputHandler::OnKeyUp(const FKeyEvent& KeyEvent)
|
FReply UImGuiInputHandler::OnKeyUp(const FKeyEvent& KeyEvent)
|
||||||
{
|
{
|
||||||
|
InputState->KeyUpEvents.Add(KeyEvent.GetKeyCode(), KeyEvent);
|
||||||
|
|
||||||
if (KeyEvent.GetKey().IsGamepadKey())
|
if (KeyEvent.GetKey().IsGamepadKey())
|
||||||
{
|
{
|
||||||
bool bConsume = false;
|
bool bConsume = false;
|
||||||
|
@ -45,6 +45,9 @@ void FImGuiInputState::ClearUpdateState()
|
|||||||
{
|
{
|
||||||
ClearCharacters();
|
ClearCharacters();
|
||||||
|
|
||||||
|
KeyDownEvents.Reset();
|
||||||
|
KeyUpEvents.Reset();
|
||||||
|
|
||||||
KeysUpdateRange.SetEmpty();
|
KeysUpdateRange.SetEmpty();
|
||||||
MouseButtonsUpdateRange.SetEmpty();
|
MouseButtonsUpdateRange.SetEmpty();
|
||||||
|
|
||||||
|
@ -201,6 +201,9 @@ public:
|
|||||||
// and information about dirty parts of keys or mouse buttons arrays.
|
// and information about dirty parts of keys or mouse buttons arrays.
|
||||||
void ClearUpdateState();
|
void ClearUpdateState();
|
||||||
|
|
||||||
|
TMap<uint32, FKeyEvent> KeyDownEvents;
|
||||||
|
TMap<uint32, FKeyEvent> KeyUpEvents;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
void SetKeyDown(uint32 KeyIndex, bool bIsDown);
|
void SetKeyDown(uint32 KeyIndex, bool bIsDown);
|
||||||
|
@ -85,41 +85,108 @@ namespace ImGuiInterops
|
|||||||
// Input Mapping
|
// Input Mapping
|
||||||
//====================================================================================================
|
//====================================================================================================
|
||||||
|
|
||||||
|
static TMap<FKey, ImGuiKey> UnrealToImGuiKeyMap;
|
||||||
|
|
||||||
void SetUnrealKeyMap(ImGuiIO& IO)
|
void SetUnrealKeyMap(ImGuiIO& IO)
|
||||||
{
|
{
|
||||||
struct FUnrealToImGuiMapping
|
UnrealToImGuiKeyMap.Add(EKeys::Tab, ImGuiKey_Tab);
|
||||||
{
|
|
||||||
FUnrealToImGuiMapping()
|
UnrealToImGuiKeyMap.Add(EKeys::Left, ImGuiKey_LeftArrow);
|
||||||
{
|
UnrealToImGuiKeyMap.Add(EKeys::Right, ImGuiKey_RightArrow);
|
||||||
KeyMap[ImGuiKey_Tab] = GetKeyIndex(EKeys::Tab);
|
UnrealToImGuiKeyMap.Add(EKeys::Up, ImGuiKey_UpArrow);
|
||||||
KeyMap[ImGuiKey_LeftArrow] = GetKeyIndex(EKeys::Left);
|
UnrealToImGuiKeyMap.Add(EKeys::Down, ImGuiKey_DownArrow);
|
||||||
KeyMap[ImGuiKey_RightArrow] = GetKeyIndex(EKeys::Right);
|
|
||||||
KeyMap[ImGuiKey_UpArrow] = GetKeyIndex(EKeys::Up);
|
UnrealToImGuiKeyMap.Add(EKeys::PageUp, ImGuiKey_PageUp);
|
||||||
KeyMap[ImGuiKey_DownArrow] = GetKeyIndex(EKeys::Down);
|
UnrealToImGuiKeyMap.Add(EKeys::PageDown, ImGuiKey_PageDown);
|
||||||
KeyMap[ImGuiKey_PageUp] = GetKeyIndex(EKeys::PageUp);
|
UnrealToImGuiKeyMap.Add(EKeys::Home, ImGuiKey_Home);
|
||||||
KeyMap[ImGuiKey_PageDown] = GetKeyIndex(EKeys::PageDown);
|
UnrealToImGuiKeyMap.Add(EKeys::End, ImGuiKey_End);
|
||||||
KeyMap[ImGuiKey_Home] = GetKeyIndex(EKeys::Home);
|
UnrealToImGuiKeyMap.Add(EKeys::Insert, ImGuiKey_Insert);
|
||||||
KeyMap[ImGuiKey_End] = GetKeyIndex(EKeys::End);
|
UnrealToImGuiKeyMap.Add(EKeys::Delete, ImGuiKey_Delete);
|
||||||
KeyMap[ImGuiKey_Insert] = GetKeyIndex(EKeys::Insert);
|
|
||||||
KeyMap[ImGuiKey_Delete] = GetKeyIndex(EKeys::Delete);
|
|
||||||
KeyMap[ImGuiKey_Backspace] = GetKeyIndex(EKeys::BackSpace);
|
|
||||||
KeyMap[ImGuiKey_Space] = GetKeyIndex(EKeys::SpaceBar);
|
|
||||||
KeyMap[ImGuiKey_Enter] = GetKeyIndex(EKeys::Enter);
|
|
||||||
KeyMap[ImGuiKey_Escape] = GetKeyIndex(EKeys::Escape);
|
|
||||||
KeyMap[ImGuiKey_A] = GetKeyIndex(EKeys::A);
|
|
||||||
KeyMap[ImGuiKey_C] = GetKeyIndex(EKeys::C);
|
|
||||||
KeyMap[ImGuiKey_V] = GetKeyIndex(EKeys::V);
|
|
||||||
KeyMap[ImGuiKey_X] = GetKeyIndex(EKeys::X);
|
|
||||||
KeyMap[ImGuiKey_Y] = GetKeyIndex(EKeys::Y);
|
|
||||||
KeyMap[ImGuiKey_Z] = GetKeyIndex(EKeys::Z);
|
|
||||||
}
|
|
||||||
|
|
||||||
ImGuiTypes::FKeyMap KeyMap;
|
UnrealToImGuiKeyMap.Add(EKeys::NumLock, ImGuiKey_NumLock);
|
||||||
};
|
UnrealToImGuiKeyMap.Add(EKeys::ScrollLock, ImGuiKey_ScrollLock);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Pause, ImGuiKey_Pause);
|
||||||
|
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::BackSpace, ImGuiKey_Backspace);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::SpaceBar, ImGuiKey_Space);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Enter, ImGuiKey_Enter);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Escape, ImGuiKey_Escape);
|
||||||
|
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::A, ImGuiKey_A);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::B, ImGuiKey_B);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::C, ImGuiKey_C);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::D, ImGuiKey_D);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::E, ImGuiKey_E);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::F, ImGuiKey_F);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::G, ImGuiKey_G);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::H, ImGuiKey_H);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::I, ImGuiKey_I);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::J, ImGuiKey_J);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::K, ImGuiKey_K);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::L, ImGuiKey_L);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::M, ImGuiKey_M);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::N, ImGuiKey_N);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::O, ImGuiKey_O);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::P, ImGuiKey_P);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Q, ImGuiKey_Q);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::R, ImGuiKey_R);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::S, ImGuiKey_S);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::T, ImGuiKey_T);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::U, ImGuiKey_U);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::V, ImGuiKey_V);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::W, ImGuiKey_W);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::X, ImGuiKey_X);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Y, ImGuiKey_Y);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Z, ImGuiKey_Z);
|
||||||
|
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::F1, ImGuiKey_F1);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::F2, ImGuiKey_F2);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::F3, ImGuiKey_F3);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::F4, ImGuiKey_F4);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::F5, ImGuiKey_F5);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::F6, ImGuiKey_F6);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::F7, ImGuiKey_F7);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::F8, ImGuiKey_F8);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::F9, ImGuiKey_F9);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::F10, ImGuiKey_F10);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::F11, ImGuiKey_F11);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::F12, ImGuiKey_F12);
|
||||||
|
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::One, ImGuiKey_0);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Two, ImGuiKey_1);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Three, ImGuiKey_2);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Four, ImGuiKey_3);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Five, ImGuiKey_4);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Six, ImGuiKey_5);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Seven, ImGuiKey_6);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Eight, ImGuiKey_7);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Nine, ImGuiKey_8);
|
||||||
|
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Equals, ImGuiKey_Equal);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Comma, ImGuiKey_Comma);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Period, ImGuiKey_Period);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Slash, ImGuiKey_Slash);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::LeftBracket, ImGuiKey_LeftBracket);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::RightBracket, ImGuiKey_RightBracket);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Apostrophe, ImGuiKey_Apostrophe);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Semicolon, ImGuiKey_Semicolon);
|
||||||
|
|
||||||
static const FUnrealToImGuiMapping Mapping;
|
UnrealToImGuiKeyMap.Add(EKeys::NumPadZero, ImGuiKey_Keypad0);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::NumPadOne, ImGuiKey_Keypad1);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::NumPadTwo, ImGuiKey_Keypad2);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::NumPadThree, ImGuiKey_Keypad3);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::NumPadFour, ImGuiKey_Keypad4);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::NumPadFive, ImGuiKey_Keypad5);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::NumPadSix, ImGuiKey_Keypad6);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::NumPadSeven, ImGuiKey_Keypad7);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::NumPadEight, ImGuiKey_Keypad8);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::NumPadNine, ImGuiKey_Keypad9);
|
||||||
|
|
||||||
Copy(Mapping.KeyMap, IO.KeyMap);
|
UnrealToImGuiKeyMap.Add(EKeys::Multiply, ImGuiKey_KeypadMultiply);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Add, ImGuiKey_KeypadAdd);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Subtract, ImGuiKey_KeypadSubtract);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Decimal, ImGuiKey_KeypadDecimal);
|
||||||
|
UnrealToImGuiKeyMap.Add(EKeys::Divide, ImGuiKey_KeypadDivide);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Simple transform mapping key codes to 0-511 range used in ImGui.
|
// Simple transform mapping key codes to 0-511 range used in ImGui.
|
||||||
@ -302,7 +369,23 @@ namespace ImGuiInterops
|
|||||||
// Copy buffers.
|
// Copy buffers.
|
||||||
if (!InputState.GetKeysUpdateRange().IsEmpty())
|
if (!InputState.GetKeysUpdateRange().IsEmpty())
|
||||||
{
|
{
|
||||||
Copy(InputState.GetKeys(), IO.KeysDown, InputState.GetKeysUpdateRange());
|
// Key down events
|
||||||
|
for(const auto& Pair : InputState.KeyDownEvents)
|
||||||
|
{
|
||||||
|
if(UnrealToImGuiKeyMap.Contains(Pair.Value.GetKey()))
|
||||||
|
{
|
||||||
|
IO.AddKeyEvent(UnrealToImGuiKeyMap[Pair.Value.GetKey()], true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Key up events
|
||||||
|
for(const auto& Pair : InputState.KeyUpEvents)
|
||||||
|
{
|
||||||
|
if(UnrealToImGuiKeyMap.Contains(Pair.Value.GetKey()))
|
||||||
|
{
|
||||||
|
IO.AddKeyEvent(UnrealToImGuiKeyMap[Pair.Value.GetKey()], false);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!InputState.GetMouseButtonsUpdateRange().IsEmpty())
|
if (!InputState.GetMouseButtonsUpdateRange().IsEmpty())
|
||||||
|
Loading…
Reference in New Issue
Block a user