[FL-3021] USB/BLE HID Remote icon fix (#2179)
Co-authored-by: あく <alleteam@gmail.com>
This commit is contained in:
parent
8a279758fd
commit
f43b76efc2
Binary file not shown.
Before Width: | Height: | Size: 3.5 KiB After Width: | Height: | Size: 657 B |
@ -42,11 +42,13 @@ static void bt_hid_connection_status_changed_callback(BtStatus status, void* con
|
|||||||
furi_assert(context);
|
furi_assert(context);
|
||||||
Hid* hid = context;
|
Hid* hid = context;
|
||||||
bool connected = (status == BtStatusConnected);
|
bool connected = (status == BtStatusConnected);
|
||||||
|
if(hid->transport == HidTransportBle) {
|
||||||
if(connected) {
|
if(connected) {
|
||||||
notification_internal_message(hid->notifications, &sequence_set_blue_255);
|
notification_internal_message(hid->notifications, &sequence_set_blue_255);
|
||||||
} else {
|
} else {
|
||||||
notification_internal_message(hid->notifications, &sequence_reset_blue);
|
notification_internal_message(hid->notifications, &sequence_reset_blue);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
hid_keynote_set_connected_status(hid->hid_keynote, connected);
|
hid_keynote_set_connected_status(hid->hid_keynote, connected);
|
||||||
hid_keyboard_set_connected_status(hid->hid_keyboard, connected);
|
hid_keyboard_set_connected_status(hid->hid_keyboard, connected);
|
||||||
hid_media_set_connected_status(hid->hid_media, connected);
|
hid_media_set_connected_status(hid->hid_media, connected);
|
||||||
@ -186,7 +188,9 @@ void hid_free(Hid* app) {
|
|||||||
furi_assert(app);
|
furi_assert(app);
|
||||||
|
|
||||||
// Reset notification
|
// Reset notification
|
||||||
|
if(app->transport == HidTransportBle) {
|
||||||
notification_internal_message(app->notifications, &sequence_reset_blue);
|
notification_internal_message(app->notifications, &sequence_reset_blue);
|
||||||
|
}
|
||||||
|
|
||||||
// Free views
|
// Free views
|
||||||
view_dispatcher_remove_view(app->view_dispatcher, HidViewSubmenu);
|
view_dispatcher_remove_view(app->view_dispatcher, HidViewSubmenu);
|
||||||
|
@ -25,6 +25,7 @@ typedef struct {
|
|||||||
bool back_pressed;
|
bool back_pressed;
|
||||||
bool connected;
|
bool connected;
|
||||||
char key_string[5];
|
char key_string[5];
|
||||||
|
HidTransport transport;
|
||||||
} HidKeyboardModel;
|
} HidKeyboardModel;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
@ -207,7 +208,7 @@ static void hid_keyboard_draw_callback(Canvas* canvas, void* context) {
|
|||||||
HidKeyboardModel* model = context;
|
HidKeyboardModel* model = context;
|
||||||
|
|
||||||
// Header
|
// Header
|
||||||
if(!model->connected) {
|
if((!model->connected) && (model->transport == HidTransportBle)) {
|
||||||
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);
|
canvas_set_font(canvas, FontPrimary);
|
||||||
elements_multiline_text_aligned(canvas, 17, 3, AlignLeft, AlignTop, "Keyboard");
|
elements_multiline_text_aligned(canvas, 17, 3, AlignLeft, AlignTop, "Keyboard");
|
||||||
@ -361,6 +362,12 @@ HidKeyboard* hid_keyboard_alloc(Hid* bt_hid) {
|
|||||||
view_set_draw_callback(hid_keyboard->view, hid_keyboard_draw_callback);
|
view_set_draw_callback(hid_keyboard->view, hid_keyboard_draw_callback);
|
||||||
view_set_input_callback(hid_keyboard->view, hid_keyboard_input_callback);
|
view_set_input_callback(hid_keyboard->view, hid_keyboard_input_callback);
|
||||||
|
|
||||||
|
with_view_model(
|
||||||
|
hid_keyboard->view,
|
||||||
|
HidKeyboardModel * model,
|
||||||
|
{ model->transport = bt_hid->transport; },
|
||||||
|
true);
|
||||||
|
|
||||||
return hid_keyboard;
|
return hid_keyboard;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -19,6 +19,7 @@ typedef struct {
|
|||||||
bool ok_pressed;
|
bool ok_pressed;
|
||||||
bool back_pressed;
|
bool back_pressed;
|
||||||
bool connected;
|
bool connected;
|
||||||
|
HidTransport transport;
|
||||||
} HidKeynoteModel;
|
} HidKeynoteModel;
|
||||||
|
|
||||||
static void hid_keynote_draw_arrow(Canvas* canvas, uint8_t x, uint8_t y, CanvasDirection dir) {
|
static void hid_keynote_draw_arrow(Canvas* canvas, uint8_t x, uint8_t y, CanvasDirection dir) {
|
||||||
@ -39,11 +40,14 @@ static void hid_keynote_draw_callback(Canvas* canvas, void* context) {
|
|||||||
HidKeynoteModel* model = context;
|
HidKeynoteModel* model = context;
|
||||||
|
|
||||||
// Header
|
// Header
|
||||||
|
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);
|
canvas_set_font(canvas, FontPrimary);
|
||||||
elements_multiline_text_aligned(canvas, 17, 3, AlignLeft, AlignTop, "Keynote");
|
elements_multiline_text_aligned(canvas, 17, 3, AlignLeft, AlignTop, "Keynote");
|
||||||
|
|
||||||
@ -186,6 +190,9 @@ HidKeynote* hid_keynote_alloc(Hid* hid) {
|
|||||||
view_set_draw_callback(hid_keynote->view, hid_keynote_draw_callback);
|
view_set_draw_callback(hid_keynote->view, hid_keynote_draw_callback);
|
||||||
view_set_input_callback(hid_keynote->view, hid_keynote_input_callback);
|
view_set_input_callback(hid_keynote->view, hid_keynote_input_callback);
|
||||||
|
|
||||||
|
with_view_model(
|
||||||
|
hid_keynote->view, HidKeynoteModel * model, { model->transport = hid->transport; }, true);
|
||||||
|
|
||||||
return hid_keynote;
|
return hid_keynote;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,6 +21,7 @@ typedef struct {
|
|||||||
bool down_pressed;
|
bool down_pressed;
|
||||||
bool ok_pressed;
|
bool ok_pressed;
|
||||||
bool connected;
|
bool connected;
|
||||||
|
HidTransport transport;
|
||||||
} HidMediaModel;
|
} HidMediaModel;
|
||||||
|
|
||||||
static void hid_media_draw_arrow(Canvas* canvas, uint8_t x, uint8_t y, CanvasDirection dir) {
|
static void hid_media_draw_arrow(Canvas* canvas, uint8_t x, uint8_t y, CanvasDirection dir) {
|
||||||
@ -41,11 +42,14 @@ static void hid_media_draw_callback(Canvas* canvas, void* context) {
|
|||||||
HidMediaModel* model = context;
|
HidMediaModel* model = context;
|
||||||
|
|
||||||
// Header
|
// Header
|
||||||
|
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);
|
canvas_set_font(canvas, FontPrimary);
|
||||||
elements_multiline_text_aligned(canvas, 17, 3, AlignLeft, AlignTop, "Media");
|
elements_multiline_text_aligned(canvas, 17, 3, AlignLeft, AlignTop, "Media");
|
||||||
canvas_set_font(canvas, FontSecondary);
|
canvas_set_font(canvas, FontSecondary);
|
||||||
@ -190,6 +194,9 @@ HidMedia* hid_media_alloc(Hid* hid) {
|
|||||||
view_set_draw_callback(hid_media->view, hid_media_draw_callback);
|
view_set_draw_callback(hid_media->view, hid_media_draw_callback);
|
||||||
view_set_input_callback(hid_media->view, hid_media_input_callback);
|
view_set_input_callback(hid_media->view, hid_media_input_callback);
|
||||||
|
|
||||||
|
with_view_model(
|
||||||
|
hid_media->view, HidMediaModel * model, { model->transport = hid->transport; }, true);
|
||||||
|
|
||||||
return hid_media;
|
return hid_media;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,6 +20,7 @@ typedef struct {
|
|||||||
bool left_mouse_held;
|
bool left_mouse_held;
|
||||||
bool right_mouse_pressed;
|
bool right_mouse_pressed;
|
||||||
bool connected;
|
bool connected;
|
||||||
|
HidTransport transport;
|
||||||
} HidMouseModel;
|
} HidMouseModel;
|
||||||
|
|
||||||
static void hid_mouse_draw_callback(Canvas* canvas, void* context) {
|
static void hid_mouse_draw_callback(Canvas* canvas, void* context) {
|
||||||
@ -27,11 +28,14 @@ static void hid_mouse_draw_callback(Canvas* canvas, void* context) {
|
|||||||
HidMouseModel* model = context;
|
HidMouseModel* model = context;
|
||||||
|
|
||||||
// Header
|
// Header
|
||||||
|
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);
|
canvas_set_font(canvas, FontPrimary);
|
||||||
elements_multiline_text_aligned(canvas, 17, 3, AlignLeft, AlignTop, "Mouse");
|
elements_multiline_text_aligned(canvas, 17, 3, AlignLeft, AlignTop, "Mouse");
|
||||||
canvas_set_font(canvas, FontSecondary);
|
canvas_set_font(canvas, FontSecondary);
|
||||||
@ -198,6 +202,9 @@ HidMouse* hid_mouse_alloc(Hid* hid) {
|
|||||||
view_set_draw_callback(hid_mouse->view, hid_mouse_draw_callback);
|
view_set_draw_callback(hid_mouse->view, hid_mouse_draw_callback);
|
||||||
view_set_input_callback(hid_mouse->view, hid_mouse_input_callback);
|
view_set_input_callback(hid_mouse->view, hid_mouse_input_callback);
|
||||||
|
|
||||||
|
with_view_model(
|
||||||
|
hid_mouse->view, HidMouseModel * model, { model->transport = hid->transport; }, true);
|
||||||
|
|
||||||
return hid_mouse;
|
return hid_mouse;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -16,6 +16,7 @@ typedef struct {
|
|||||||
bool connected;
|
bool connected;
|
||||||
bool running;
|
bool running;
|
||||||
uint8_t counter;
|
uint8_t counter;
|
||||||
|
HidTransport transport;
|
||||||
} HidMouseJigglerModel;
|
} HidMouseJigglerModel;
|
||||||
|
|
||||||
static void hid_mouse_jiggler_draw_callback(Canvas* canvas, void* context) {
|
static void hid_mouse_jiggler_draw_callback(Canvas* canvas, void* context) {
|
||||||
@ -23,11 +24,14 @@ static void hid_mouse_jiggler_draw_callback(Canvas* canvas, void* context) {
|
|||||||
HidMouseJigglerModel* model = context;
|
HidMouseJigglerModel* model = context;
|
||||||
|
|
||||||
// Header
|
// Header
|
||||||
|
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);
|
canvas_set_font(canvas, FontPrimary);
|
||||||
elements_multiline_text_aligned(canvas, 17, 3, AlignLeft, AlignTop, "Mouse Jiggler");
|
elements_multiline_text_aligned(canvas, 17, 3, AlignLeft, AlignTop, "Mouse Jiggler");
|
||||||
|
|
||||||
@ -120,6 +124,12 @@ HidMouseJiggler* hid_mouse_jiggler_alloc(Hid* hid) {
|
|||||||
hid_mouse_jiggler->timer = furi_timer_alloc(
|
hid_mouse_jiggler->timer = furi_timer_alloc(
|
||||||
hid_mouse_jiggler_timer_callback, FuriTimerTypePeriodic, hid_mouse_jiggler);
|
hid_mouse_jiggler_timer_callback, FuriTimerTypePeriodic, hid_mouse_jiggler);
|
||||||
|
|
||||||
|
with_view_model(
|
||||||
|
hid_mouse_jiggler->view,
|
||||||
|
HidMouseJigglerModel * model,
|
||||||
|
{ model->transport = hid->transport; },
|
||||||
|
true);
|
||||||
|
|
||||||
return hid_mouse_jiggler;
|
return hid_mouse_jiggler;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -19,6 +19,7 @@ typedef struct {
|
|||||||
bool ok_pressed;
|
bool ok_pressed;
|
||||||
bool connected;
|
bool connected;
|
||||||
bool is_cursor_set;
|
bool is_cursor_set;
|
||||||
|
HidTransport transport;
|
||||||
} HidTikTokModel;
|
} HidTikTokModel;
|
||||||
|
|
||||||
static void hid_tiktok_draw_callback(Canvas* canvas, void* context) {
|
static void hid_tiktok_draw_callback(Canvas* canvas, void* context) {
|
||||||
@ -26,11 +27,14 @@ static void hid_tiktok_draw_callback(Canvas* canvas, void* context) {
|
|||||||
HidTikTokModel* model = context;
|
HidTikTokModel* model = context;
|
||||||
|
|
||||||
// Header
|
// Header
|
||||||
|
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);
|
canvas_set_font(canvas, FontPrimary);
|
||||||
elements_multiline_text_aligned(canvas, 17, 3, AlignLeft, AlignTop, "TikTok");
|
elements_multiline_text_aligned(canvas, 17, 3, AlignLeft, AlignTop, "TikTok");
|
||||||
canvas_set_font(canvas, FontSecondary);
|
canvas_set_font(canvas, FontSecondary);
|
||||||
@ -207,6 +211,9 @@ HidTikTok* hid_tiktok_alloc(Hid* bt_hid) {
|
|||||||
view_set_draw_callback(hid_tiktok->view, hid_tiktok_draw_callback);
|
view_set_draw_callback(hid_tiktok->view, hid_tiktok_draw_callback);
|
||||||
view_set_input_callback(hid_tiktok->view, hid_tiktok_input_callback);
|
view_set_input_callback(hid_tiktok->view, hid_tiktok_input_callback);
|
||||||
|
|
||||||
|
with_view_model(
|
||||||
|
hid_tiktok->view, HidTikTokModel * model, { model->transport = bt_hid->transport; }, true);
|
||||||
|
|
||||||
return hid_tiktok;
|
return hid_tiktok;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user