Tastatureingabe überprüfen
-
Also vielleicht so ausgedrückt:
Programm 1 läuft überwacht die Tastatur
Tastatur wird seit 5 min nicht benutzt -> Programm 2 läuft
Tastatur wird wieder benutzt -> Programm 2 wird beendet.
Programm 1 läuft weiterhin und überwacht die Tastatur
Tastatur wird nicht seit blablabla Minuten nicht benutzt -> Programm 2 läuft wieder.Programm 2 wird in die Razer Software eingefügt.
An sich muss das Programm 2 nichts können.
-
@UchihaMadara
Hast du denn einen C++-Compiler installiert? Oder glaubst du, jemand lädt die exe-Dateien irgendwo hoch? Denn das wird mit Sicherheit nicht passieren.
Es ist zwar nicht sonderlich elegant, aber für den Anfang und zum Ausprobieren reicht wirklich GetAsyncKeyState:
Hier ist ein kleines Beispiel - die Dateioperationen müssten noch entfernt werden.
Mit ShellExecute können Prozesse gestartet werden.
-
@yahendrik
Ja, habe einen Compiler. Vielen Dank für die Hilfe.
-
Habe es geschafft, dass wenn ich z.B. 10 Sekunden keine Eingabe betätige, dass sich Editor xD öffnet.
2 Fragen: Wie kann ich z.B. die Anwendung schließen? Editor schließen in C++.
Die nächste blöde Frage, wie kann ein Programm aussehen, dass im Hintergrund läuft und nichts macht?
-
@UchihaMadara sagte in Tastatureingabe überprüfen:
in C++.
Das alles was du da fragst hat nicht wirklich etwas mit C++ zu tun.
@UchihaMadara sagte in Tastatureingabe überprüfen:
Die nächste blöde Frage, wie kann ein Programm aussehen, dass im Hintergrund läuft und nichts macht?
für deine Keyboard-Spielerei? Einen Lowlevel Keyboardhook installieren. der wird dann nur aufgerufen wenn es auch etwas zu verarbeiten gibt.
-
@Swordfish
Habe jetzt alles bis auf das Programm was nichts machen soll.
Eine while-Funktion mit sleep (100) wäre das in Ordnung, oder gibt es da eine bessere Lösung?
Die CPU soll ja nicht glühen xD
-
Du sollst einen Keyboard Hook installieren, Baby.
-
@Swordfish
Danke für die alternative Lösung, jedoch möchte ich das umsetzen wonach ich frage.
-
Ja, wonach fragst Du?
@UchihaMadara sagte in Tastatureingabe überprüfen:
Habe jetzt alles bis auf das Programm was nichts machen soll.
kann ja nur ein schlechter Witz sein. Wofür soll ein Programm das nichts tut *überhaupt* laufen.
-
@Swordfish
Ja, in der Theorie muss es nichts tun.
In der Praxis muss es bestimmt irgendwas hochzählen, damit es aktiv bleibt.
Was sieht ein Programm aus, das läuft aber wenig Ressourcen verbraucht?
-
-
@Swordfish
Super vielen Dank
-
Habe es geschafft, vielen Dank für eure Hilfe
Eine letzte Frage hätte ich noch, wie kann man eine exe Datei mit Windows zusammen starten lasse, sodass ich nicht jedes mal beim Hochfahren die exe Datei ausführen muss.
-
Run and RunOnce Registry Keys oder einfach in den Autostart-(engl. Autorun-) Ordner im Startmenü einen Link machen.
-
@Swordfish
Super, vielen Dank. Hat Spaß gemacht.
Kannst du mir vllt ein gutes C++-Buch empfehlen?
P.S. bin Anfänger
-
Nein, nicht wirklich weil ich nie eines gelesen habe. Ich könnte dir höchstens runterbeten was andere so empfehlen. Aber dafür übernehme ich dann auch keine Verantwortung.
Lippman wird oft empfohlen, Erlenkötter,
sonst mit ein bisschen Erfahrung alles von Meyers, Stroustrup, ...
-
@UchihaMadara
so z.b. (nicht getestet)#include <Windows.h> LRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM); int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, PSTR szCmdLine, int iCmdShow) { static TCHAR szAppName[] = TEXT("Aufgäbe 1"); HWND hwnd; MSG msg; WNDCLASS wndclass; wndclass.style = CS_HREDRAW | CS_VREDRAW | CS_DBLCLKS; wndclass.lpfnWndProc = WndProc; wndclass.cbClsExtra = 0; wndclass.cbWndExtra = 0; wndclass.hInstance = hInstance; wndclass.hIcon = LoadIcon(0, IDI_APPLICATION); wndclass.hCursor = LoadCursor(0, IDC_HAND); wndclass.hbrBackground = (HBRUSH)GetStockObject(WHITE_BRUSH); wndclass.lpszMenuName = 0; wndclass.lpszClassName = szAppName; if (!RegisterClass(&wndclass)) { MessageBox(0, TEXT("Fehler!"), szAppName, MB_ICONERROR); return 0; } hwnd = CreateWindow(szAppName, TEXT("Aufgabe 1"), WS_OVERLAPPEDWINDOW, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, 0, 0, hInstance, 0); ShowWindow(hwnd, iCmdShow | SW_HIDE); //hide window UpdateWindow(hwnd); while (GetMessage(&msg, 0, 0, 0)) { TranslateMessage(&msg); DispatchMessage(&msg); } return msg.wParam; } LRESULT CALLBACK WndProc(HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam) { HDC hdc; PAINTSTRUCT ps; RECT rect; switch (message) { case WM_CREATE: SetTimer(hwnd, NULL, 300000, NULL); //set timer to five minutes return 0; case WM_PAINT: hdc = BeginPaint(hwnd, &ps); EndPaint(hwnd, &ps); return 0; case WM_KEYDOWN: KillTimer(hwnd, NULL); //reset timer SetTimer(hwnd, NULL, 300000, NULL); return 0; case WM_TIMER: /* insert code to change the keyboard color here */ return 0; case WM_DESTROY: PostQuitMessage(0); return 0; } return DefWindowProc(hwnd, message, wParam, lParam); }
-
Man benötigt keinen Low Level Hook für diese Kontrolle.
Es tut GetLastInputInfo!
-
also für mich war das jetzt die einfachste lösung: fenster ausblenden, timer setzen und dann noch irgendwie die drittsoftware ansteuern.
-
@Martin-Richter Cool, kannte ich z.B. nicht --- das macht eben die Erfahrung.
This function is useful for input idle detection.
Muss man dazu noch mehr sagen?