Touch emulation from usb cdc (#1706)

This commit is contained in:
Totoo 2024-01-03 14:06:29 +01:00 committed by GitHub
parent fbe7954f2e
commit 58bf60695d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
9 changed files with 52 additions and 4 deletions

View File

@ -238,6 +238,10 @@ ui::Widget* EventDispatcher::touch_widget(ui::Widget* const w, ui::TouchEvent ev
return nullptr; return nullptr;
} }
void EventDispatcher::emulateTouch(ui::TouchEvent event) {
on_touch_event(event);
}
void EventDispatcher::on_touch_event(ui::TouchEvent event) { void EventDispatcher::on_touch_event(ui::TouchEvent event) {
/* TODO: Capture widget receiving the Start event, send Move and /* TODO: Capture widget receiving the Start event, send Move and
* End events to the same widget. * End events to the same widget.

View File

@ -86,6 +86,8 @@ class EventDispatcher {
events_flag(EVT_MASK_LOCAL); events_flag(EVT_MASK_LOCAL);
} }
void emulateTouch(ui::TouchEvent event);
private: private:
static Thread* thread_event_loop; static Thread* thread_event_loop;

View File

@ -157,7 +157,7 @@ static void event_loop() {
[&event_dispatcher](const Message* const) { [&event_dispatcher](const Message* const) {
event_dispatcher.set_display_sleep(true); event_dispatcher.set_display_sleep(true);
}}; }};
portapack::setEventDispatcherToUSBSerial(&event_dispatcher);
event_dispatcher.run(); event_dispatcher.run();
} }

View File

@ -542,4 +542,8 @@ void shutdown(const bool leave_screen_on) {
shutdown_base(); shutdown_base();
} }
void setEventDispatcherToUSBSerial(EventDispatcher* evt) {
usb_serial.setEventDispatcher(evt);
}
} /* namespace portapack */ } /* namespace portapack */

View File

@ -68,6 +68,8 @@ bool get_antenna_bias();
bool init(); bool init();
void shutdown(const bool leave_screen_on = false); void shutdown(const bool leave_screen_on = false);
void setEventDispatcherToUSBSerial(EventDispatcher* evt);
Backlight* backlight(); Backlight* backlight();
} /* namespace portapack */ } /* namespace portapack */

View File

@ -32,7 +32,7 @@ void USBSerial::dispatch() {
if (shell_created == false) { if (shell_created == false) {
shell_created = true; shell_created = true;
create_shell(); create_shell(_eventDispatcher);
} }
bulk_out_receive(); bulk_out_receive();

View File

@ -24,6 +24,8 @@
#include "ch.h" #include "ch.h"
#include "hal.h" #include "hal.h"
class EventDispatcher;
namespace portapack { namespace portapack {
class USBSerial { class USBSerial {
@ -32,6 +34,7 @@ class USBSerial {
void dispatch(); void dispatch();
void on_channel_opened(); void on_channel_opened();
void on_channel_closed(); void on_channel_closed();
void setEventDispatcher(EventDispatcher* ed) { _eventDispatcher = ed; }
private: private:
void enable_xtal(); void enable_xtal();
@ -43,6 +46,8 @@ class USBSerial {
bool connected{false}; bool connected{false};
bool shell_created{false}; bool shell_created{false};
EventDispatcher* _eventDispatcher = NULL;
}; };
} // namespace portapack } // namespace portapack

View File

@ -51,6 +51,11 @@
#define SHELL_WA_SIZE THD_WA_SIZE(1024 * 3) #define SHELL_WA_SIZE THD_WA_SIZE(1024 * 3)
#define palOutputPad(port, pad) (LPC_GPIO->DIR[(port)] |= 1 << (pad)) #define palOutputPad(port, pad) (LPC_GPIO->DIR[(port)] |= 1 << (pad))
static EventDispatcher* _eventDispatcherInstance = NULL;
static EventDispatcher* getEventDispatcherInstance() {
return _eventDispatcherInstance;
}
// queue handler from ch // queue handler from ch
static msg_t qwait(GenericQueue* qp, systime_t time) { static msg_t qwait(GenericQueue* qp, systime_t time) {
if (TIME_IMMEDIATE == time) if (TIME_IMMEDIATE == time)
@ -338,6 +343,28 @@ static void cmd_button(BaseSequentialStream* chp, int argc, char* argv[]) {
chprintf(chp, "ok\r\n"); chprintf(chp, "ok\r\n");
} }
static void cmd_touch(BaseSequentialStream* chp, int argc, char* argv[]) {
if (argc != 2) {
chprintf(chp, "usage: touch x y\r\n");
return;
}
int x = (int)strtol(argv[0], NULL, 10);
int y = (int)strtol(argv[1], NULL, 10);
if (x < 0 || x > ui::screen_width || y < 0 || y > ui::screen_height) {
chprintf(chp, "usage: touch x y\r\n");
return;
}
auto evtd = getEventDispatcherInstance();
if (evtd == NULL) {
chprintf(chp, "error\r\n");
}
evtd->emulateTouch({{x, y}, ui::TouchEvent::Type::Start});
evtd->emulateTouch({{x, y}, ui::TouchEvent::Type::End});
chprintf(chp, "ok\r\n");
}
static void cmd_sd_list_dir(BaseSequentialStream* chp, int argc, char* argv[]) { static void cmd_sd_list_dir(BaseSequentialStream* chp, int argc, char* argv[]) {
if (argc != 1) { if (argc != 1) {
chprintf(chp, "usage: ls /\r\n"); chprintf(chp, "usage: ls /\r\n");
@ -838,6 +865,7 @@ static const ShellCommand commands[] = {
{"write_memory", cmd_write_memory}, {"write_memory", cmd_write_memory},
{"read_memory", cmd_read_memory}, {"read_memory", cmd_read_memory},
{"button", cmd_button}, {"button", cmd_button},
{"touch", cmd_touch},
{"ls", cmd_sd_list_dir}, {"ls", cmd_sd_list_dir},
{"rm", cmd_sd_delete}, {"rm", cmd_sd_delete},
{"open", cmd_sd_open}, {"open", cmd_sd_open},
@ -854,6 +882,7 @@ static const ShellConfig shell_cfg1 = {
(BaseSequentialStream*)&SUSBD1, (BaseSequentialStream*)&SUSBD1,
commands}; commands};
void create_shell() { void create_shell(EventDispatcher* evtd) {
_eventDispatcherInstance = evtd;
shellCreate(&shell_cfg1, SHELL_WA_SIZE, NORMALPRIO); shellCreate(&shell_cfg1, SHELL_WA_SIZE, NORMALPRIO);
} }

View File

@ -26,4 +26,6 @@
#include "shell.h" #include "shell.h"
void create_shell(void); class EventDispatcher;
void create_shell(EventDispatcher* evtd);