Merge branch 'Flipper-XFW:dev' into dev

This commit is contained in:
Matthew
2023-10-11 14:19:30 -07:00
committed by GitHub
59 changed files with 118 additions and 111 deletions

View File

@@ -1,3 +0,0 @@
#pragma once
#define HID_BT_KEYS_STORAGE_NAME ".bt_hid.keys"

Binary file not shown.

Before

Width:  |  Height:  |  Size: 174 B

View File

@@ -1,14 +0,0 @@
#pragma once
#include <gui/view.h>
typedef struct Hid Hid;
typedef struct HidTikShorts HidTikShorts;
HidTikShorts* hid_tikshorts_alloc(Hid* bt_hid);
void hid_tikshorts_free(HidTikShorts* hid_tikshorts);
View* hid_tikshorts_get_view(HidTikShorts* hid_tikshorts);
void hid_tikshorts_set_connected_status(HidTikShorts* hid_tikshorts, bool connected);

View File

@@ -4,6 +4,8 @@ App(
apptype=FlipperAppType.EXTERNAL, apptype=FlipperAppType.EXTERNAL,
entry_point="hid_usb_app", entry_point="hid_usb_app",
stack_size=1 * 1024, stack_size=1 * 1024,
fap_description="Use Flipper as a HID remote control over USB",
fap_version="1.0",
fap_category="USB", fap_category="USB",
fap_icon="hid_usb_10px.png", fap_icon="hid_usb_10px.png",
fap_icon_assets="assets", fap_icon_assets="assets",
@@ -17,6 +19,8 @@ App(
apptype=FlipperAppType.EXTERNAL, apptype=FlipperAppType.EXTERNAL,
entry_point="hid_ble_app", entry_point="hid_ble_app",
stack_size=1 * 1024, stack_size=1 * 1024,
fap_description="Use Flipper as a HID remote control over Bluetooth",
fap_version="1.0",
fap_category="Bluetooth", fap_category="Bluetooth",
fap_icon="hid_ble_10px.png", fap_icon="hid_ble_10px.png",
fap_icon_assets="assets", fap_icon_assets="assets",

View File

Before

Width:  |  Height:  |  Size: 3.5 KiB

After

Width:  |  Height:  |  Size: 3.5 KiB

View File

Before

Width:  |  Height:  |  Size: 3.5 KiB

After

Width:  |  Height:  |  Size: 3.5 KiB

View File

Before

Width:  |  Height:  |  Size: 172 B

After

Width:  |  Height:  |  Size: 172 B

View File

Before

Width:  |  Height:  |  Size: 173 B

After

Width:  |  Height:  |  Size: 173 B

View File

Before

Width:  |  Height:  |  Size: 180 B

After

Width:  |  Height:  |  Size: 180 B

View File

Before

Width:  |  Height:  |  Size: 177 B

After

Width:  |  Height:  |  Size: 177 B

View File

Before

Width:  |  Height:  |  Size: 179 B

After

Width:  |  Height:  |  Size: 179 B

View File

Before

Width:  |  Height:  |  Size: 178 B

After

Width:  |  Height:  |  Size: 178 B

View File

Before

Width:  |  Height:  |  Size: 177 B

After

Width:  |  Height:  |  Size: 177 B

View File

Before

Width:  |  Height:  |  Size: 178 B

After

Width:  |  Height:  |  Size: 178 B

View File

Before

Width:  |  Height:  |  Size: 177 B

After

Width:  |  Height:  |  Size: 177 B

View File

Before

Width:  |  Height:  |  Size: 176 B

After

Width:  |  Height:  |  Size: 176 B

View File

Before

Width:  |  Height:  |  Size: 176 B

After

Width:  |  Height:  |  Size: 176 B

View File

Before

Width:  |  Height:  |  Size: 179 B

After

Width:  |  Height:  |  Size: 179 B

View File

Before

Width:  |  Height:  |  Size: 162 B

After

Width:  |  Height:  |  Size: 162 B

View File

Before

Width:  |  Height:  |  Size: 163 B

After

Width:  |  Height:  |  Size: 163 B

View File

Before

Width:  |  Height:  |  Size: 161 B

After

Width:  |  Height:  |  Size: 161 B

View File

Before

Width:  |  Height:  |  Size: 165 B

After

Width:  |  Height:  |  Size: 165 B

View File

Before

Width:  |  Height:  |  Size: 164 B

After

Width:  |  Height:  |  Size: 164 B

View File

Before

Width:  |  Height:  |  Size: 163 B

After

Width:  |  Height:  |  Size: 163 B

View File

Before

Width:  |  Height:  |  Size: 3.5 KiB

After

Width:  |  Height:  |  Size: 3.5 KiB

View File

Before

Width:  |  Height:  |  Size: 3.6 KiB

After

Width:  |  Height:  |  Size: 3.6 KiB

View File

Before

Width:  |  Height:  |  Size: 2.4 KiB

After

Width:  |  Height:  |  Size: 2.4 KiB

View File

Before

Width:  |  Height:  |  Size: 1.7 KiB

After

Width:  |  Height:  |  Size: 1.7 KiB

View File

Before

Width:  |  Height:  |  Size: 3.5 KiB

After

Width:  |  Height:  |  Size: 3.5 KiB

View File

Before

Width:  |  Height:  |  Size: 3.5 KiB

After

Width:  |  Height:  |  Size: 3.5 KiB

View File

Before

Width:  |  Height:  |  Size: 3.5 KiB

After

Width:  |  Height:  |  Size: 3.5 KiB

View File

Before

Width:  |  Height:  |  Size: 4.5 KiB

After

Width:  |  Height:  |  Size: 4.5 KiB

View File

Before

Width:  |  Height:  |  Size: 1.7 KiB

After

Width:  |  Height:  |  Size: 1.7 KiB

View File

Before

Width:  |  Height:  |  Size: 1.8 KiB

After

Width:  |  Height:  |  Size: 1.8 KiB

View File

Before

Width:  |  Height:  |  Size: 1.9 KiB

After

Width:  |  Height:  |  Size: 1.9 KiB

View File

Before

Width:  |  Height:  |  Size: 1.9 KiB

After

Width:  |  Height:  |  Size: 1.9 KiB

View File

Before

Width:  |  Height:  |  Size: 1.8 KiB

After

Width:  |  Height:  |  Size: 1.8 KiB

View File

Before

Width:  |  Height:  |  Size: 2.8 KiB

After

Width:  |  Height:  |  Size: 2.8 KiB

View File

@@ -1,6 +1,7 @@
#include "hid.h" #include "hid.h"
#include "views.h" #include "views.h"
#include <notification/notification_messages.h> #include <notification/notification_messages.h>
#include <dolphin/dolphin.h>
#define TAG "HidApp" #define TAG "HidApp"
@@ -10,7 +11,7 @@ enum HidDebugSubmenuIndex {
HidSubmenuIndexKeyboard, HidSubmenuIndexKeyboard,
HidSubmenuIndexNumpad, HidSubmenuIndexNumpad,
HidSubmenuIndexMedia, HidSubmenuIndexMedia,
HidSubmenuIndexTikShorts, HidSubmenuIndexTikTok,
HidSubmenuIndexMouse, HidSubmenuIndexMouse,
HidSubmenuIndexMouseClicker, HidSubmenuIndexMouseClicker,
HidSubmenuIndexMouseJiggler, HidSubmenuIndexMouseJiggler,
@@ -39,9 +40,9 @@ static void hid_submenu_callback(void* context, uint32_t index) {
} else if(index == HidSubmenuIndexMouse) { } else if(index == HidSubmenuIndexMouse) {
app->view_id = HidViewMouse; app->view_id = HidViewMouse;
view_dispatcher_switch_to_view(app->view_dispatcher, HidViewMouse); view_dispatcher_switch_to_view(app->view_dispatcher, HidViewMouse);
} else if(index == HidSubmenuIndexTikShorts) { } else if(index == HidSubmenuIndexTikTok) {
app->view_id = BtHidViewTikShorts; app->view_id = BtHidViewTikTok;
view_dispatcher_switch_to_view(app->view_dispatcher, BtHidViewTikShorts); view_dispatcher_switch_to_view(app->view_dispatcher, BtHidViewTikTok);
} else if(index == HidSubmenuIndexMouseClicker) { } else if(index == HidSubmenuIndexMouseClicker) {
app->view_id = HidViewMouseClicker; app->view_id = HidViewMouseClicker;
view_dispatcher_switch_to_view(app->view_dispatcher, HidViewMouseClicker); view_dispatcher_switch_to_view(app->view_dispatcher, HidViewMouseClicker);
@@ -69,7 +70,7 @@ static void bt_hid_connection_status_changed_callback(BtStatus status, void* con
hid_mouse_set_connected_status(hid->hid_mouse, connected); hid_mouse_set_connected_status(hid->hid_mouse, connected);
hid_mouse_clicker_set_connected_status(hid->hid_mouse_clicker, connected); hid_mouse_clicker_set_connected_status(hid->hid_mouse_clicker, connected);
hid_mouse_jiggler_set_connected_status(hid->hid_mouse_jiggler, connected); hid_mouse_jiggler_set_connected_status(hid->hid_mouse_jiggler, connected);
hid_tikshorts_set_connected_status(hid->hid_tikshorts, connected); hid_tiktok_set_connected_status(hid->hid_tiktok, connected);
} }
static void hid_dialog_callback(DialogExResult result, void* context) { static void hid_dialog_callback(DialogExResult result, void* context) {
@@ -133,7 +134,7 @@ Hid* hid_alloc(HidTransport transport) {
submenu_add_item( submenu_add_item(
app->device_type_submenu, app->device_type_submenu,
"TikTok / YT Shorts", "TikTok / YT Shorts",
HidSubmenuIndexTikShorts, HidSubmenuIndexTikTok,
hid_submenu_callback, hid_submenu_callback,
app); app);
} }
@@ -195,11 +196,11 @@ Hid* hid_app_alloc_view(void* context) {
view_dispatcher_add_view( view_dispatcher_add_view(
app->view_dispatcher, HidViewMedia, hid_media_get_view(app->hid_media)); app->view_dispatcher, HidViewMedia, hid_media_get_view(app->hid_media));
// TikTok / YT Shorts view // TikTok view
app->hid_tikshorts = hid_tikshorts_alloc(app); app->hid_tiktok = hid_tiktok_alloc(app);
view_set_previous_callback(hid_tikshorts_get_view(app->hid_tikshorts), hid_exit_confirm_view); view_set_previous_callback(hid_tiktok_get_view(app->hid_tiktok), hid_exit_confirm_view);
view_dispatcher_add_view( view_dispatcher_add_view(
app->view_dispatcher, BtHidViewTikShorts, hid_tikshorts_get_view(app->hid_tikshorts)); app->view_dispatcher, BtHidViewTikTok, hid_tiktok_get_view(app->hid_tiktok));
// Mouse view // Mouse view
app->hid_mouse = hid_mouse_alloc(app); app->hid_mouse = hid_mouse_alloc(app);
@@ -255,8 +256,8 @@ void hid_free(Hid* app) {
hid_mouse_clicker_free(app->hid_mouse_clicker); hid_mouse_clicker_free(app->hid_mouse_clicker);
view_dispatcher_remove_view(app->view_dispatcher, HidViewMouseJiggler); view_dispatcher_remove_view(app->view_dispatcher, HidViewMouseJiggler);
hid_mouse_jiggler_free(app->hid_mouse_jiggler); hid_mouse_jiggler_free(app->hid_mouse_jiggler);
view_dispatcher_remove_view(app->view_dispatcher, BtHidViewTikShorts); view_dispatcher_remove_view(app->view_dispatcher, BtHidViewTikTok);
hid_tikshorts_free(app->hid_tikshorts); hid_tiktok_free(app->hid_tiktok);
view_dispatcher_free(app->view_dispatcher); view_dispatcher_free(app->view_dispatcher);
// Close records // Close records
@@ -403,6 +404,8 @@ int32_t hid_usb_app(void* p) {
bt_hid_connection_status_changed_callback(BtStatusConnected, app); bt_hid_connection_status_changed_callback(BtStatusConnected, app);
dolphin_deed(DolphinDeedPluginStart);
view_dispatcher_run(app->view_dispatcher); view_dispatcher_run(app->view_dispatcher);
furi_hal_usb_set_config(usb_mode_prev, NULL); furi_hal_usb_set_config(usb_mode_prev, NULL);
@@ -441,6 +444,8 @@ int32_t hid_ble_app(void* p) {
furi_hal_bt_start_advertising(); furi_hal_bt_start_advertising();
bt_set_status_changed_callback(app->bt, bt_hid_connection_status_changed_callback, app); bt_set_status_changed_callback(app->bt, bt_hid_connection_status_changed_callback, app);
dolphin_deed(DolphinDeedPluginStart);
view_dispatcher_run(app->view_dispatcher); view_dispatcher_run(app->view_dispatcher);
bt_set_status_changed_callback(app->bt, NULL, NULL); bt_set_status_changed_callback(app->bt, NULL, NULL);

View File

@@ -21,11 +21,11 @@
#include "views/hid_numpad.h" #include "views/hid_numpad.h"
#include "views/hid_media.h" #include "views/hid_media.h"
#include "views/hid_mouse.h" #include "views/hid_mouse.h"
#include "views/hid_mouse_jiggler.h"
#include "views/hid_tikshorts.h"
#include "views/hid_mouse_clicker.h" #include "views/hid_mouse_clicker.h"
#include "views/hid_mouse_jiggler.h"
#include "views/hid_tiktok.h"
#include "hid_path.h" #define HID_BT_KEYS_STORAGE_NAME ".bt_hid.keys"
typedef enum { typedef enum {
HidTransportUsb, HidTransportUsb,
@@ -48,7 +48,7 @@ struct Hid {
HidMouse* hid_mouse; HidMouse* hid_mouse;
HidMouseClicker* hid_mouse_clicker; HidMouseClicker* hid_mouse_clicker;
HidMouseJiggler* hid_mouse_jiggler; HidMouseJiggler* hid_mouse_jiggler;
HidTikShorts* hid_tikshorts; HidTikTok* hid_tiktok;
HidTransport transport; HidTransport transport;
uint32_t view_id; uint32_t view_id;
@@ -66,4 +66,4 @@ void hid_hal_mouse_move(Hid* instance, int8_t dx, int8_t dy);
void hid_hal_mouse_scroll(Hid* instance, int8_t delta); void hid_hal_mouse_scroll(Hid* instance, int8_t delta);
void hid_hal_mouse_press(Hid* instance, uint16_t event); void hid_hal_mouse_press(Hid* instance, uint16_t event);
void hid_hal_mouse_release(Hid* instance, uint16_t event); void hid_hal_mouse_release(Hid* instance, uint16_t event);
void hid_hal_mouse_release_all(Hid* instance); void hid_hal_mouse_release_all(Hid* instance);

View File

Before

Width:  |  Height:  |  Size: 151 B

After

Width:  |  Height:  |  Size: 151 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 969 B

View File

@@ -7,6 +7,6 @@ typedef enum {
HidViewMouse, HidViewMouse,
HidViewMouseClicker, HidViewMouseClicker,
HidViewMouseJiggler, HidViewMouseJiggler,
BtHidViewTikShorts, BtHidViewTikTok,
HidViewExitConfirm, HidViewExitConfirm,
} HidView; } HidView;

View File

@@ -4,6 +4,7 @@
#include <gui/icon_i.h> #include <gui/icon_i.h>
#include "../hid.h" #include "../hid.h"
#include "hid_icons.h" #include "hid_icons.h"
#include <assets_icons.h> #include <assets_icons.h>
#define TAG "HidKeyboard" #define TAG "HidKeyboard"

View File

@@ -3,6 +3,7 @@
#include "../hid.h" #include "../hid.h"
#include "hid_icons.h" #include "hid_icons.h"
#include <assets_icons.h> #include <assets_icons.h>
#define TAG "HidKeynote" #define TAG "HidKeynote"
@@ -117,16 +118,16 @@ static void hid_keynote_draw_vertical_callback(Canvas* canvas, void* context) {
HidKeynoteModel* model = context; HidKeynoteModel* model = context;
// Header // Header
canvas_set_font(canvas, FontPrimary);
if(model->transport == HidTransportBle) { if(model->transport == HidTransportBle) {
if(model->connected) { if(model->connected) {
canvas_draw_icon(canvas, 0, 0, &I_Ble_connected_15x15); canvas_draw_icon(canvas, 0, 0, &I_Ble_connected_15x15);
} else { } else {
canvas_draw_icon(canvas, 0, 0, &I_Ble_disconnected_15x15); canvas_draw_icon(canvas, 0, 0, &I_Ble_disconnected_15x15);
} }
canvas_set_font(canvas, FontPrimary);
elements_multiline_text_aligned(canvas, 20, 3, AlignLeft, AlignTop, "Keynote"); elements_multiline_text_aligned(canvas, 20, 3, AlignLeft, AlignTop, "Keynote");
} else { } else {
canvas_set_font(canvas, FontPrimary);
elements_multiline_text_aligned(canvas, 12, 3, AlignLeft, AlignTop, "Keynote"); elements_multiline_text_aligned(canvas, 12, 3, AlignLeft, AlignTop, "Keynote");
} }

View File

@@ -6,6 +6,7 @@
#include "../hid.h" #include "../hid.h"
#include "hid_icons.h" #include "hid_icons.h"
#include <assets_icons.h> #include <assets_icons.h>
#define TAG "HidMedia" #define TAG "HidMedia"

View File

@@ -3,6 +3,7 @@
#include "../hid.h" #include "../hid.h"
#include "hid_icons.h" #include "hid_icons.h"
#include <assets_icons.h> #include <assets_icons.h>
#define TAG "HidMouse" #define TAG "HidMouse"

View File

@@ -3,6 +3,7 @@
#include "../hid.h" #include "../hid.h"
#include "hid_icons.h" #include "hid_icons.h"
#include <assets_icons.h> #include <assets_icons.h>
#define TAG "HidMouseClicker" #define TAG "HidMouseClicker"

View File

@@ -3,6 +3,7 @@
#include "../hid.h" #include "../hid.h"
#include "hid_icons.h" #include "hid_icons.h"
#include <assets_icons.h> #include <assets_icons.h>
#define TAG "HidMouseJiggler" #define TAG "HidMouseJiggler"

View File

@@ -4,6 +4,7 @@
#include <gui/icon_i.h> #include <gui/icon_i.h>
#include "../hid.h" #include "../hid.h"
#include "hid_icons.h" #include "hid_icons.h"
#include <assets_icons.h> #include <assets_icons.h>
#define TAG "HidNumpad" #define TAG "HidNumpad"

View File

@@ -1,13 +1,14 @@
#include "hid_tikshorts.h" #include "hid_tiktok.h"
#include "../hid.h" #include "../hid.h"
#include <gui/elements.h> #include <gui/elements.h>
#include "hid_icons.h" #include "hid_icons.h"
#include <assets_icons.h> #include <assets_icons.h>
#define TAG "HidTikShorts" #define TAG "HidTikTok"
struct HidTikShorts { struct HidTikTok {
View* view; View* view;
Hid* hid; Hid* hid;
}; };
@@ -22,11 +23,11 @@ typedef struct {
bool is_cursor_set; bool is_cursor_set;
bool back_mouse_pressed; bool back_mouse_pressed;
HidTransport transport; HidTransport transport;
} HidTikShortsModel; } HidTikTokModel;
static void hid_tikshorts_draw_callback(Canvas* canvas, void* context) { static void hid_tiktok_draw_callback(Canvas* canvas, void* context) {
furi_assert(context); furi_assert(context);
HidTikShortsModel* model = context; HidTikTokModel* model = context;
// Header // Header
if(model->transport == HidTransportBle) { if(model->transport == HidTransportBle) {
@@ -111,32 +112,30 @@ static void hid_tikshorts_draw_callback(Canvas* canvas, void* context) {
elements_multiline_text_aligned(canvas, 13, 62, AlignLeft, AlignBottom, "Hold to exit"); elements_multiline_text_aligned(canvas, 13, 62, AlignLeft, AlignBottom, "Hold to exit");
} }
static void hid_tikshorts_reset_cursor(HidTikShorts* hid_tikshorts) { static void hid_tiktok_reset_cursor(HidTikTok* hid_tiktok) {
// Set cursor to the phone's left up corner // Set cursor to the phone's left up corner
// Delays to guarantee one packet per connection interval // Delays to guarantee one packet per connection interval
for(size_t i = 0; i < 8; i++) { for(size_t i = 0; i < 8; i++) {
hid_hal_mouse_move(hid_tikshorts->hid, -127, -127); hid_hal_mouse_move(hid_tiktok->hid, -127, -127);
furi_delay_ms(50); furi_delay_ms(50);
} }
// Move cursor from the corner // Move cursor from the corner
hid_hal_mouse_move(hid_tikshorts->hid, 20, 120); hid_hal_mouse_move(hid_tiktok->hid, 20, 120);
furi_delay_ms(50); furi_delay_ms(50);
} }
static void hid_tikshorts_process_press( static void
HidTikShorts* hid_tikshorts, hid_tiktok_process_press(HidTikTok* hid_tiktok, HidTikTokModel* model, InputEvent* event) {
HidTikShortsModel* model,
InputEvent* event) {
if(event->key == InputKeyUp) { if(event->key == InputKeyUp) {
model->up_pressed = true; model->up_pressed = true;
} else if(event->key == InputKeyDown) { } else if(event->key == InputKeyDown) {
model->down_pressed = true; model->down_pressed = true;
} else if(event->key == InputKeyLeft) { } else if(event->key == InputKeyLeft) {
model->left_pressed = true; model->left_pressed = true;
hid_hal_consumer_key_press(hid_tikshorts->hid, HID_CONSUMER_VOLUME_DECREMENT); hid_hal_consumer_key_press(hid_tiktok->hid, HID_CONSUMER_VOLUME_DECREMENT);
} else if(event->key == InputKeyRight) { } else if(event->key == InputKeyRight) {
model->right_pressed = true; model->right_pressed = true;
hid_hal_consumer_key_press(hid_tikshorts->hid, HID_CONSUMER_VOLUME_INCREMENT); hid_hal_consumer_key_press(hid_tiktok->hid, HID_CONSUMER_VOLUME_INCREMENT);
} else if(event->key == InputKeyOk) { } else if(event->key == InputKeyOk) {
model->ok_pressed = true; model->ok_pressed = true;
} else if(event->key == InputKeyBack) { } else if(event->key == InputKeyBack) {
@@ -144,20 +143,18 @@ static void hid_tikshorts_process_press(
} }
} }
static void hid_tikshorts_process_release( static void
HidTikShorts* hid_tikshorts, hid_tiktok_process_release(HidTikTok* hid_tiktok, HidTikTokModel* model, InputEvent* event) {
HidTikShortsModel* model,
InputEvent* event) {
if(event->key == InputKeyUp) { if(event->key == InputKeyUp) {
model->up_pressed = false; model->up_pressed = false;
} else if(event->key == InputKeyDown) { } else if(event->key == InputKeyDown) {
model->down_pressed = false; model->down_pressed = false;
} else if(event->key == InputKeyLeft) { } else if(event->key == InputKeyLeft) {
model->left_pressed = false; model->left_pressed = false;
hid_hal_consumer_key_release(hid_tikshorts->hid, HID_CONSUMER_VOLUME_DECREMENT); hid_hal_consumer_key_release(hid_tiktok->hid, HID_CONSUMER_VOLUME_DECREMENT);
} else if(event->key == InputKeyRight) { } else if(event->key == InputKeyRight) {
model->right_pressed = false; model->right_pressed = false;
hid_hal_consumer_key_release(hid_tikshorts->hid, HID_CONSUMER_VOLUME_INCREMENT); hid_hal_consumer_key_release(hid_tiktok->hid, HID_CONSUMER_VOLUME_INCREMENT);
} else if(event->key == InputKeyOk) { } else if(event->key == InputKeyOk) {
model->ok_pressed = false; model->ok_pressed = false;
} else if(event->key == InputKeyBack) { } else if(event->key == InputKeyBack) {
@@ -165,61 +162,61 @@ static void hid_tikshorts_process_release(
} }
} }
static bool hid_tikshorts_input_callback(InputEvent* event, void* context) { static bool hid_tiktok_input_callback(InputEvent* event, void* context) {
furi_assert(context); furi_assert(context);
HidTikShorts* hid_tikshorts = context; HidTikTok* hid_tiktok = context;
bool consumed = false; bool consumed = false;
with_view_model( with_view_model(
hid_tikshorts->view, hid_tiktok->view,
HidTikShortsModel * model, HidTikTokModel * model,
{ {
if(event->type == InputTypePress) { if(event->type == InputTypePress) {
hid_tikshorts_process_press(hid_tikshorts, model, event); hid_tiktok_process_press(hid_tiktok, model, event);
if(model->connected && !model->is_cursor_set) { if(model->connected && !model->is_cursor_set) {
hid_tikshorts_reset_cursor(hid_tikshorts); hid_tiktok_reset_cursor(hid_tiktok);
model->is_cursor_set = true; model->is_cursor_set = true;
} }
consumed = true; consumed = true;
} else if(event->type == InputTypeRelease) { } else if(event->type == InputTypeRelease) {
hid_tikshorts_process_release(hid_tikshorts, model, event); hid_tiktok_process_release(hid_tiktok, model, event);
consumed = true; consumed = true;
} else if(event->type == InputTypeShort) { } else if(event->type == InputTypeShort) {
if(event->key == InputKeyOk) { if(event->key == InputKeyOk) {
hid_hal_mouse_press(hid_tikshorts->hid, HID_MOUSE_BTN_LEFT); hid_hal_mouse_press(hid_tiktok->hid, HID_MOUSE_BTN_LEFT);
furi_delay_ms(25); furi_delay_ms(25);
hid_hal_mouse_release(hid_tikshorts->hid, HID_MOUSE_BTN_LEFT); hid_hal_mouse_release(hid_tiktok->hid, HID_MOUSE_BTN_LEFT);
furi_delay_ms(100); furi_delay_ms(100);
hid_hal_mouse_press(hid_tikshorts->hid, HID_MOUSE_BTN_LEFT); hid_hal_mouse_press(hid_tiktok->hid, HID_MOUSE_BTN_LEFT);
furi_delay_ms(25); furi_delay_ms(25);
hid_hal_mouse_release(hid_tikshorts->hid, HID_MOUSE_BTN_LEFT); hid_hal_mouse_release(hid_tiktok->hid, HID_MOUSE_BTN_LEFT);
consumed = true;
} else if(event->key == InputKeyDown) {
// Swipe to next video
hid_hal_mouse_scroll(hid_tikshorts->hid, 6);
hid_hal_mouse_scroll(hid_tikshorts->hid, 8);
hid_hal_mouse_scroll(hid_tikshorts->hid, 10);
hid_hal_mouse_scroll(hid_tikshorts->hid, 8);
hid_hal_mouse_scroll(hid_tikshorts->hid, 6);
consumed = true; consumed = true;
} else if(event->key == InputKeyUp) { } else if(event->key == InputKeyUp) {
// Swipe to previous video // Emulate up swipe
hid_hal_mouse_scroll(hid_tikshorts->hid, -6); hid_hal_mouse_scroll(hid_tiktok->hid, -6);
hid_hal_mouse_scroll(hid_tikshorts->hid, -8); hid_hal_mouse_scroll(hid_tiktok->hid, -8);
hid_hal_mouse_scroll(hid_tikshorts->hid, -10); hid_hal_mouse_scroll(hid_tiktok->hid, -10);
hid_hal_mouse_scroll(hid_tikshorts->hid, -8); hid_hal_mouse_scroll(hid_tiktok->hid, -8);
hid_hal_mouse_scroll(hid_tikshorts->hid, -6); hid_hal_mouse_scroll(hid_tiktok->hid, -6);
consumed = true;
} else if(event->key == InputKeyDown) {
// Emulate down swipe
hid_hal_mouse_scroll(hid_tiktok->hid, 6);
hid_hal_mouse_scroll(hid_tiktok->hid, 8);
hid_hal_mouse_scroll(hid_tiktok->hid, 10);
hid_hal_mouse_scroll(hid_tiktok->hid, 8);
hid_hal_mouse_scroll(hid_tiktok->hid, 6);
consumed = true; consumed = true;
} else if(event->key == InputKeyBack) { } else if(event->key == InputKeyBack) {
// Pause // Pause
hid_hal_mouse_press(hid_tikshorts->hid, HID_MOUSE_BTN_LEFT); hid_hal_mouse_press(hid_tiktok->hid, HID_MOUSE_BTN_LEFT);
furi_delay_ms(50); furi_delay_ms(50);
hid_hal_mouse_release(hid_tikshorts->hid, HID_MOUSE_BTN_LEFT); hid_hal_mouse_release(hid_tiktok->hid, HID_MOUSE_BTN_LEFT);
consumed = true; consumed = true;
} }
} else if(event->type == InputTypeLong) { } else if(event->type == InputTypeLong) {
if(event->key == InputKeyBack) { if(event->key == InputKeyBack) {
hid_hal_consumer_key_release_all(hid_tikshorts->hid); hid_hal_consumer_key_release_all(hid_tiktok->hid);
model->is_cursor_set = false; model->is_cursor_set = false;
consumed = false; consumed = false;
} }
@@ -230,40 +227,37 @@ static bool hid_tikshorts_input_callback(InputEvent* event, void* context) {
return consumed; return consumed;
} }
HidTikShorts* hid_tikshorts_alloc(Hid* bt_hid) { HidTikTok* hid_tiktok_alloc(Hid* bt_hid) {
HidTikShorts* hid_tikshorts = malloc(sizeof(HidTikShorts)); HidTikTok* hid_tiktok = malloc(sizeof(HidTikTok));
hid_tikshorts->hid = bt_hid; hid_tiktok->hid = bt_hid;
hid_tikshorts->view = view_alloc(); hid_tiktok->view = view_alloc();
view_set_context(hid_tikshorts->view, hid_tikshorts); view_set_context(hid_tiktok->view, hid_tiktok);
view_allocate_model(hid_tikshorts->view, ViewModelTypeLocking, sizeof(HidTikShortsModel)); view_allocate_model(hid_tiktok->view, ViewModelTypeLocking, sizeof(HidTikTokModel));
view_set_draw_callback(hid_tikshorts->view, hid_tikshorts_draw_callback); view_set_draw_callback(hid_tiktok->view, hid_tiktok_draw_callback);
view_set_input_callback(hid_tikshorts->view, hid_tikshorts_input_callback); view_set_input_callback(hid_tiktok->view, hid_tiktok_input_callback);
with_view_model( with_view_model(
hid_tikshorts->view, hid_tiktok->view, HidTikTokModel * model, { model->transport = bt_hid->transport; }, true);
HidTikShortsModel * model,
{ model->transport = bt_hid->transport; },
true);
return hid_tikshorts; return hid_tiktok;
} }
void hid_tikshorts_free(HidTikShorts* hid_tikshorts) { void hid_tiktok_free(HidTikTok* hid_tiktok) {
furi_assert(hid_tikshorts); furi_assert(hid_tiktok);
view_free(hid_tikshorts->view); view_free(hid_tiktok->view);
free(hid_tikshorts); free(hid_tiktok);
} }
View* hid_tikshorts_get_view(HidTikShorts* hid_tikshorts) { View* hid_tiktok_get_view(HidTikTok* hid_tiktok) {
furi_assert(hid_tikshorts); furi_assert(hid_tiktok);
return hid_tikshorts->view; return hid_tiktok->view;
} }
void hid_tikshorts_set_connected_status(HidTikShorts* hid_tikshorts, bool connected) { void hid_tiktok_set_connected_status(HidTikTok* hid_tiktok, bool connected) {
furi_assert(hid_tikshorts); furi_assert(hid_tiktok);
with_view_model( with_view_model(
hid_tikshorts->view, hid_tiktok->view,
HidTikShortsModel * model, HidTikTokModel * model,
{ {
model->connected = connected; model->connected = connected;
model->is_cursor_set = false; model->is_cursor_set = false;

View File

@@ -0,0 +1,14 @@
#pragma once
#include <gui/view.h>
typedef struct Hid Hid;
typedef struct HidTikTok HidTikTok;
HidTikTok* hid_tiktok_alloc(Hid* bt_hid);
void hid_tiktok_free(HidTikTok* hid_tiktok);
View* hid_tiktok_get_view(HidTikTok* hid_tiktok);
void hid_tiktok_set_connected_status(HidTikTok* hid_tiktok, bool connected);