kopia lustrzana https://github.com/OpenRTX/OpenRTX
* Combine S-meter and Level meter
* Make squelch bar always yellow * Include font height in s-meter total height Correct bottom bar printing position Increase bottom bar size on GD-77replace/336c061ec87c6c8a39b0956dc74607ba33f1dadc
rodzic
118c514081
commit
882a657359
|
@ -303,25 +303,16 @@ void gfx_drawBattery(point_t start, uint16_t width, uint16_t height, uint8_t per
|
|||
void gfx_drawSmeter(point_t start, uint16_t width, uint16_t height, float rssi, float squelch, color_t color);
|
||||
|
||||
/**
|
||||
* Function to draw Smeter of arbitrary size.
|
||||
* Function to draw Smeter + level meter of arbitrary size.
|
||||
* Version without squelch bar for digital protocols
|
||||
* Starting coordinates are relative to the top left point.
|
||||
* @param start: Smeter start point, in pixel coordinates.
|
||||
* @param width: Smeter width
|
||||
* @param height: Smeter height
|
||||
* @param rssi: rssi level in dBm
|
||||
*/
|
||||
void gfx_drawSmeterNoSquelch(point_t start, uint16_t width, uint16_t height, float rssi);
|
||||
|
||||
/**
|
||||
* Function to draw level meter of arbitrary size.
|
||||
* Starting coordinates are relative to the top left point.
|
||||
* @param start: level meter start point, in pixel coordinates.
|
||||
* @param width: level meter width
|
||||
* @param height: level meter height
|
||||
* @param level: level in range {0, 255}
|
||||
*/
|
||||
void gfx_drawLevelMeter(point_t start, uint16_t width, uint16_t height, uint8_t level);
|
||||
void gfx_drawSmeterLevel(point_t start, uint16_t width, uint16_t height, float rssi, uint8_t level);
|
||||
|
||||
/**
|
||||
* Function to draw GPS SNR bar graph of arbitrary size.
|
||||
|
|
|
@ -121,6 +121,7 @@ typedef struct layout_t
|
|||
uint16_t line3_h;
|
||||
uint16_t menu_h;
|
||||
uint16_t bottom_h;
|
||||
uint16_t bottom_pad;
|
||||
uint16_t status_v_pad;
|
||||
uint16_t horizontal_pad;
|
||||
uint16_t text_v_offset;
|
||||
|
|
|
@ -403,7 +403,6 @@ point_t gfx_printBuffer(point_t start, fontSize_t size, textAlign_t alignment,
|
|||
uint16_t line_size = get_line_size(f, buf, len);
|
||||
uint16_t reset_x = get_reset_x(alignment, line_size, start.x);
|
||||
start.x = reset_x;
|
||||
|
||||
// Save initial start.y value to calculate vertical size
|
||||
uint16_t saved_start_y = start.y;
|
||||
uint16_t line_h = 0;
|
||||
|
@ -612,14 +611,14 @@ void gfx_drawBattery(point_t start, uint16_t width, uint16_t height,
|
|||
* Function to draw RSSI-meter of arbitrary size
|
||||
* starting coordinates are relative to the top left point.
|
||||
*
|
||||
* 1 2 3 4 5 6 7 8 9 +10 +20|
|
||||
* * * * * * * * * * * *|
|
||||
* *************** <-- Squelch |
|
||||
* *************** |
|
||||
* ****************************************** |
|
||||
* ****************************************** <- RSSI |
|
||||
* ****************************************** | <-- Height (px)
|
||||
* ****************************************** |
|
||||
* **************** <-- Squelch |
|
||||
* *************** |
|
||||
* * * * * * * * * * * *|
|
||||
* 1 2 3 4 5 6 7 8 9 +10 +20|
|
||||
* _________________________________________________________________
|
||||
*
|
||||
* ^
|
||||
|
@ -635,54 +634,62 @@ void gfx_drawSmeter(point_t start, uint16_t width, uint16_t height, float rssi,
|
|||
color_t yellow = {250, 180, 19 , 255};
|
||||
color_t red = {255, 0, 0 , 255};
|
||||
|
||||
fontSize_t font = FONT_SIZE_5PT;
|
||||
uint8_t font_height = gfx_getFontHeight(font);
|
||||
uint16_t bar_height = (height - 3 - font_height);
|
||||
|
||||
// S-level marks and numbers
|
||||
for(int i = 0; i < 11; i++)
|
||||
for(int i = 0; i < 12; i++)
|
||||
{
|
||||
color_t color = (i % 3 == 0) ? yellow : white;
|
||||
color = (i > 9) ? red : color;
|
||||
point_t pixel_pos = {start.x + i * (width - 1) / 11, start.y};
|
||||
gfx_setPixel(pixel_pos, color);
|
||||
pixel_pos.y += height;
|
||||
if (i == 10) {
|
||||
pixel_pos.x -= 8;
|
||||
gfx_print(pixel_pos, FONT_SIZE_5PT, TEXT_ALIGN_LEFT, color, "+%d", i);
|
||||
gfx_print(pixel_pos, font, TEXT_ALIGN_LEFT, color, "+%d", i);
|
||||
}
|
||||
else if(i == 11){
|
||||
pixel_pos.x -= 10;
|
||||
gfx_print(pixel_pos, font, TEXT_ALIGN_LEFT, red, "+20");
|
||||
}
|
||||
else
|
||||
gfx_print(pixel_pos, FONT_SIZE_5PT, TEXT_ALIGN_LEFT, color, "%d", i);
|
||||
gfx_print(pixel_pos, font, TEXT_ALIGN_LEFT, color, "%d", i);
|
||||
if (i == 10) {
|
||||
pixel_pos.x += 8;
|
||||
}
|
||||
pixel_pos.y += height;
|
||||
gfx_setPixel(pixel_pos, color);
|
||||
}
|
||||
|
||||
point_t pixel_pos = {start.x + width - 11, start.y};
|
||||
gfx_print(pixel_pos, FONT_SIZE_5PT, TEXT_ALIGN_LEFT, red, "+20");
|
||||
pixel_pos.x += 10;
|
||||
pixel_pos.y += height;
|
||||
gfx_setPixel(pixel_pos, red);
|
||||
// Squelch bar
|
||||
uint16_t squelch_height = bar_height / 3 ;
|
||||
uint16_t squelch_width = width * squelch;
|
||||
point_t squelch_pos = {start.x, start.y + 2};
|
||||
gfx_drawRect(squelch_pos, squelch_width, squelch_height, color, true);
|
||||
|
||||
// RSSI bar
|
||||
uint16_t rssi_height = height * 2 / 3;
|
||||
uint16_t rssi_height = bar_height * 2 / 3;
|
||||
float s_level = (127.0f + rssi) / 6.0f;
|
||||
uint16_t rssi_width = (s_level < 0.0f) ? 0 : (s_level * (width - 1) / 11);
|
||||
rssi_width = (s_level > 10.0f) ? width : rssi_width;
|
||||
point_t rssi_pos = { start.x, start.y + 1 };
|
||||
point_t rssi_pos = { start.x, start.y + 2 + squelch_height};
|
||||
gfx_drawRect(rssi_pos, rssi_width, rssi_height, white, true);
|
||||
|
||||
// Squelch bar
|
||||
uint16_t squelch_height = height / 3 - 1;
|
||||
uint16_t squelch_width = width * squelch;
|
||||
point_t squelch_pos = { start.x, start.y + 1 + rssi_height };
|
||||
gfx_drawRect(squelch_pos, squelch_width, squelch_height, color, true);
|
||||
}
|
||||
|
||||
/*
|
||||
* Function to draw RSSI-meter of arbitrary size
|
||||
* Function to draw RSSI-meter with level-meter of arbitrary size
|
||||
* Version without squelch bar for digital protocols
|
||||
* starting coordinates are relative to the top left point.
|
||||
*
|
||||
* * * * * *|
|
||||
* ****************************************** |
|
||||
* ****************************************** <- RSSI |
|
||||
* ****************************************** <- level |
|
||||
* ****************************************** |
|
||||
* ****************************************** |
|
||||
* * * * * *|
|
||||
* ****************************************** | <-- Height (px)
|
||||
* ****************************************** <- RSSI |
|
||||
* ****************************************** |
|
||||
* ****************************************** |
|
||||
* 1 2 3 4 5 6 7 8 9 +10 +20|
|
||||
* _________________________________________________________________
|
||||
|
@ -693,81 +700,57 @@ void gfx_drawSmeter(point_t start, uint16_t width, uint16_t height, float rssi,
|
|||
* Width (px)
|
||||
*
|
||||
*/
|
||||
void gfx_drawSmeterNoSquelch(point_t start, uint16_t width, uint16_t height, float rssi)
|
||||
void gfx_drawSmeterLevel(point_t start, uint16_t width, uint16_t height, float rssi,
|
||||
uint8_t level)
|
||||
{
|
||||
color_t red = {255, 0, 0 , 255};
|
||||
color_t green = {0, 255, 0, 255};
|
||||
color_t white = {255, 255, 255, 255};
|
||||
color_t yellow = {250, 180, 19 , 255};
|
||||
color_t red = {255, 0, 0 , 255};
|
||||
|
||||
fontSize_t font = FONT_SIZE_5PT;
|
||||
uint8_t font_height = gfx_getFontHeight(font);
|
||||
uint16_t bar_height = (height - 6 - font_height) / 2;
|
||||
|
||||
// Level meter marks
|
||||
for(int i = 0; i <= 4; i++)
|
||||
{
|
||||
point_t pixel_pos = {start.x + i * (width - 1) / 4, start.y};
|
||||
gfx_setPixel(pixel_pos, white);
|
||||
pixel_pos.y += (bar_height + 3);
|
||||
gfx_setPixel(pixel_pos, white);
|
||||
}
|
||||
// Level bar
|
||||
uint16_t level_width = (level / 255 * width);
|
||||
point_t level_pos = { start.x, start.y + 2 };
|
||||
gfx_drawRect(level_pos, level_width, bar_height, green, true);
|
||||
// RSSI bar
|
||||
float s_level = (127.0f + rssi) / 6.0f;
|
||||
uint16_t rssi_width = (s_level < 0.0f) ? 0 : (s_level * (width - 1) / 11);
|
||||
rssi_width = (s_level > 10.0f) ? width : rssi_width;
|
||||
point_t rssi_pos = {start.x, start.y + 5 + bar_height};
|
||||
gfx_drawRect(rssi_pos, rssi_width, bar_height, white, true);
|
||||
// S-level marks and numbers
|
||||
for(int i = 0; i < 11; i++)
|
||||
for(int i = 0; i < 12; i++)
|
||||
{
|
||||
color_t color = (i % 3 == 0) ? yellow : white;
|
||||
color = (i > 9) ? red : color;
|
||||
point_t pixel_pos = {start.x + i * (width - 1) / 11, start.y};
|
||||
pixel_pos.y += ((height - 1) + font_height);
|
||||
point_t pixel_pos = {start.x + i * (width - 1) / 11,
|
||||
start.y + height};
|
||||
if (i == 10) {
|
||||
pixel_pos.x -= 8;
|
||||
gfx_print(pixel_pos, font, TEXT_ALIGN_LEFT, color, "+%d", i);
|
||||
}
|
||||
else if(i == 11){
|
||||
pixel_pos.x -= 10;
|
||||
gfx_print(pixel_pos, font, TEXT_ALIGN_LEFT, red, "+20");
|
||||
}
|
||||
else
|
||||
gfx_print(pixel_pos, font, TEXT_ALIGN_LEFT, color, "%d", i);
|
||||
if (i == 10) {
|
||||
pixel_pos.x += 8;
|
||||
}
|
||||
}
|
||||
|
||||
point_t pixel_pos = {start.x + width - 11, start.y};
|
||||
pixel_pos.y += ((height - 1) + font_height);
|
||||
gfx_print(pixel_pos, font, TEXT_ALIGN_LEFT, red, "+20");
|
||||
|
||||
// RSSI bar
|
||||
uint16_t rssi_height = height - 4;
|
||||
float s_level = (127.0f + rssi) / 6.0f;
|
||||
uint16_t rssi_width = (s_level < 0.0f) ? 0 : (s_level * (width - 1) / 11);
|
||||
rssi_width = (s_level > 10.0f) ? width : rssi_width;
|
||||
point_t rssi_pos = { start.x, start.y + 1 };
|
||||
gfx_drawRect(rssi_pos, rssi_width, rssi_height, white, true);
|
||||
}
|
||||
|
||||
/*
|
||||
* Function to draw level meter of arbitrary size
|
||||
* starting coordinates are relative to the top left point.
|
||||
*
|
||||
* * * * * *|
|
||||
* ****************************************** |
|
||||
* ****************************************** <- level |
|
||||
* ****************************************** | <-- Height (px)
|
||||
* ****************************************** |
|
||||
* * * * * *|
|
||||
* _________________________________________________________________
|
||||
*
|
||||
* ^
|
||||
* |
|
||||
*
|
||||
* Width (px)
|
||||
*
|
||||
*/
|
||||
void gfx_drawLevelMeter(point_t start, uint16_t width, uint16_t height, uint8_t level)
|
||||
{
|
||||
color_t white = {255, 255, 255, 255};
|
||||
|
||||
// S-level marks and numbers
|
||||
for(int i = 0; i <= 4; i++)
|
||||
{
|
||||
point_t pixel_pos = {start.x + i * (width - 1) / 4, start.y};
|
||||
gfx_setPixel(pixel_pos, white);
|
||||
pixel_pos.y += (height - 1);
|
||||
gfx_setPixel(pixel_pos, white);
|
||||
}
|
||||
|
||||
// Level bar
|
||||
uint16_t level_height = height - 4;
|
||||
uint16_t level_width = (level / 255 * width);
|
||||
point_t level_pos = { start.x, start.y + 2 };
|
||||
gfx_drawRect(level_pos, level_width, level_height, white, true);
|
||||
}
|
||||
|
||||
/*
|
||||
|
|
|
@ -208,7 +208,7 @@ layout_t _ui_calculateLayout()
|
|||
const uint16_t line2_h = 20;
|
||||
const uint16_t line3_h = 40;
|
||||
const uint16_t menu_h = 16;
|
||||
const uint16_t bottom_h = 20;
|
||||
const uint16_t bottom_h = 23;
|
||||
const uint16_t bottom_pad = top_pad;
|
||||
const uint16_t status_v_pad = 2;
|
||||
const uint16_t small_line_v_pad = 2;
|
||||
|
@ -243,7 +243,7 @@ layout_t _ui_calculateLayout()
|
|||
const uint16_t line2_h = 10;
|
||||
const uint16_t line3_h = 16;
|
||||
const uint16_t menu_h = 10;
|
||||
const uint16_t bottom_h = 8;
|
||||
const uint16_t bottom_h = 15;
|
||||
const uint16_t bottom_pad = 0;
|
||||
const uint16_t status_v_pad = 1;
|
||||
const uint16_t small_line_v_pad = 1;
|
||||
|
@ -321,6 +321,7 @@ layout_t _ui_calculateLayout()
|
|||
line3_h,
|
||||
menu_h,
|
||||
bottom_h,
|
||||
bottom_pad,
|
||||
status_v_pad,
|
||||
horizontal_pad,
|
||||
text_v_offset,
|
||||
|
|
|
@ -150,33 +150,26 @@ void _ui_drawMainBottom()
|
|||
// Squelch bar
|
||||
float rssi = last_state.rssi;
|
||||
float squelch = last_state.sqlLevel / 16.0f;
|
||||
uint16_t meter_width = SCREEN_WIDTH - 2 * layout.horizontal_pad;
|
||||
uint16_t meter_height = layout.bottom_h;
|
||||
point_t meter_pos = { layout.horizontal_pad,
|
||||
layout.bottom_pos.y +
|
||||
layout.status_v_pad +
|
||||
layout.text_v_offset -
|
||||
layout.bottom_h };
|
||||
uint16_t meter_height = layout.bottom_h - 1;
|
||||
SCREEN_HEIGHT - meter_height - layout.bottom_pad};
|
||||
switch(last_state.channel.mode)
|
||||
{
|
||||
case FM:
|
||||
gfx_drawSmeter(meter_pos,
|
||||
SCREEN_WIDTH - 2 * layout.horizontal_pad,
|
||||
meter_width,
|
||||
meter_height,
|
||||
rssi,
|
||||
squelch,
|
||||
color_white);
|
||||
yellow_fab413);
|
||||
break;
|
||||
case DMR:
|
||||
meter_height = (meter_height / 2);
|
||||
gfx_drawLevelMeter(meter_pos,
|
||||
SCREEN_WIDTH - 2 * layout.horizontal_pad,
|
||||
gfx_drawSmeterLevel(meter_pos,
|
||||
meter_width,
|
||||
meter_height,
|
||||
rssi,
|
||||
255);
|
||||
meter_pos.y += meter_height;
|
||||
gfx_drawSmeterNoSquelch(meter_pos,
|
||||
SCREEN_WIDTH - 2 * layout.horizontal_pad,
|
||||
meter_height,
|
||||
rssi);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -25,6 +25,9 @@
|
|||
#include <interfaces/nvmem.h>
|
||||
#include <interfaces/platform.h>
|
||||
|
||||
/* UI main screen helper functions, their implementation is in "ui_main.c" */
|
||||
extern void _ui_drawMainBottom();
|
||||
|
||||
void _ui_drawMenuList(uint8_t selected, int (*getCurrentEntry)(char *buf, uint8_t max_len, uint8_t index))
|
||||
{
|
||||
point_t pos = layout.line1_pos;
|
||||
|
@ -591,37 +594,8 @@ bool _ui_drawMacroMenu() {
|
|||
yellow_fab413, "9 ");
|
||||
gfx_print(layout.line3_pos, layout.top_font, TEXT_ALIGN_RIGHT,
|
||||
color_white, "Sav");
|
||||
// Smeter bar
|
||||
float rssi = last_state.rssi;
|
||||
float squelch = last_state.sqlLevel / 16.0f;
|
||||
point_t meter_pos = { layout.horizontal_pad,
|
||||
layout.bottom_pos.y +
|
||||
layout.status_v_pad +
|
||||
layout.text_v_offset -
|
||||
layout.bottom_h };
|
||||
uint16_t meter_height = layout.bottom_h - 1;
|
||||
switch(last_state.channel.mode)
|
||||
{
|
||||
case FM:
|
||||
gfx_drawSmeter(meter_pos,
|
||||
SCREEN_WIDTH - 2 * layout.horizontal_pad,
|
||||
meter_height,
|
||||
rssi,
|
||||
squelch,
|
||||
yellow_fab413);
|
||||
break;
|
||||
case DMR:
|
||||
meter_height = (meter_height / 2);
|
||||
gfx_drawLevelMeter(meter_pos,
|
||||
SCREEN_WIDTH - 2 * layout.horizontal_pad,
|
||||
meter_height,
|
||||
255);
|
||||
meter_pos.y += meter_height;
|
||||
gfx_drawSmeterNoSquelch(meter_pos,
|
||||
SCREEN_WIDTH - 2 * layout.horizontal_pad,
|
||||
meter_height,
|
||||
rssi);
|
||||
break;
|
||||
}
|
||||
|
||||
// Draw S-meter bar
|
||||
_ui_drawMainBottom();
|
||||
return true;
|
||||
}
|
||||
|
|
Ładowanie…
Reference in New Issue