| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139 |
- #include "send_view.h"
- #include <furi.h>
- #include <gui/elements.h>
- #include <notification/notification.h>
- #include <notification/notification_messages.h>
- #include <furi_hal_serial_control.h>
- #include <furi_hal_serial.h>
- #include <string.h>
- #include <stdio.h>
- typedef enum ESerialCommand {
- ESerialCommand_Send
- } ESerialCommand;
- struct SendView {
- View* view;
- FuriHalSerialHandle* serial_handle;
- };
- typedef struct {
- bool right_pressed;
- bool connected;
- } SendViewModel;
- static void Shake(void) {
- NotificationApp* notification = furi_record_open(RECORD_NOTIFICATION);
- notification_message(notification, &sequence_single_vibro);
- furi_record_close(RECORD_NOTIFICATION);
- }
- void send_serial_command_send(FuriHalSerialHandle* serial_handle, ESerialCommand command) {
- uint8_t data[1] = {0};
- char name[10] = "send";
- int length = strlen(name);
- for(int i = 0; i < length; i++) {
- switch(command) {
- case ESerialCommand_Send:
- data[0] = name[i];
- break;
- default:
- return;
- };
- furi_hal_serial_tx(serial_handle, data, 1);
- }
- }
- static void send_view_draw_callback(Canvas* canvas, void* context) {
- furi_assert(context);
- SendViewModel* model = context;
- canvas_clear(canvas);
- canvas_set_color(canvas, ColorBlack);
- canvas_draw_str_aligned(canvas, 64, 0, AlignCenter, AlignTop, "SEND MODULE");
- canvas_draw_line(canvas, 0, 10, 128, 10);
- canvas_draw_str_aligned(canvas, 64, 15, AlignCenter, AlignTop, "Press right to send IFTTT");
- canvas_draw_str_aligned(canvas, 64, 25, AlignCenter, AlignTop, "command or press and hold");
- canvas_draw_str_aligned(canvas, 64, 35, AlignCenter, AlignTop, "back to return to the menu");
- // Right
- if(model->right_pressed) {
- }
- }
- static void send_view_process(SendView* send_view, InputEvent* event) {
- with_view_model(
- send_view->view,
- SendViewModel * model,
- {
- if(event->type == InputTypePress) {
- if(event->key == InputKeyUp) {
- } else if(event->key == InputKeyDown) {
- } else if(event->key == InputKeyLeft) {
- } else if(event->key == InputKeyRight) {
- model->right_pressed = true;
- Shake();
- send_serial_command_send(send_view->serial_handle, ESerialCommand_Send);
- } else if(event->key == InputKeyOk) {
- } else if(event->key == InputKeyBack) {
- }
- } else if(event->type == InputTypeRelease) {
- if(event->key == InputKeyUp) {
- } else if(event->key == InputKeyDown) {
- } else if(event->key == InputKeyLeft) {
- } else if(event->key == InputKeyRight) {
- model->right_pressed = false;
- } else if(event->key == InputKeyOk) {
- } else if(event->key == InputKeyBack) {
- }
- } else if(event->type == InputTypeShort) {
- if(event->key == InputKeyBack) {
- }
- }
- },
- true);
- }
- static bool send_view_input_callback(InputEvent* event, void* context) {
- furi_assert(context);
- SendView* send_view = context;
- bool consumed = false;
- if(event->type == InputTypeLong && event->key == InputKeyBack) {
- } else {
- send_view_process(send_view, event);
- consumed = true;
- }
- return consumed;
- }
- SendView* send_view_alloc(FuriHalSerialHandle* serial_handle) {
- SendView* send_view = malloc(sizeof(SendView));
- send_view->view = view_alloc();
- send_view->serial_handle = serial_handle;
- view_set_context(send_view->view, send_view);
- view_allocate_model(send_view->view, ViewModelTypeLocking, sizeof(SendViewModel));
- view_set_draw_callback(send_view->view, send_view_draw_callback);
- view_set_input_callback(send_view->view, send_view_input_callback);
- return send_view;
- }
- void send_view_free(SendView* send_view) {
- furi_assert(send_view);
- view_free(send_view->view);
- free(send_view);
- }
- View* send_view_get_view(SendView* send_view) {
- furi_assert(send_view);
- return send_view->view;
- }
- void send_view_set_data(SendView* send_view, bool connected) {
- furi_assert(send_view);
- with_view_model(
- send_view->view, SendViewModel * model, { model->connected = connected; }, true);
- }
|