| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- #include <furi.h>
- #include "../desktop_i.h"
- #include "desktop_first_start.h"
- void desktop_first_start_set_callback(
- DesktopFirstStartView* first_start_view,
- DesktopFirstStartViewCallback callback,
- void* context) {
- furi_assert(first_start_view);
- furi_assert(callback);
- first_start_view->callback = callback;
- first_start_view->context = context;
- }
- void desktop_first_start_render(Canvas* canvas, void* model) {
- DesktopFirstStartViewModel* m = model;
- canvas_clear(canvas);
- canvas_set_color(canvas, ColorBlack);
- canvas_set_font(canvas, FontSecondary);
- uint8_t width = canvas_width(canvas);
- uint8_t height = canvas_height(canvas);
- const char* my_name = furi_hal_version_get_name_ptr();
- if(m->page == 0) {
- canvas_draw_icon(canvas, 0, height - 48, &I_DolphinFirstStart0_70x53);
- elements_multiline_text_framed(canvas, 75, 20, "Hey m8,\npress > to\ncontinue");
- } else if(m->page == 1) {
- canvas_draw_icon(canvas, 0, height - 48, &I_DolphinFirstStart1_59x53);
- elements_multiline_text_framed(canvas, 64, 20, "First Of All,\n... >");
- } else if(m->page == 2) {
- canvas_draw_icon(canvas, 0, height - 48, &I_DolphinFirstStart2_59x51);
- elements_multiline_text_framed(canvas, 64, 20, "Thank you\nfor your\nsupport! >");
- } else if(m->page == 3) {
- canvas_draw_icon(canvas, width - 57, height - 48, &I_DolphinFirstStart3_57x48);
- elements_multiline_text_framed(canvas, 0, 20, "Kickstarter\ncampaign\nwas INSANE! >");
- } else if(m->page == 4) {
- canvas_draw_icon(canvas, width - 67, height - 50, &I_DolphinFirstStart4_67x53);
- elements_multiline_text_framed(canvas, 0, 17, "Now\nallow me\nto introduce\nmyself >");
- } else if(m->page == 5) {
- char buf[64];
- snprintf(
- buf,
- 64,
- "%s %s%s",
- "I am",
- my_name ? my_name : "Unknown",
- ",\ncyberdesktop\nliving in your\npocket >");
- canvas_draw_icon(canvas, 0, height - 48, &I_DolphinFirstStart5_54x49);
- elements_multiline_text_framed(canvas, 60, 17, buf);
- } else if(m->page == 6) {
- canvas_draw_icon(canvas, 0, height - 48, &I_DolphinFirstStart6_58x54);
- elements_multiline_text_framed(
- canvas, 63, 17, "I can grow\nsmart'n'cool\nif you use me\noften >");
- } else if(m->page == 7) {
- canvas_draw_icon(canvas, width - 61, height - 48, &I_DolphinFirstStart7_61x51);
- elements_multiline_text_framed(
- canvas, 0, 17, "As long as\nyou read, write\nand emulate >");
- } else if(m->page == 8) {
- canvas_draw_icon(canvas, width - 56, height - 48, &I_DolphinFirstStart8_56x51);
- elements_multiline_text_framed(
- canvas, 0, 17, "You can check\nmy level and\nmood in the\nPassport menu");
- }
- }
- View* desktop_first_start_get_view(DesktopFirstStartView* first_start_view) {
- furi_assert(first_start_view);
- return first_start_view->view;
- }
- bool desktop_first_start_input(InputEvent* event, void* context) {
- furi_assert(event);
- DesktopFirstStartView* first_start_view = context;
- if(event->type == InputTypeShort) {
- DesktopFirstStartViewModel* model = view_get_model(first_start_view->view);
- if(event->key == InputKeyLeft) {
- if(model->page > 0) model->page--;
- } else if(event->key == InputKeyRight) {
- uint32_t page = ++model->page;
- if(page > 8) {
- first_start_view->callback(DesktopFirstStartCompleted, first_start_view->context);
- }
- }
- view_commit_model(first_start_view->view, true);
- }
- return true;
- }
- DesktopFirstStartView* desktop_first_start_alloc() {
- DesktopFirstStartView* first_start_view = furi_alloc(sizeof(DesktopFirstStartView));
- first_start_view->view = view_alloc();
- view_allocate_model(
- first_start_view->view, ViewModelTypeLocking, sizeof(DesktopFirstStartViewModel));
- view_set_context(first_start_view->view, first_start_view);
- view_set_draw_callback(first_start_view->view, (ViewDrawCallback)desktop_first_start_render);
- view_set_input_callback(first_start_view->view, desktop_first_start_input);
- return first_start_view;
- }
- void desktop_first_start_free(DesktopFirstStartView* first_start_view) {
- furi_assert(first_start_view);
- view_free(first_start_view->view);
- free(first_start_view);
- }
|