UI: Add responsive layout calculation

This commit is contained in:
Federico Amedeo Izzo 2020-10-31 18:12:44 +01:00 committed by Niccolò Izzo
parent a19ba1785e
commit 58cb6857a5
1 changed files with 145 additions and 16 deletions

View File

@ -42,16 +42,24 @@
* bottom_status_bar (16 px) 8 pt font with 4 px vertical padding
*
*
* 128x64 display (GD77)
* 128x64 display (GD-77)
*
* top_status_bar (8 px) 8 pt font without vertical padding
*
* Line 1 (16px)
* Line 2 (16px)
* Line 3 (16px)
* Line 1 (20px) 16 pt font with 2 px vertical padding
* Line 2 (20px) 16 pt font with 2 px vertical padding
* Line 3 (8px) 8 pt font without vertical padding
*
* bottom_status_bar (8 px) 8 pt font without vertical padding
*
*
* 128x48 display (RD-5R)
*
* top_status_bar (8 px) 8 pt font without vertical padding
*
* Line 1 (20px) 16 pt font with 2 px vertical padding
* Line 2 (20px) 16 pt font with 2 px vertical padding
*
*/
#include <stdio.h>
@ -60,40 +68,154 @@
#include "rtc.h"
#include "platform.h"
typedef struct layout_t
{
point_t top_pos;
point_t line1_pos;
point_t line2_pos;
point_t line3_pos;
point_t bottom_pos;
fontSize_t top_font;
fontSize_t line1_font;
fontSize_t line2_font;
fontSize_t line3_font;
fontSize_t bottom_font;
} layout_t;
layout_t layout;
bool layout_ready = false;
color_t color_white = {255, 255, 255};
layout_t _ui_calculateLayout()
{
// Variables needed to calculate positions
uint16_t top_h = 0;
uint16_t top_pad = 0;
uint16_t line1_h = 0;
uint16_t line2_h = 0;
uint16_t line3_h = 0;
uint16_t line_pad = 0;
uint16_t bottom_pad = 0;
fontSize_t top_font = 0;
fontSize_t line1_font = 0;
fontSize_t line2_font = 0;
fontSize_t line3_font = 0;
fontSize_t bottom_font = 0;
// Calculate UI layout depending on vertical resolution
// Tytera MD380, MD-UV380
if (SCREEN_HEIGHT >= 128)
{
// Height and padding shown in diagram at beginning of file
top_h = 16;
top_pad = 4;
line1_h = 32;
line2_h = 32;
line3_h = 32;
line_pad = 8;
bottom_pad = 4;
// Top bar font: 8 pt
top_font = FONT_SIZE_1;
// Middle line fonts: 16 pt
line1_font = FONT_SIZE_3;
line2_font = FONT_SIZE_3;
line3_font = FONT_SIZE_3;
// Bottom bar font: 8 pt
bottom_font = FONT_SIZE_1;
}
// Radioddity GD-77
else if (SCREEN_HEIGHT >= 64)
{
// Height and padding shown in diagram at beginning of file
top_h = 8;
top_pad = 0;
line1_h = 20;
line2_h = 20;
line3_h = 0;
line_pad = 2;
bottom_pad = 0;
// Top bar font: 8 pt
top_font = FONT_SIZE_1;
// Middle line fonts: 16, 16, 8 pt
line1_font = FONT_SIZE_3;
line2_font = FONT_SIZE_3;
line3_font = FONT_SIZE_1;
// Bottom bar font: 8 pt
bottom_font = FONT_SIZE_1;
}
else if (SCREEN_HEIGHT >= 48)
{
// Height and padding shown in diagram at beginning of file
top_h = 8;
top_pad = 0;
line1_h = 20;
line2_h = 20;
line3_h = 0;
line_pad = 2;
bottom_pad = 0;
// Top bar font: 8 pt
top_font = FONT_SIZE_1;
// Middle line fonts: 16, 16
line1_font = FONT_SIZE_3;
line2_font = FONT_SIZE_3;
// Not present in this UI
line3_font = 0;
bottom_font = 0;
}
else
{
printf("ERROR: Unsupported vertical resolution: %d\n", SCREEN_HEIGHT);
}
// Calculate printing positions
point_t top_pos = {0, top_pad};
point_t line1_pos = {0, top_h + line_pad};
point_t line2_pos = {0, top_h + line1_h + line_pad};
point_t line3_pos = {0, top_h + line1_h + line2_h + line_pad};
point_t bottom_pos = {0, top_h + line1_h + line2_h + line3_h + bottom_pad};
layout_t new_layout = {
top_pos,
line1_pos,
line2_pos,
line3_pos,
bottom_pos,
top_font,
line1_font,
line2_font,
line3_font,
bottom_font,
};
return new_layout;
}
void ui_drawTopBar()
{
// Top bar printing position, uses 4 px padding
point_t top_bar_pos = {0, 5};
// Print clock on top bar
char clock_buf[6] = "";
curTime_t time = rtc_getTime();
snprintf(clock_buf, sizeof(clock_buf), "%2d:%2d", time.hour, time.minute);
gfx_print(top_bar_pos, clock_buf, FONT_SIZE_1, TEXT_ALIGN_CENTER, color_white);
gfx_print(layout.top_pos, clock_buf, layout.top_font, TEXT_ALIGN_CENTER, color_white);
// Print battery voltage on top bar, use 4 px padding
// TODO: Replace with battery icon
char bat_buf[6] = "";
float v_bat = platform_getVbat();
snprintf(bat_buf, sizeof(bat_buf), "%.1fV ", v_bat);
gfx_print(top_bar_pos, bat_buf, FONT_SIZE_1, TEXT_ALIGN_RIGHT, color_white);
gfx_print(layout.top_pos, bat_buf, layout.top_font, TEXT_ALIGN_RIGHT, color_white);
}
void ui_drawVFO(state_t state)
{
// Middle line printing positions, uses 8 px padding
point_t line1_pos = {0, 25};
point_t line2_pos = {0, 57};
point_t line3_pos = {0, 89};
// Print VFO frequencies
char freq_buf[20] = "";
snprintf(freq_buf, sizeof(freq_buf), "Rx: %09.5f", state.rx_freq);
gfx_print(line1_pos, freq_buf, FONT_SIZE_3, TEXT_ALIGN_CENTER, color_white);
gfx_print(layout.line1_pos, freq_buf, layout.line1_font, TEXT_ALIGN_CENTER, color_white);
snprintf(freq_buf, sizeof(freq_buf), "Tx: %09.5f", state.tx_freq);
gfx_print(line2_pos, freq_buf, FONT_SIZE_3, TEXT_ALIGN_CENTER, color_white);
gfx_print(layout.line2_pos, freq_buf, layout.line2_font, TEXT_ALIGN_CENTER, color_white);
}
void ui_drawMainScreen(state_t state)
@ -104,10 +226,17 @@ void ui_drawMainScreen(state_t state)
void ui_init()
{
layout = _ui_calculateLayout();
layout_ready = true;
}
bool ui_update(state_t state, uint32_t keys)
{
if(!layout_ready)
{
layout = _ui_calculateLayout();
layout_ready = true;
}
gfx_clearScreen();
ui_drawMainScreen(state);
return true;