|
|
@@ -50,12 +50,16 @@ void xremote_transmit_draw_ir(Canvas* canvas, XRemoteTransmitModel* model) {
|
|
|
canvas_set_font(canvas, FontPrimary);
|
|
|
canvas_draw_str_aligned(canvas, 74, 5, AlignLeft, AlignTop, "Sending");
|
|
|
canvas_set_font(canvas, FontSecondary);
|
|
|
- canvas_draw_str_aligned(canvas, 74, 20, AlignLeft, AlignTop, "Infrared");
|
|
|
- canvas_draw_str_aligned(canvas, 74, 30, AlignLeft, AlignTop, model->name);
|
|
|
-
|
|
|
- char temp_str[18];
|
|
|
- snprintf(temp_str, 18, "%u", model->time);
|
|
|
- canvas_draw_str_aligned(canvas, 74, 40, AlignLeft, AlignTop, temp_str);
|
|
|
+ canvas_draw_str_aligned(canvas, 74, 15, AlignLeft, AlignTop, "Infrared");
|
|
|
+ canvas_draw_str_aligned(canvas, 74, 25, AlignLeft, AlignTop, model->name);
|
|
|
+
|
|
|
+ if (model->time == 0) {
|
|
|
+ canvas_draw_icon(canvas, 36, 2, &I_ir_ani_1_32x22);
|
|
|
+ } else if (model->time == 1) {
|
|
|
+ canvas_draw_icon(canvas, 36, 2, &I_ir_ani_2_32x22);
|
|
|
+ } else if (model->time == 2) {
|
|
|
+ canvas_draw_icon(canvas, 36, 2, &I_ir_ani_3_32x22);
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
void xremote_transmit_draw_pause(Canvas* canvas, XRemoteTransmitModel* model) {
|
|
|
@@ -66,12 +70,16 @@ void xremote_transmit_draw_pause(Canvas* canvas, XRemoteTransmitModel* model) {
|
|
|
canvas_set_font(canvas, FontPrimary);
|
|
|
canvas_draw_str_aligned(canvas, 74, 5, AlignLeft, AlignTop, "Waiting");
|
|
|
canvas_set_font(canvas, FontSecondary);
|
|
|
- canvas_draw_str_aligned(canvas, 74, 20, AlignLeft, AlignTop, "Sequence");
|
|
|
- canvas_draw_str_aligned(canvas, 74, 30, AlignLeft, AlignTop, model->name);
|
|
|
-
|
|
|
- char temp_str[18];
|
|
|
- snprintf(temp_str, 18, "%u", model->time);
|
|
|
- canvas_draw_str_aligned(canvas, 74, 40, AlignLeft, AlignTop, temp_str);
|
|
|
+ canvas_draw_str_aligned(canvas, 74, 15, AlignLeft, AlignTop, "Sequence");
|
|
|
+ canvas_draw_str_aligned(canvas, 74, 25, AlignLeft, AlignTop, model->name);
|
|
|
+
|
|
|
+ if (model->time == 0) {
|
|
|
+ canvas_draw_icon(canvas, 9, 28, &I_pause_ani_1_22x23);
|
|
|
+ } else if (model->time == 1) {
|
|
|
+ canvas_draw_icon(canvas, 9, 28, &I_pause_ani_2_22x23);
|
|
|
+ } else if (model->time == 2) {
|
|
|
+ canvas_draw_icon(canvas, 9, 28, &I_pause_ani_3_22x23);
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
void xremote_transmit_draw_subghz(Canvas* canvas, XRemoteTransmitModel* model) {
|
|
|
@@ -82,12 +90,16 @@ void xremote_transmit_draw_subghz(Canvas* canvas, XRemoteTransmitModel* model) {
|
|
|
canvas_set_font(canvas, FontPrimary);
|
|
|
canvas_draw_str_aligned(canvas, 74, 5, AlignLeft, AlignTop, "Sending");
|
|
|
canvas_set_font(canvas, FontSecondary);
|
|
|
- canvas_draw_str_aligned(canvas, 74, 20, AlignLeft, AlignTop, "SubGhz");
|
|
|
- canvas_draw_str_aligned(canvas, 74, 30, AlignLeft, AlignTop, model->name);
|
|
|
-
|
|
|
- char temp_str[18];
|
|
|
- snprintf(temp_str, 18, "%u", model->time);
|
|
|
- canvas_draw_str_aligned(canvas, 74, 40, AlignLeft, AlignTop, temp_str);
|
|
|
+ canvas_draw_str_aligned(canvas, 74, 15, AlignLeft, AlignTop, "SubGhz");
|
|
|
+ canvas_draw_str_aligned(canvas, 74, 25, AlignLeft, AlignTop, model->name);
|
|
|
+
|
|
|
+ if (model->time == 0) {
|
|
|
+ canvas_draw_icon(canvas, 15, 1, &I_sg_ani_1_19x13);
|
|
|
+ } else if (model->time == 1) {
|
|
|
+ canvas_draw_icon(canvas, 15, 1, &I_sg_ani_2_19x13);
|
|
|
+ } else if (model->time == 2) {
|
|
|
+ canvas_draw_icon(canvas, 15, 1, &I_sg_ani_3_19x13);
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
void xremote_transmit_draw(Canvas* canvas, XRemoteTransmitModel* model) {
|
|
|
@@ -98,6 +110,10 @@ void xremote_transmit_draw(Canvas* canvas, XRemoteTransmitModel* model) {
|
|
|
} else if(model->type == XRemoteRemoteItemTypePause) {
|
|
|
xremote_transmit_draw_pause(canvas, model);
|
|
|
}
|
|
|
+ if (model->time > 2) {
|
|
|
+ model->time = 0;
|
|
|
+ }
|
|
|
+ elements_button_right(canvas, "exit");
|
|
|
}
|
|
|
|
|
|
bool xremote_transmit_input(InputEvent* event, void* context) {
|
|
|
@@ -106,6 +122,7 @@ bool xremote_transmit_input(InputEvent* event, void* context) {
|
|
|
if(event->type == InputTypeRelease) {
|
|
|
switch(event->key) {
|
|
|
case InputKeyBack:
|
|
|
+ case InputKeyRight:
|
|
|
with_view_model(
|
|
|
instance->view,
|
|
|
XRemoteTransmitModel * model,
|
|
|
@@ -123,6 +140,16 @@ bool xremote_transmit_input(InputEvent* event, void* context) {
|
|
|
return true;
|
|
|
}
|
|
|
|
|
|
+void xremote_transmit_enter(void* context) {
|
|
|
+ furi_assert(context);
|
|
|
+ XRemoteTransmit* instance = (XRemoteTransmit*)context;
|
|
|
+ with_view_model(
|
|
|
+ instance->view,
|
|
|
+ XRemoteTransmitModel * model,
|
|
|
+ { xremote_transmit_model_init(model); },
|
|
|
+ true);
|
|
|
+}
|
|
|
+
|
|
|
XRemoteTransmit* xremote_transmit_alloc() {
|
|
|
XRemoteTransmit* instance = malloc(sizeof(XRemoteTransmit));
|
|
|
instance->view = view_alloc();
|
|
|
@@ -130,7 +157,7 @@ XRemoteTransmit* xremote_transmit_alloc() {
|
|
|
view_set_context(instance->view, instance);
|
|
|
view_set_draw_callback(instance->view, (ViewDrawCallback)xremote_transmit_draw);
|
|
|
view_set_input_callback(instance->view, xremote_transmit_input);
|
|
|
- view_set_enter_callback(instance->view, xremote_transmit_enter);
|
|
|
+ //view_set_enter_callback(instance->view, xremote_transmit_enter);
|
|
|
|
|
|
with_view_model(
|
|
|
instance->view,
|
|
|
@@ -141,16 +168,6 @@ XRemoteTransmit* xremote_transmit_alloc() {
|
|
|
return instance;
|
|
|
}
|
|
|
|
|
|
-void xremote_transmit_enter(void* context) {
|
|
|
- furi_assert(context);
|
|
|
- XRemoteTransmit* instance = (XRemoteTransmit*)context;
|
|
|
- with_view_model(
|
|
|
- instance->view,
|
|
|
- XRemoteTransmitModel * model,
|
|
|
- { xremote_transmit_model_init(model); },
|
|
|
- true);
|
|
|
-}
|
|
|
-
|
|
|
void xremote_transmit_free(XRemoteTransmit* instance) {
|
|
|
furi_assert(instance);
|
|
|
|