mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-03 12:00:59 +00:00
improve display.loader
This commit is contained in:
parent
244002a4a8
commit
c91bca8a8a
BIN
assets/fingerprint.png
Normal file
BIN
assets/fingerprint.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 3.8 KiB |
BIN
assets/fingerprint.toig
Normal file
BIN
assets/fingerprint.toig
Normal file
Binary file not shown.
@ -37,9 +37,14 @@ static void display_blit(uint8_t x, uint8_t y, uint8_t w, uint8_t h, void *data,
|
|||||||
display_update();
|
display_update();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void inflate_callback_image(uint8_t byte, uint32_t pos, void *userdata)
|
||||||
|
{
|
||||||
|
DATA(byte);
|
||||||
|
}
|
||||||
|
|
||||||
static void display_image(uint8_t x, uint8_t y, uint8_t w, uint8_t h, void *data, int datalen) {
|
static void display_image(uint8_t x, uint8_t y, uint8_t w, uint8_t h, void *data, int datalen) {
|
||||||
display_set_window(x, y, w, h);
|
display_set_window(x, y, w, h);
|
||||||
sinf_inflate(data, DATAfunc);
|
sinf_inflate(data, inflate_callback_image, NULL);
|
||||||
display_update();
|
display_update();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -56,7 +61,7 @@ static void set_color_table(uint16_t fgcolor, uint16_t bgcolor)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void DATAiconmap(uint8_t byte)
|
static void inflate_callback_icon(uint8_t byte, uint32_t pos, void *userdata)
|
||||||
{
|
{
|
||||||
DATA(COLORTABLE[byte >> 4] >> 8);
|
DATA(COLORTABLE[byte >> 4] >> 8);
|
||||||
DATA(COLORTABLE[byte >> 4] & 0xFF);
|
DATA(COLORTABLE[byte >> 4] & 0xFF);
|
||||||
@ -67,7 +72,7 @@ static void DATAiconmap(uint8_t byte)
|
|||||||
static void display_icon(uint8_t x, uint8_t y, uint8_t w, uint8_t h, void *data, int datalen, uint16_t fgcolor, uint16_t bgcolor) {
|
static void display_icon(uint8_t x, uint8_t y, uint8_t w, uint8_t h, void *data, int datalen, uint16_t fgcolor, uint16_t bgcolor) {
|
||||||
display_set_window(x, y, w, h);
|
display_set_window(x, y, w, h);
|
||||||
set_color_table(fgcolor, bgcolor);
|
set_color_table(fgcolor, bgcolor);
|
||||||
sinf_inflate(data, DATAiconmap);
|
sinf_inflate(data, inflate_callback_icon, NULL);
|
||||||
display_update();
|
display_update();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -145,7 +150,7 @@ static void display_qrcode(uint8_t x, uint8_t y, char *data, int datalen, int sc
|
|||||||
|
|
||||||
#include "modtrezorui-loader.h"
|
#include "modtrezorui-loader.h"
|
||||||
|
|
||||||
static void display_loader(uint16_t position, uint16_t fgcolor, uint16_t bgcolor)
|
static void display_loader(uint16_t progress, uint16_t fgcolor, uint16_t bgcolor, const uint8_t *icon)
|
||||||
{
|
{
|
||||||
set_color_table(fgcolor, bgcolor);
|
set_color_table(fgcolor, bgcolor);
|
||||||
display_set_window(RESX / 2 - img_loader_size, RESY * 2 / 5 - img_loader_size, img_loader_size * 2, img_loader_size * 2);
|
display_set_window(RESX / 2 - img_loader_size, RESY * 2 / 5 - img_loader_size, img_loader_size * 2, img_loader_size * 2);
|
||||||
@ -168,8 +173,20 @@ static void display_loader(uint16_t position, uint16_t fgcolor, uint16_t bgcolor
|
|||||||
} else {
|
} else {
|
||||||
a = 999 - (img_loader[my][mx] >> 8);
|
a = 999 - (img_loader[my][mx] >> 8);
|
||||||
}
|
}
|
||||||
|
// inside of circle - draw glyph
|
||||||
|
if (mx + my > (48 * 2) && mx >= img_loader_size - 48 && my >= img_loader_size - 48) {
|
||||||
|
int i = (x - (img_loader_size - 48)) + (y - (img_loader_size - 48)) * 96;
|
||||||
uint8_t c;
|
uint8_t c;
|
||||||
if (position > a) {
|
if (i % 2) {
|
||||||
|
c = icon[i / 2] & 0x0F;
|
||||||
|
} else {
|
||||||
|
c = (icon[i / 2] & 0xF0) >> 4;
|
||||||
|
}
|
||||||
|
DATA(c << 4 | c >> 1);
|
||||||
|
DATA(c << 7 | c << 1);
|
||||||
|
} else {
|
||||||
|
uint8_t c;
|
||||||
|
if (progress > a) {
|
||||||
c = (img_loader[my][mx] & 0x00F0) >> 4;
|
c = (img_loader[my][mx] & 0x00F0) >> 4;
|
||||||
} else {
|
} else {
|
||||||
c = img_loader[my][mx] & 0x000F;
|
c = img_loader[my][mx] & 0x000F;
|
||||||
@ -178,6 +195,7 @@ static void display_loader(uint16_t position, uint16_t fgcolor, uint16_t bgcolor
|
|||||||
DATA(COLORTABLE[c] & 0xFF);
|
DATA(COLORTABLE[c] & 0xFF);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
display_update();
|
display_update();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -313,15 +331,43 @@ STATIC mp_obj_t mod_TrezorUi_Display_qrcode(size_t n_args, const mp_obj_t *args)
|
|||||||
}
|
}
|
||||||
STATIC MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(mod_TrezorUi_Display_qrcode_obj, 5, 5, mod_TrezorUi_Display_qrcode);
|
STATIC MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(mod_TrezorUi_Display_qrcode_obj, 5, 5, mod_TrezorUi_Display_qrcode);
|
||||||
|
|
||||||
// def Display.loader(self, position: int, fgcolor: int, bgcolor: int) -> None
|
|
||||||
|
static void inflate_callback_loader(uint8_t byte, uint32_t pos, void *userdata)
|
||||||
|
{
|
||||||
|
uint8_t *out = (uint8_t *)userdata;
|
||||||
|
out[pos] = byte;
|
||||||
|
}
|
||||||
|
|
||||||
|
// def Display.loader(self, progress: int, fgcolor: int, bgcolor: int, icon: bytes=None) -> None
|
||||||
STATIC mp_obj_t mod_TrezorUi_Display_loader(size_t n_args, const mp_obj_t *args) {
|
STATIC mp_obj_t mod_TrezorUi_Display_loader(size_t n_args, const mp_obj_t *args) {
|
||||||
mp_int_t position = mp_obj_get_int(args[1]);
|
mp_int_t progress = mp_obj_get_int(args[1]);
|
||||||
mp_int_t fgcolor = mp_obj_get_int(args[2]);
|
mp_int_t fgcolor = mp_obj_get_int(args[2]);
|
||||||
mp_int_t bgcolor = mp_obj_get_int(args[3]);
|
mp_int_t bgcolor = mp_obj_get_int(args[3]);
|
||||||
display_loader(position, fgcolor, bgcolor);
|
if (n_args > 4) { // icon provided
|
||||||
|
mp_buffer_info_t bufinfo;
|
||||||
|
mp_get_buffer_raise(args[4], &bufinfo, MP_BUFFER_READ);
|
||||||
|
uint8_t *data = bufinfo.buf;
|
||||||
|
if (bufinfo.len < 8 || memcmp(data, "TOIg", 4) != 0) {
|
||||||
|
nlr_raise(mp_obj_new_exception_msg(&mp_type_ValueError, "Invalid image format"));
|
||||||
|
}
|
||||||
|
mp_int_t w = *(uint16_t *)(data + 4);
|
||||||
|
mp_int_t h = *(uint16_t *)(data + 6);
|
||||||
|
mp_int_t datalen = *(uint32_t *)(data + 8);
|
||||||
|
if (w != 96 || h != 96) {
|
||||||
|
nlr_raise(mp_obj_new_exception_msg(&mp_type_ValueError, "Invalid icon size"));
|
||||||
|
}
|
||||||
|
if (datalen != bufinfo.len - 12) {
|
||||||
|
nlr_raise(mp_obj_new_exception_msg(&mp_type_ValueError, "Invalid size of data"));
|
||||||
|
}
|
||||||
|
uint8_t icondata[96 * 96 /2];
|
||||||
|
sinf_inflate(data + 12, inflate_callback_loader, icondata);
|
||||||
|
display_loader(progress, fgcolor, bgcolor, icondata);
|
||||||
|
} else {
|
||||||
|
display_loader(progress, fgcolor, bgcolor, NULL);
|
||||||
|
}
|
||||||
return mp_const_none;
|
return mp_const_none;
|
||||||
}
|
}
|
||||||
STATIC MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(mod_TrezorUi_Display_loader_obj, 4, 4, mod_TrezorUi_Display_loader);
|
STATIC MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(mod_TrezorUi_Display_loader_obj, 4, 5, mod_TrezorUi_Display_loader);
|
||||||
|
|
||||||
// def Display.orientation(self, degrees: int) -> None
|
// def Display.orientation(self, degrees: int) -> None
|
||||||
STATIC mp_obj_t mod_TrezorUi_Display_orientation(mp_obj_t self, mp_obj_t degrees) {
|
STATIC mp_obj_t mod_TrezorUi_Display_orientation(mp_obj_t self, mp_obj_t degrees) {
|
||||||
|
@ -55,7 +55,9 @@ typedef struct {
|
|||||||
int cbufi;
|
int cbufi;
|
||||||
SINF_TREE ltree; /* dynamic length/symbol tree */
|
SINF_TREE ltree; /* dynamic length/symbol tree */
|
||||||
SINF_TREE dtree; /* dynamic distance tree */
|
SINF_TREE dtree; /* dynamic distance tree */
|
||||||
void (* write)(uint8_t byte);
|
void (* write)(uint8_t byte, uint32_t pos, void *userdata);
|
||||||
|
void *userdata;
|
||||||
|
uint32_t written;
|
||||||
} SINF_DATA;
|
} SINF_DATA;
|
||||||
|
|
||||||
/* --------------------------------------------------- *
|
/* --------------------------------------------------- *
|
||||||
@ -103,7 +105,8 @@ static void sinf_write(SINF_DATA *d, uint8_t byte)
|
|||||||
{
|
{
|
||||||
d->cbuf[d->cbufi] = byte;
|
d->cbuf[d->cbufi] = byte;
|
||||||
d->cbufi = (d->cbufi + 1) % (1 << SINF_WBITS);
|
d->cbufi = (d->cbufi + 1) % (1 << SINF_WBITS);
|
||||||
d->write(byte);
|
d->write(byte, d->written, d->userdata);
|
||||||
|
d->written++;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* build the fixed huffman trees */
|
/* build the fixed huffman trees */
|
||||||
@ -391,7 +394,7 @@ static int sinf_inflate_dynamic_block(SINF_DATA *d)
|
|||||||
* ---------------------- */
|
* ---------------------- */
|
||||||
|
|
||||||
/* inflate stream from source */
|
/* inflate stream from source */
|
||||||
static int sinf_inflate(uint8_t *data, void (*write_callback)(uint8_t byte))
|
static int sinf_inflate(uint8_t *data, void (*write_callback)(uint8_t byte, uint32_t pos, void *userdata), void *userdata)
|
||||||
{
|
{
|
||||||
SINF_DATA d;
|
SINF_DATA d;
|
||||||
int bfinal;
|
int bfinal;
|
||||||
@ -401,6 +404,8 @@ static int sinf_inflate(uint8_t *data, void (*write_callback)(uint8_t byte))
|
|||||||
d.cbufi = 0;
|
d.cbufi = 0;
|
||||||
d.source = data;
|
d.source = data;
|
||||||
d.write = write_callback;
|
d.write = write_callback;
|
||||||
|
d.userdata = userdata;
|
||||||
|
d.written = 0;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
|
|
||||||
|
@ -10,10 +10,6 @@
|
|||||||
#define CMD(X) (*((__IO uint8_t *)((uint32_t)(0x60000000))) = (X))
|
#define CMD(X) (*((__IO uint8_t *)((uint32_t)(0x60000000))) = (X))
|
||||||
#define DATA(X) (*((__IO uint8_t *)((uint32_t)(0x60000000 | 0x10000))) = (X))
|
#define DATA(X) (*((__IO uint8_t *)((uint32_t)(0x60000000 | 0x10000))) = (X))
|
||||||
|
|
||||||
static void DATAfunc(uint8_t x) {
|
|
||||||
DATA(x);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void DATAS(void *bytes, int len);
|
static void DATAS(void *bytes, int len);
|
||||||
|
|
||||||
void sram_init(void) {
|
void sram_init(void) {
|
||||||
|
@ -8,6 +8,8 @@
|
|||||||
#include <SDL2/SDL.h>
|
#include <SDL2/SDL.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
#define DISPLAY_BORDER 8
|
||||||
|
|
||||||
static SDL_Renderer *RENDERER = 0;
|
static SDL_Renderer *RENDERER = 0;
|
||||||
static SDL_Surface *SCREEN = 0;
|
static SDL_Surface *SCREEN = 0;
|
||||||
static SDL_Texture *TEXTURE = 0;
|
static SDL_Texture *TEXTURE = 0;
|
||||||
@ -16,11 +18,8 @@ static int POSX, POSY, SX, SY, EX, EY = 0;
|
|||||||
static int ROTATION = 0;
|
static int ROTATION = 0;
|
||||||
|
|
||||||
#define CMD(X) (void)(X);
|
#define CMD(X) (void)(X);
|
||||||
#define DATA(X) DATAfunc((X))
|
|
||||||
|
|
||||||
#define DISPLAY_BORDER 8
|
static void DATA(uint8_t x) {
|
||||||
|
|
||||||
static void DATAfunc(uint8_t x) {
|
|
||||||
if (POSX <= EX && POSY <= EY) {
|
if (POSX <= EX && POSY <= EY) {
|
||||||
((uint8_t *)SCREEN->pixels)[POSX * 2 + POSY * SCREEN->pitch + (DATAODD ^ 1)] = x;
|
((uint8_t *)SCREEN->pixels)[POSX * 2 + POSY * SCREEN->pitch + (DATAODD ^ 1)] = x;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user