Table of Contents

Laboratorul 05. Grafica

Despre LVGL

LVGL (Light and Versatile Graphics Library) este o biblioteca open-source pentru interfete grafice (GUI) pe dispozitive embedded.

Exercitii

1. Porning de la config-ul hacktorwatch:lvgl. In acest config aplicatia HacktorWatch (CONFIG_HACKTORWATCH_REV2) este activata in mod implicit.

2. Apelati functia “lv_example_checkbox_1()” din setul de functii oferite ca exemplu de biblioteca LVGL. Stergeti partea de cod care face label-ul “Hello!” folosita la ex. 1.

3. Activati driver-ul de touchscreen CST816S si suportul de touchscreen din LVGL

4. Rulati urmatorul cod care va crea un obiect “circle” folosit ca parinte pentru mai multe elemente - o coloana cu un label si un checkbox - aflate in interiorul cercului. Mai jos este o diagrama cu relatia dintre ele.

Adaugati in hacktorwatch_main.c urmatoarea functie si apelati functia din main().

static void hacktorwatch_count_steps(void)
{
    circle = lv_obj_create(lv_screen_active());

    lv_obj_set_style_radius(circle, LV_RADIUS_CIRCLE, 0); 
    lv_obj_set_size(circle, 230, 230);
    lv_obj_align(circle, LV_ALIGN_CENTER, 0, 0); 

    lv_obj_t * column1 = lv_obj_create(circle);
    lv_obj_set_flex_flow(column1, LV_FLEX_FLOW_COLUMN);
    lv_obj_set_size(column1, lv_pct(80), lv_pct(60));
    lv_obj_align(column1, LV_ALIGN_CENTER, 0, 0); 

    cb_count = lv_checkbox_create(column1);
    lv_checkbox_set_text(cb_count, "Count");
    lv_obj_add_state(cb_count, LV_STATE_CHECKED);
    lv_obj_add_event_cb(cb_count, event_handler, LV_EVENT_ALL, NULL);

    label_steps = lv_label_create(column1);
    lv_obj_set_width(label_steps, lv_pct(100));
    lv_label_set_text_fmt(label_steps, "Steps: %i", total_steps);

    lv_obj_update_layout(circle);
}

Pentru a simula pasii numarati de accelerometru, vom instantia un timer care se va executa o data pe secunda. La fiecare executie a timer-ului, vom incrementa variabila “total_steps” si vom face refresh la label pentru a afisa noul count pe display. Definiti urmatoare functie in fisierul hacktorwatch_main.c:

static void hacktorwatch_inc_step(lv_timer_t * timer)
{   
    int should_inc;

    should_inc = lv_obj_get_state(cb_count) & LV_STATE_CHECKED;
    if (should_inc) {
        total_steps++;
        lv_label_set_text_fmt(label_steps, "Steps: %u", total_steps);
    }
}

In main(), instantiati timer-ul:

  lv_timer_create(hacktorwatch_inc_step, 1000, NULL);

Resurse