Merge pull request #105 from InfiniTimeOrg/arrow_keys_for_swiping
main: add swipe direction keys to make debugging easier
This commit is contained in:
commit
e9a42c8638
@ -123,6 +123,9 @@ Using the keyboard the following events can be triggered:
|
|||||||
- `i` ... take screenshot
|
- `i` ... take screenshot
|
||||||
- `I` ... start/stop Gif screen capture
|
- `I` ... start/stop Gif screen capture
|
||||||
|
|
||||||
|
Additionally using the arrow keys the respective swipe gesture can be triggered.
|
||||||
|
For example pressing the UP key triggers a `SwipeUp` gesture.
|
||||||
|
|
||||||
## Littlefs-do helper
|
## Littlefs-do helper
|
||||||
|
|
||||||
To help working with the SPI-raw file the tool `littlefs-do` is provided.
|
To help working with the SPI-raw file the tool `littlefs-do` is provided.
|
||||||
|
31
main.cpp
31
main.cpp
@ -651,6 +651,24 @@ public:
|
|||||||
debounce('8', '!'+8, state[SDL_SCANCODE_8], key_handled_8);
|
debounce('8', '!'+8, state[SDL_SCANCODE_8], key_handled_8);
|
||||||
debounce('9', '!'+9, state[SDL_SCANCODE_9], key_handled_9);
|
debounce('9', '!'+9, state[SDL_SCANCODE_9], key_handled_9);
|
||||||
debounce('0', '!'+0, state[SDL_SCANCODE_0], key_handled_0);
|
debounce('0', '!'+0, state[SDL_SCANCODE_0], key_handled_0);
|
||||||
|
// direction keys
|
||||||
|
debounce(':', ':', state[SDL_SCANCODE_UP], key_handled_up);
|
||||||
|
debounce(';', ';', state[SDL_SCANCODE_DOWN], key_handled_down);
|
||||||
|
debounce('<', '<', state[SDL_SCANCODE_LEFT], key_handled_left);
|
||||||
|
debounce('>', '>', state[SDL_SCANCODE_RIGHT], key_handled_right);
|
||||||
|
}
|
||||||
|
// inject a swipe gesture to the touch handler and notify displayapp to notice it
|
||||||
|
void send_gesture(Pinetime::Drivers::Cst816S::Gestures gesture)
|
||||||
|
{
|
||||||
|
Pinetime::Drivers::Cst816S::TouchInfos info;
|
||||||
|
info.isValid = true;
|
||||||
|
info.touching = true;
|
||||||
|
info.gesture = gesture;
|
||||||
|
touchHandler.ProcessTouchInfo(info);
|
||||||
|
displayApp.PushMessage(Pinetime::Applications::Display::Messages::TouchEvent);
|
||||||
|
info.touching = false;
|
||||||
|
info.gesture = Pinetime::Drivers::Cst816S::Gestures::None;
|
||||||
|
touchHandler.ProcessTouchInfo(info);
|
||||||
}
|
}
|
||||||
// modify the simulated controller depending on the pressed key
|
// modify the simulated controller depending on the pressed key
|
||||||
void handle_key(SDL_Keycode key) {
|
void handle_key(SDL_Keycode key) {
|
||||||
@ -728,6 +746,14 @@ public:
|
|||||||
this->switch_to_screen(key-'0');
|
this->switch_to_screen(key-'0');
|
||||||
} else if (key >= '!'+0 && key <= '!'+9) {
|
} else if (key >= '!'+0 && key <= '!'+9) {
|
||||||
this->switch_to_screen(key-'!'+10);
|
this->switch_to_screen(key-'!'+10);
|
||||||
|
} else if (key == ':') { // up
|
||||||
|
send_gesture(Pinetime::Drivers::Cst816S::Gestures::SlideUp);
|
||||||
|
} else if (key == ';') { // down
|
||||||
|
send_gesture(Pinetime::Drivers::Cst816S::Gestures::SlideDown);
|
||||||
|
} else if (key == '<') { // left
|
||||||
|
send_gesture(Pinetime::Drivers::Cst816S::Gestures::SlideLeft);
|
||||||
|
} else if (key == '>') { // up
|
||||||
|
send_gesture(Pinetime::Drivers::Cst816S::Gestures::SlideRight);
|
||||||
}
|
}
|
||||||
batteryController.voltage = batteryController.percentRemaining * 50;
|
batteryController.voltage = batteryController.percentRemaining * 50;
|
||||||
}
|
}
|
||||||
@ -905,6 +931,11 @@ private:
|
|||||||
bool key_handled_8 = false;
|
bool key_handled_8 = false;
|
||||||
bool key_handled_9 = false;
|
bool key_handled_9 = false;
|
||||||
bool key_handled_0 = false;
|
bool key_handled_0 = false;
|
||||||
|
// direction arrows
|
||||||
|
bool key_handled_up = false; // inject swipe up
|
||||||
|
bool key_handled_down = false; // inject swipe down
|
||||||
|
bool key_handled_left = false; // inject swipe left
|
||||||
|
bool key_handled_right = false; // inject swipe right
|
||||||
bool visible; // show Simulator window
|
bool visible; // show Simulator window
|
||||||
int height; // Height of the window
|
int height; // Height of the window
|
||||||
int width; // Width of the window
|
int width; // Width of the window
|
||||||
|
Loading…
Reference in New Issue
Block a user