1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2024-11-27 01:48:17 +00:00
trezor-firmware/extmod/modtrezorui/modtrezorui-unix.h

125 lines
3.7 KiB
C
Raw Normal View History

2016-03-27 21:10:31 +00:00
/*
* Copyright (c) Pavol Rusnak, SatoshiLabs
*
* Licensed under Microsoft Reference Source License (Ms-RSL)
* see LICENSE.md file for details
*/
#include <SDL2/SDL.h>
2016-04-28 19:43:22 +00:00
#include <stdlib.h>
2016-03-27 21:10:31 +00:00
static SDL_Renderer *RENDERER = 0;
static SDL_Surface *SCREEN = 0;
static SDL_Texture *TEXTURE = 0;
static int DATAODD = 0;
static int POSX, POSY, SX, SY, EX, EY = 0;
2016-03-29 13:31:41 +00:00
static int ROTATION = 0;
2016-03-27 21:10:31 +00:00
#define CMD(X) (void)(X);
#define DATA(X) DATAfunc((X))
#define DISPLAY_BORDER 8
static void DATAfunc(uint8_t x) {
2016-03-27 21:10:31 +00:00
if (POSX <= EX && POSY <= EY) {
((uint8_t *)SCREEN->pixels)[POSX * 2 + POSY * SCREEN->pitch + (DATAODD ^ 1)] = x;
}
DATAODD = !DATAODD;
if (DATAODD == 0) {
POSX++;
if (POSX > EX) {
POSX = SX;
POSY++;
}
}
}
2016-04-29 01:15:18 +00:00
uint32_t trezorui_poll_sdl_event(void)
{
SDL_Event event;
int x, y;
SDL_PumpEvents();
2016-04-29 01:15:18 +00:00
if (SDL_PollEvent(&event) > 0) {
switch (event.type) {
case SDL_MOUSEBUTTONDOWN:
2016-03-31 22:59:09 +00:00
case SDL_MOUSEMOTION:
case SDL_MOUSEBUTTONUP:
x = event.button.x - DISPLAY_BORDER;
y = event.button.y - DISPLAY_BORDER;
2016-04-28 20:58:15 +00:00
if (x < 0 || y < 0 || x >= RESX || y >= RESY) break;
2016-03-31 22:59:09 +00:00
switch (event.type) {
case SDL_MOUSEBUTTONDOWN:
2016-04-28 20:58:15 +00:00
return (0x00 << 24) | (0x01 << 16) | (x << 8) | y; // touch_start
2016-03-31 22:59:09 +00:00
break;
case SDL_MOUSEMOTION:
// remove other SDL_MOUSEMOTION events from queue
SDL_FlushEvent(SDL_MOUSEMOTION);
2016-03-31 22:59:09 +00:00
if (event.motion.state) {
2016-04-28 20:58:15 +00:00
return (0x00 << 24) | (0x02 << 16) | (x << 8) | y; // touch_move
2016-03-31 22:59:09 +00:00
}
break;
case SDL_MOUSEBUTTONUP:
2016-04-28 20:58:15 +00:00
return (0x00 << 24) | (0x03 << 16) | (x << 8) | y; // touch_end
2016-03-31 22:59:09 +00:00
break;
}
break;
case SDL_KEYUP:
if (event.key.keysym.sym == SDLK_ESCAPE) {
exit(3);
}
break;
2016-04-28 19:43:22 +00:00
case SDL_QUIT:
exit(3);
break;
}
}
2016-04-28 20:58:15 +00:00
return 0;
}
2016-03-27 21:10:31 +00:00
static void display_init(void)
{
if (SDL_Init(SDL_INIT_VIDEO) != 0) {
printf("SDL_Init Error: %s\n", SDL_GetError());
}
SDL_Window *win = SDL_CreateWindow("TREZOR", SDL_WINDOWPOS_UNDEFINED, SDL_WINDOWPOS_UNDEFINED, RESX + 2 * DISPLAY_BORDER, RESY + 2 * DISPLAY_BORDER, SDL_WINDOW_SHOWN);
2016-03-27 21:10:31 +00:00
if (!win) {
printf("SDL_CreateWindow Error: %s\n", SDL_GetError());
SDL_Quit();
}
RENDERER = SDL_CreateRenderer(win, -1, SDL_RENDERER_SOFTWARE);
if (!RENDERER) {
printf("SDL_CreateRenderer Error: %s\n", SDL_GetError());
SDL_DestroyWindow(win);
SDL_Quit();
}
SDL_RenderClear(RENDERER);
SCREEN = SDL_CreateRGBSurface(0, RESX, RESY, 16, 0xF800, 0x07E0, 0x001F, 0x0000);
TEXTURE = SDL_CreateTexture(RENDERER, SDL_PIXELFORMAT_RGB565, SDL_TEXTUREACCESS_STREAMING, RESX, RESY);
}
static void display_set_window(uint16_t x, uint16_t y, uint16_t w, uint16_t h) {
2016-03-27 21:10:31 +00:00
SX = x; SY = y;
EX = x + w - 1; EY = y + h - 1;
POSX = SX; POSY = SY;
DATAODD = 0;
}
static void display_update(void)
{
2016-03-29 13:31:41 +00:00
SDL_RenderClear(RENDERER);
2016-03-27 21:10:31 +00:00
SDL_UpdateTexture(TEXTURE, NULL, SCREEN->pixels, SCREEN->pitch);
const SDL_Rect r = {DISPLAY_BORDER, DISPLAY_BORDER, RESX, RESY};
SDL_RenderCopyEx(RENDERER, TEXTURE, NULL, &r, ROTATION, NULL, 0);
2016-03-27 21:10:31 +00:00
SDL_RenderPresent(RENDERER);
}
2016-03-29 13:31:41 +00:00
static void display_orientation(int degrees)
{
ROTATION = degrees;
display_update();
}
2016-04-03 13:26:49 +00:00
static void display_backlight(uint8_t val)
{
}