| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160 |
- #include "weather_station_receiver.h"
- #include "../weather_station_app_i.h"
- #include "weather_station_icons.h"
- #include "../protocols/ws_generic.h"
- #include <input/input.h>
- #include <gui/elements.h>
- #define abs(x) ((x) > 0 ? (x) : -(x))
- struct WSReceiverInfo {
- View* view;
- };
- typedef struct {
- FuriString* protocol_name;
- WSBlockGeneric* generic;
- } WSReceiverInfoModel;
- void ws_view_receiver_info_update(WSReceiverInfo* ws_receiver_info, FlipperFormat* fff) {
- furi_assert(ws_receiver_info);
- furi_assert(fff);
- with_view_model(
- ws_receiver_info->view,
- WSReceiverInfoModel * model,
- {
- flipper_format_rewind(fff);
- flipper_format_read_string(fff, "Protocol", model->protocol_name);
- ws_block_generic_deserialize(model->generic, fff);
- },
- true);
- }
- void ws_view_receiver_info_draw(Canvas* canvas, WSReceiverInfoModel* model) {
- char buffer[64];
- canvas_clear(canvas);
- canvas_set_color(canvas, ColorBlack);
- canvas_set_font(canvas, FontSecondary);
- snprintf(
- buffer,
- sizeof(buffer),
- "%s %db",
- furi_string_get_cstr(model->protocol_name),
- model->generic->data_count_bit);
- canvas_draw_str(canvas, 5, 8, buffer);
- if(model->generic->channel != WS_NO_CHANNEL) {
- snprintf(buffer, sizeof(buffer), "Ch: %01d", model->generic->channel);
- canvas_draw_str(canvas, 105, 8, buffer);
- }
- if(model->generic->id != WS_NO_ID) {
- snprintf(buffer, sizeof(buffer), "Sn: 0x%02lX", model->generic->id);
- canvas_draw_str(canvas, 5, 20, buffer);
- }
- if(model->generic->btn != WS_NO_BTN) {
- snprintf(buffer, sizeof(buffer), "Btn: %01d", model->generic->btn);
- canvas_draw_str(canvas, 62, 20, buffer);
- }
- if(model->generic->battery_low != WS_NO_BATT) {
- snprintf(
- buffer, sizeof(buffer), "Batt: %s", (!model->generic->battery_low ? "ok" : "low"));
- canvas_draw_str(canvas, 90, 20, buffer);
- }
- snprintf(buffer, sizeof(buffer), "Data: 0x%llX", model->generic->data);
- canvas_draw_str(canvas, 5, 32, buffer);
- elements_bold_rounded_frame(canvas, 2, 37, 123, 25);
- canvas_set_font(canvas, FontPrimary);
- if(model->generic->temp != WS_NO_TEMPERATURE) {
- canvas_draw_icon(canvas, 18, 42, &I_Therm_7x16);
- snprintf(buffer, sizeof(buffer), "%3.1f C", (double)model->generic->temp);
- canvas_draw_str_aligned(canvas, 63, 46, AlignRight, AlignTop, buffer);
- canvas_draw_circle(canvas, 55, 45, 1);
- }
- if(model->generic->humidity != WS_NO_HUMIDITY) {
- canvas_draw_icon(canvas, 75, 42, &I_Humid_10x15);
- snprintf(buffer, sizeof(buffer), "%d%%", model->generic->humidity);
- canvas_draw_str(canvas, 91, 54, buffer);
- }
- }
- bool ws_view_receiver_info_input(InputEvent* event, void* context) {
- furi_assert(context);
- //WSReceiverInfo* ws_receiver_info = context;
- if(event->key == InputKeyBack) {
- return false;
- }
- return true;
- }
- void ws_view_receiver_info_enter(void* context) {
- furi_assert(context);
- }
- void ws_view_receiver_info_exit(void* context) {
- furi_assert(context);
- WSReceiverInfo* ws_receiver_info = context;
- with_view_model(
- ws_receiver_info->view,
- WSReceiverInfoModel * model,
- { furi_string_reset(model->protocol_name); },
- false);
- }
- WSReceiverInfo* ws_view_receiver_info_alloc() {
- WSReceiverInfo* ws_receiver_info = malloc(sizeof(WSReceiverInfo));
- // View allocation and configuration
- ws_receiver_info->view = view_alloc();
- view_allocate_model(ws_receiver_info->view, ViewModelTypeLocking, sizeof(WSReceiverInfoModel));
- view_set_context(ws_receiver_info->view, ws_receiver_info);
- view_set_draw_callback(ws_receiver_info->view, (ViewDrawCallback)ws_view_receiver_info_draw);
- view_set_input_callback(ws_receiver_info->view, ws_view_receiver_info_input);
- view_set_enter_callback(ws_receiver_info->view, ws_view_receiver_info_enter);
- view_set_exit_callback(ws_receiver_info->view, ws_view_receiver_info_exit);
- with_view_model(
- ws_receiver_info->view,
- WSReceiverInfoModel * model,
- {
- model->generic = malloc(sizeof(WSBlockGeneric));
- model->protocol_name = furi_string_alloc();
- },
- true);
- return ws_receiver_info;
- }
- void ws_view_receiver_info_free(WSReceiverInfo* ws_receiver_info) {
- furi_assert(ws_receiver_info);
- with_view_model(
- ws_receiver_info->view,
- WSReceiverInfoModel * model,
- {
- furi_string_free(model->protocol_name);
- free(model->generic);
- },
- false);
- view_free(ws_receiver_info->view);
- free(ws_receiver_info);
- }
- View* ws_view_receiver_info_get_view(WSReceiverInfo* ws_receiver_info) {
- furi_assert(ws_receiver_info);
- return ws_receiver_info->view;
- }
|