upd
This commit is contained in:
@@ -16,7 +16,6 @@ Keybinds::Keybinds() {
|
||||
void Keybinds::pollInputs() {
|
||||
for (Keybind& k : keybinds) {
|
||||
if (k.key != 0) {
|
||||
// Если кнопка удерживается
|
||||
if (GetAsyncKeyState(k.key) & 0x8000) {
|
||||
k.var = true;
|
||||
} else {
|
||||
@@ -95,5 +94,65 @@ void Keybinds::menuButton(bool& var) {
|
||||
}
|
||||
}
|
||||
|
||||
void Keybinds::menuButton(int& key) {
|
||||
char keyName[32] = "None";
|
||||
if (key != 0) {
|
||||
switch (key) {
|
||||
case VK_INSERT: strcpy_s(keyName, "INSERT"); break;
|
||||
case VK_DELETE: strcpy_s(keyName, "DELETE"); break;
|
||||
case VK_HOME: strcpy_s(keyName, "HOME"); break;
|
||||
case VK_END: strcpy_s(keyName, "END"); break;
|
||||
case VK_PRIOR: strcpy_s(keyName, "PAGE UP"); break;
|
||||
case VK_NEXT: strcpy_s(keyName, "PAGE DOWN"); break;
|
||||
case VK_LBUTTON: strcpy_s(keyName, "MOUSE1"); break;
|
||||
case VK_RBUTTON: strcpy_s(keyName, "MOUSE2"); break;
|
||||
case VK_MBUTTON: strcpy_s(keyName, "MOUSE3"); break;
|
||||
case VK_XBUTTON1: strcpy_s(keyName, "MOUSE4"); break;
|
||||
case VK_XBUTTON2: strcpy_s(keyName, "MOUSE5"); break;
|
||||
default:
|
||||
if (key >= 'A' && key <= 'Z') {
|
||||
sprintf_s(keyName, "%c", key);
|
||||
}
|
||||
else if (key >= '0' && key <= '9') {
|
||||
sprintf_s(keyName, "%c", key);
|
||||
}
|
||||
else {
|
||||
sprintf_s(keyName, "0x%X", key);
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
static bool isListening = false;
|
||||
static bool skipFrame = false;
|
||||
if (!isListening) {
|
||||
ImGui::Text("[%s]", keyName);
|
||||
ImGui::SameLine();
|
||||
if (ImGui::Button("Change##BindInt")) {
|
||||
isListening = true;
|
||||
skipFrame = true;
|
||||
}
|
||||
} else {
|
||||
ImGui::Text("Press any key...");
|
||||
ImGui::SameLine();
|
||||
if (ImGui::Button("Cancel") || (GetAsyncKeyState(VK_ESCAPE) & 0x8000)) {
|
||||
isListening = false;
|
||||
return;
|
||||
}
|
||||
if (!skipFrame) {
|
||||
if (GetAsyncKeyState(VK_XBUTTON1) & 0x8000) { key = VK_XBUTTON1; isListening = false; return; }
|
||||
if (GetAsyncKeyState(VK_XBUTTON2) & 0x8000) { key = VK_XBUTTON2; isListening = false; return; }
|
||||
for (int keyCode = 7; keyCode < 256; ++keyCode) {
|
||||
if (GetAsyncKeyState(keyCode) & 0x8000) {
|
||||
key = keyCode;
|
||||
isListening = false;
|
||||
return;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
skipFrame = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Keybinds keybind;
|
||||
|
||||
@@ -17,6 +17,7 @@ public:
|
||||
void pollInputs();
|
||||
|
||||
void menuButton(bool& var);
|
||||
void menuButton(int& key);
|
||||
private:
|
||||
std::vector<Keybind> keybinds;
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user