sys: Improve shortcut api

This commit is contained in:
WerWolv 2021-04-16 19:43:54 +02:00
parent 59dd372ec8
commit 771bb22962
8 changed files with 54 additions and 44 deletions

View File

@ -24,7 +24,7 @@ namespace hex {
bool isAvailable() override { return true; } bool isAvailable() override { return true; }
bool shouldProcess() override { return true; } bool shouldProcess() override { return true; }
bool handleShortcut(int key, int mods) override; bool handleShortcut(bool keys[512], bool ctrl, bool shift, bool alt) override;
bool hasViewMenuItemEntry() override { return false; } bool hasViewMenuItemEntry() override { return false; }
ImVec2 getMinSize() override { return ImVec2(400, 100); } ImVec2 getMinSize() override { return ImVec2(400, 100); }

View File

@ -27,7 +27,7 @@ namespace hex {
void drawContent() override; void drawContent() override;
void drawAlwaysVisible() override; void drawAlwaysVisible() override;
void drawMenu() override; void drawMenu() override;
bool handleShortcut(int key, int mods) override; bool handleShortcut(bool keys[512], bool ctrl, bool shift, bool alt) override;
private: private:
MemoryEditor m_memoryEditor; MemoryEditor m_memoryEditor;

View File

@ -52,6 +52,8 @@ namespace hex {
double m_lastFrameTime; double m_lastFrameTime;
bool m_prevKeysDown[512];
static inline std::tuple<int, int> s_currShortcut = { -1, -1 }; static inline std::tuple<int, int> s_currShortcut = { -1, -1 };
}; };

View File

@ -26,7 +26,7 @@ namespace hex {
virtual void drawContent() = 0; virtual void drawContent() = 0;
virtual void drawAlwaysVisible() { } virtual void drawAlwaysVisible() { }
virtual void drawMenu(); virtual void drawMenu();
virtual bool handleShortcut(int key, int mods); virtual bool handleShortcut(bool keys[512], bool ctrl, bool shift, bool alt);
virtual bool isAvailable(); virtual bool isAvailable();
virtual bool shouldProcess() { return this->isAvailable() && this->getWindowOpenState(); } virtual bool shouldProcess() { return this->isAvailable() && this->getWindowOpenState(); }

View File

@ -14,7 +14,7 @@ namespace hex {
View::View(std::string unlocalizedName) : m_unlocalizedViewName(unlocalizedName) { } View::View(std::string unlocalizedName) : m_unlocalizedViewName(unlocalizedName) { }
void View::drawMenu() { } void View::drawMenu() { }
bool View::handleShortcut(int key, int mods) { return false; } bool View::handleShortcut(bool keys[512], bool ctrl, bool shift, bool alt) { return false; }
bool View::isAvailable() { bool View::isAvailable() {
return SharedData::currentProvider != nullptr && SharedData::currentProvider->isAvailable(); return SharedData::currentProvider != nullptr && SharedData::currentProvider->isAvailable();

View File

@ -67,8 +67,8 @@ namespace hex {
} }
bool ViewCommandPalette::handleShortcut(int key, int mods) { bool ViewCommandPalette::handleShortcut(bool keys[512], bool ctrl, bool shift, bool alt) {
if (key == 'P' && mods == (GLFW_MOD_SHIFT | GLFW_MOD_CONTROL)) { if (ctrl && shift && keys['P']) {
View::doLater([this] { View::doLater([this] {
ImGui::OpenPopup("hex.view.command_palette.name"_lang); ImGui::OpenPopup("hex.view.command_palette.name"_lang);
this->m_commandPaletteOpen = true; this->m_commandPaletteOpen = true;

View File

@ -533,38 +533,49 @@ namespace hex {
} }
} }
bool ViewHexEditor::handleShortcut(int key, int mods) { bool ViewHexEditor::handleShortcut(bool keys[512], bool ctrl, bool shift, bool alt) {
if (mods == GLFW_MOD_CONTROL && key == 'S') { if (ctrl && keys['S']) {
save(); save();
return true; return true;
} else if (mods == (GLFW_MOD_CONTROL | GLFW_MOD_SHIFT) && key == 'S') { } else if (ctrl && shift && keys['S']) {
saveAs(); saveAs();
return true; return true;
} else if (mods == GLFW_MOD_CONTROL && key == 'Z') { }
if (ImGui::Begin(View::toWindowName("hex.view.hexeditor.name").c_str())) {
ON_SCOPE_EXIT { ImGui::End(); };
if (ImGui::IsWindowFocused(ImGuiFocusedFlags_ChildWindows)) {
if (ctrl && keys['Z']) {
if (SharedData::currentProvider != nullptr) if (SharedData::currentProvider != nullptr)
SharedData::currentProvider->undo(); SharedData::currentProvider->undo();
} else if (mods == GLFW_MOD_CONTROL && key == 'Y') { return true;
} else if (ctrl && keys['Y']) {
if (SharedData::currentProvider != nullptr) if (SharedData::currentProvider != nullptr)
SharedData::currentProvider->redo(); SharedData::currentProvider->redo();
} else if (mods == GLFW_MOD_CONTROL && key == 'F') { } else if (ctrl && keys['F']) {
View::doLater([]{ ImGui::OpenPopup("hex.view.hexeditor.menu.file.search"_lang); }); View::doLater([]{ ImGui::OpenPopup("hex.view.hexeditor.menu.file.search"_lang); });
return true; return true;
} else if (mods == GLFW_MOD_CONTROL && key == 'G') { } else if (ctrl && keys['G']) {
View::doLater([]{ ImGui::OpenPopup("hex.view.hexeditor.menu.file.goto"_lang); }); View::doLater([]{ ImGui::OpenPopup("hex.view.hexeditor.menu.file.goto"_lang); });
return true; return true;
} else if (mods == GLFW_MOD_CONTROL && key == 'O') { } else if (ctrl && keys['O']) {
View::doLater([]{ ImGui::OpenPopup("hex.view.hexeditor.open_file"_lang); }); View::doLater([]{ ImGui::OpenPopup("hex.view.hexeditor.open_file"_lang); });
return true; return true;
} else if (mods == GLFW_MOD_CONTROL && key == 'C') { } else if (ctrl && keys['C']) {
this->copyBytes(); this->copyBytes();
return true; return true;
} else if (mods == (GLFW_MOD_CONTROL | GLFW_MOD_SHIFT) && key == 'C') { } else if (ctrl && shift && keys['C']) {
this->copyString(); this->copyString();
return true; return true;
} else if (mods == GLFW_MOD_CONTROL && key == 'V') { } else if (ctrl && keys['V']) {
this->pasteBytes(); this->pasteBytes();
return true; return true;
} }
}
}
return false; return false;
} }

View File

@ -181,10 +181,17 @@ namespace hex {
} }
void Window::loop() { void Window::loop() {
bool pressedKeys[512] = { 0 };
this->m_lastFrameTime = glfwGetTime(); this->m_lastFrameTime = glfwGetTime();
while (!glfwWindowShouldClose(this->m_window)) { while (!glfwWindowShouldClose(this->m_window)) {
std::copy_n(ImGui::GetIO().KeysDown, 512, this->m_prevKeysDown);
this->frameBegin(); this->frameBegin();
for (u16 i = 0; i < 512; i++)
pressedKeys[i] = ImGui::GetIO().KeysDown[i] && !this->m_prevKeysDown[i];
for (const auto &call : View::getDeferedCalls()) for (const auto &call : View::getDeferedCalls())
call(); call();
View::getDeferedCalls().clear(); View::getDeferedCalls().clear();
@ -201,6 +208,7 @@ namespace hex {
ImGui::SetNextWindowSizeConstraints(minSize, view->getMaxSize()); ImGui::SetNextWindowSizeConstraints(minSize, view->getMaxSize());
view->drawContent(); view->drawContent();
view->handleShortcut(pressedKeys, ImGui::GetIO().KeyCtrl, ImGui::GetIO().KeyShift, ImGui::GetIO().KeyAlt);
} }
View::drawCommonInterfaces(); View::drawCommonInterfaces();
@ -352,17 +360,6 @@ namespace hex {
ImGui::EndMenuBar(); ImGui::EndMenuBar();
} }
if (auto &[key, mods] = Window::s_currShortcut; key != -1) {
for (auto &view : ContentRegistry::Views::getEntries()) {
if (view->shouldProcess()) {
if (view->handleShortcut(key, mods))
break;
}
}
Window::s_currShortcut = { -1, -1 };
}
if (SharedData::currentProvider == nullptr) { if (SharedData::currentProvider == nullptr) {
char title[256]; char title[256];
ImFormatString(title, IM_ARRAYSIZE(title), "%s/DockSpace_%08X", ImGui::GetCurrentWindow()->Name, ImGui::GetID("MainDock")); ImFormatString(title, IM_ARRAYSIZE(title), "%s/DockSpace_%08X", ImGui::GetCurrentWindow()->Name, ImGui::GetID("MainDock"));