UI: Add responsive layout calculation
This commit is contained in:
parent
a19ba1785e
commit
58cb6857a5
161
openrtx/src/ui.c
161
openrtx/src/ui.c
|
|
@ -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;
|
||||
|
|
|
|||
Loading…
Reference in New Issue