Both sdl and x11 front-ends are compiled, selectable at runtime
This commit is contained in:
parent
2b4607c5af
commit
90b8035654
9 changed files with 1306 additions and 987 deletions
16
Makefile
16
Makefile
|
@ -20,16 +20,16 @@ ifeq ($(FULL_WARNINGS), yes)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
### SDL UI
|
### SDL UI
|
||||||
ifeq ($(GUI), sdl)
|
# ifeq ($(GUI), sdl)
|
||||||
CFLAGS += $(shell pkg-config --cflags SDL_gfx sdl12_compat)
|
CFLAGS += $(shell pkg-config --cflags SDL_gfx sdl12_compat)
|
||||||
LIBS += $(shell pkg-config --libs SDL_gfx sdl12_compat)
|
LIBS += $(shell pkg-config --libs SDL_gfx sdl12_compat)
|
||||||
endif
|
# endif
|
||||||
|
|
||||||
### X11 UI
|
### X11 UI
|
||||||
ifeq ($(GUI), x11)
|
# ifeq ($(GUI), x11)
|
||||||
CFLAGS += $(shell pkg-config --cflags x11 xext) -D_GNU_SOURCE=1 -DGUI_IS_X11=1
|
CFLAGS += $(shell pkg-config --cflags x11 xext) -D_GNU_SOURCE=1 -DGUI_IS_X11=1
|
||||||
LIBS += $(shell pkg-config --libs x11 xext)
|
LIBS += $(shell pkg-config --libs x11 xext)
|
||||||
endif
|
# endif
|
||||||
|
|
||||||
DOTOS = src/emu_serial.o \
|
DOTOS = src/emu_serial.o \
|
||||||
src/emu_emulate.o \
|
src/emu_emulate.o \
|
||||||
|
@ -40,7 +40,9 @@ DOTOS = src/emu_serial.o \
|
||||||
src/emu_timer.o \
|
src/emu_timer.o \
|
||||||
src/runtime_options.o \
|
src/runtime_options.o \
|
||||||
src/romio.o \
|
src/romio.o \
|
||||||
src/ui_$(GUI).o \
|
src/ui_sdl.o \
|
||||||
|
src/ui_x11.o \
|
||||||
|
src/ui.o \
|
||||||
src/main.o
|
src/main.o
|
||||||
|
|
||||||
### debugger
|
### debugger
|
||||||
|
@ -107,7 +109,7 @@ install: all
|
||||||
|
|
||||||
install -m 755 -d -- $(DESTDIR)$(PREFIX)/share/applications
|
install -m 755 -d -- $(DESTDIR)$(PREFIX)/share/applications
|
||||||
sed "s|@PREFIX@|$(PREFIX)|g" dist/x48ng.desktop > $(DESTDIR)$(PREFIX)/share/applications/x48ng.desktop
|
sed "s|@PREFIX@|$(PREFIX)|g" dist/x48ng.desktop > $(DESTDIR)$(PREFIX)/share/applications/x48ng.desktop
|
||||||
ifeq ($(GUI), x11)
|
# ifeq ($(GUI), x11)
|
||||||
install -m 755 -d -- $(DESTDIR)/etc/X11/app-defaults
|
install -m 755 -d -- $(DESTDIR)/etc/X11/app-defaults
|
||||||
install -c -m 644 dist/X48NG.ad $(DESTDIR)/etc/X11/app-defaults/X48NG
|
install -c -m 644 dist/X48NG.ad $(DESTDIR)/etc/X11/app-defaults/X48NG
|
||||||
endif
|
# endif
|
||||||
|
|
|
@ -32,8 +32,6 @@ See https://github.com/gwenhael-le-moine/x48ng/issues
|
||||||
|
|
||||||
## Compilation
|
## Compilation
|
||||||
|
|
||||||
The default gui is sdl. You can compile the x11 by passing `GUI=x11` to make.
|
|
||||||
|
|
||||||
### Dependencies (see .github/workflows/c-cpp.yml for debian packages names)
|
### Dependencies (see .github/workflows/c-cpp.yml for debian packages names)
|
||||||
|
|
||||||
- readline
|
- readline
|
||||||
|
|
6
dist/x48ng.man.1
vendored
6
dist/x48ng.man.1
vendored
|
@ -71,9 +71,11 @@ where options include:
|
||||||
.br
|
.br
|
||||||
\-V \-\-verbose be verbose (default: false)
|
\-V \-\-verbose be verbose (default: false)
|
||||||
.br
|
.br
|
||||||
\-\-no\-chrome only display the LCD (default: false)
|
\-u \-\-front-end specify a front-end (available: x11, sdl; default: x11)
|
||||||
.br
|
.br
|
||||||
\-\-fullscreen make the UI fullscreen (default: false)
|
\-\-no\-chrome [SDL only] only display the LCD (default: false)
|
||||||
|
.br
|
||||||
|
\-\-fullscreen [SDL only] make the UI fullscreen (default: false)
|
||||||
.br
|
.br
|
||||||
\-t \-\-use\-terminal activate pseudo terminal interface (default: true)
|
\-t \-\-use\-terminal activate pseudo terminal interface (default: true)
|
||||||
.br
|
.br
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
#include <getopt.h>
|
#include <getopt.h>
|
||||||
|
|
||||||
|
@ -16,6 +17,7 @@ int useDebugger = 1;
|
||||||
int throttle = 0;
|
int throttle = 0;
|
||||||
int initialize = 0;
|
int initialize = 0;
|
||||||
int resetOnStartup = 0;
|
int resetOnStartup = 0;
|
||||||
|
int frontend_type = FRONTEND_X11;
|
||||||
|
|
||||||
char* serialLine = "/dev/ttyS0";
|
char* serialLine = "/dev/ttyS0";
|
||||||
char* homeDirectory = ".x48ng";
|
char* homeDirectory = ".x48ng";
|
||||||
|
@ -30,7 +32,7 @@ int parse_args( int argc, char* argv[] ) {
|
||||||
int option_index;
|
int option_index;
|
||||||
int c = '?';
|
int c = '?';
|
||||||
|
|
||||||
char* optstring = "c:S:hvVtsirT";
|
char* optstring = "c:S:u:hvVtsirT";
|
||||||
static struct option long_options[] = {
|
static struct option long_options[] = {
|
||||||
{ "config-dir", required_argument, NULL, 1000 },
|
{ "config-dir", required_argument, NULL, 1000 },
|
||||||
{ "rom-file", required_argument, NULL, 1010 },
|
{ "rom-file", required_argument, NULL, 1010 },
|
||||||
|
@ -41,6 +43,8 @@ int parse_args( int argc, char* argv[] ) {
|
||||||
|
|
||||||
{ "serial-line", required_argument, NULL, 1015 },
|
{ "serial-line", required_argument, NULL, 1015 },
|
||||||
|
|
||||||
|
{ "front-end", required_argument, NULL, 'u' },
|
||||||
|
|
||||||
{ "help", no_argument, NULL, 'h' },
|
{ "help", no_argument, NULL, 'h' },
|
||||||
{ "version", no_argument, NULL, 'v' },
|
{ "version", no_argument, NULL, 'v' },
|
||||||
|
|
||||||
|
@ -78,8 +82,12 @@ int parse_args( int argc, char* argv[] ) {
|
||||||
"\t --serial-line=<path>\t\tuse <path> as serial device default: "
|
"\t --serial-line=<path>\t\tuse <path> as serial device default: "
|
||||||
"%s)\n"
|
"%s)\n"
|
||||||
"\t-V --verbose\t\t\tbe verbose (default: false)\n"
|
"\t-V --verbose\t\t\tbe verbose (default: false)\n"
|
||||||
"\t --no-chrome\t\t\tonly display the LCD (default: false)\n"
|
"\t --no-chrome\t\t\t[SDL only] only display the LCD (default: "
|
||||||
"\t --fullscreen\t\t\tmake the UI fullscreen (default: false)\n"
|
"false)\n"
|
||||||
|
"\t --fullscreen\t\t\t[SDL only] make the UI fullscreen (default: "
|
||||||
|
"false)\n"
|
||||||
|
"\t-u --front-end\t\t\tspecify a front-end (available: x11, sdl; "
|
||||||
|
"default: x11)\n"
|
||||||
"\t-t --use-terminal\t\tactivate pseudo terminal interface (default: "
|
"\t-t --use-terminal\t\tactivate pseudo terminal interface (default: "
|
||||||
"true)\n"
|
"true)\n"
|
||||||
"\t-s --use-serial\t\t\tactivate serial interface (default: false)\n"
|
"\t-s --use-serial\t\t\tactivate serial interface (default: false)\n"
|
||||||
|
@ -122,6 +130,12 @@ int parse_args( int argc, char* argv[] ) {
|
||||||
case 1015:
|
case 1015:
|
||||||
serialLine = optarg;
|
serialLine = optarg;
|
||||||
break;
|
break;
|
||||||
|
case 'u':
|
||||||
|
if ( strcmp( optarg, "sdl" ) == 0 )
|
||||||
|
frontend_type = FRONTEND_SDL;
|
||||||
|
else
|
||||||
|
frontend_type = FRONTEND_X11;
|
||||||
|
break;
|
||||||
case 'V':
|
case 'V':
|
||||||
verbose = 1;
|
verbose = 1;
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -1,6 +1,9 @@
|
||||||
#ifndef _OPTIONS_H
|
#ifndef _OPTIONS_H
|
||||||
#define _OPTIONS_H 1
|
#define _OPTIONS_H 1
|
||||||
|
|
||||||
|
#define FRONTEND_SDL 0
|
||||||
|
#define FRONTEND_X11 1
|
||||||
|
|
||||||
extern char* progname;
|
extern char* progname;
|
||||||
|
|
||||||
extern int verbose;
|
extern int verbose;
|
||||||
|
@ -12,6 +15,7 @@ extern int useDebugger;
|
||||||
extern int throttle;
|
extern int throttle;
|
||||||
extern int initialize;
|
extern int initialize;
|
||||||
extern int resetOnStartup;
|
extern int resetOnStartup;
|
||||||
|
extern int frontend_type;
|
||||||
|
|
||||||
extern char* serialLine;
|
extern char* serialLine;
|
||||||
extern char* homeDirectory;
|
extern char* homeDirectory;
|
||||||
|
|
93
src/ui.c
Normal file
93
src/ui.c
Normal file
|
@ -0,0 +1,93 @@
|
||||||
|
#include "ui.h"
|
||||||
|
#include "runtime_options.h"
|
||||||
|
|
||||||
|
display_t display;
|
||||||
|
|
||||||
|
extern void ui_sdl__disp_draw_nibble( word_20 addr, word_4 val );
|
||||||
|
extern void ui_x11__disp_draw_nibble( word_20 addr, word_4 val );
|
||||||
|
void ui__disp_draw_nibble( word_20 addr, word_4 val ) {
|
||||||
|
switch ( frontend_type ) {
|
||||||
|
case FRONTEND_SDL:
|
||||||
|
return ui_sdl__disp_draw_nibble( addr, val );
|
||||||
|
case FRONTEND_X11:
|
||||||
|
return ui_x11__disp_draw_nibble( addr, val );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extern void ui_sdl__menu_draw_nibble( word_20 addr, word_4 val );
|
||||||
|
extern void ui_x11__menu_draw_nibble( word_20 addr, word_4 val );
|
||||||
|
void ui__menu_draw_nibble( word_20 addr, word_4 val ) {
|
||||||
|
switch ( frontend_type ) {
|
||||||
|
case FRONTEND_SDL:
|
||||||
|
return ui_sdl__menu_draw_nibble( addr, val );
|
||||||
|
case FRONTEND_X11:
|
||||||
|
return ui_x11__menu_draw_nibble( addr, val );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extern int ui_sdl__get_event( void );
|
||||||
|
extern int ui_x11__get_event( void );
|
||||||
|
int ui__get_event( void ) {
|
||||||
|
switch ( frontend_type ) {
|
||||||
|
case FRONTEND_SDL:
|
||||||
|
return ui_sdl__get_event();
|
||||||
|
case FRONTEND_X11:
|
||||||
|
return ui_x11__get_event();
|
||||||
|
}
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
extern void ui_sdl__update_LCD( void );
|
||||||
|
extern void ui_x11__update_LCD( void );
|
||||||
|
void ui__update_LCD( void ) {
|
||||||
|
switch ( frontend_type ) {
|
||||||
|
case FRONTEND_SDL:
|
||||||
|
return ui_sdl__update_LCD();
|
||||||
|
case FRONTEND_X11:
|
||||||
|
return ui_x11__update_LCD();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extern void ui_sdl__adjust_contrast( void );
|
||||||
|
extern void ui_x11__adjust_contrast( void );
|
||||||
|
void ui__adjust_contrast( void ) {
|
||||||
|
switch ( frontend_type ) {
|
||||||
|
case FRONTEND_SDL:
|
||||||
|
return ui_sdl__adjust_contrast();
|
||||||
|
case FRONTEND_X11:
|
||||||
|
return ui_x11__adjust_contrast();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extern void ui_sdl__draw_annunc( void );
|
||||||
|
extern void ui_x11__draw_annunc( void );
|
||||||
|
void ui__draw_annunc( void ) {
|
||||||
|
switch ( frontend_type ) {
|
||||||
|
case FRONTEND_SDL:
|
||||||
|
return ui_sdl__draw_annunc();
|
||||||
|
case FRONTEND_X11:
|
||||||
|
return ui_x11__draw_annunc();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extern void ui_sdl__init_LCD( void );
|
||||||
|
extern void ui_x11__init_LCD( void );
|
||||||
|
void ui__init_LCD( void ) {
|
||||||
|
switch ( frontend_type ) {
|
||||||
|
case FRONTEND_SDL:
|
||||||
|
return ui_sdl__init_LCD();
|
||||||
|
case FRONTEND_X11:
|
||||||
|
return ui_x11__init_LCD();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
extern void init_sdl_ui( int argc, char** argv );
|
||||||
|
extern void init_x11_ui( int argc, char** argv );
|
||||||
|
void init_ui( int argc, char** argv ) {
|
||||||
|
switch ( frontend_type ) {
|
||||||
|
case FRONTEND_SDL:
|
||||||
|
return init_sdl_ui( argc, argv );
|
||||||
|
case FRONTEND_X11:
|
||||||
|
return init_x11_ui( argc, argv );
|
||||||
|
}
|
||||||
|
}
|
136
src/ui_inner.h
136
src/ui_inner.h
|
@ -109,144 +109,8 @@ typedef struct letter_t {
|
||||||
unsigned char* bits;
|
unsigned char* bits;
|
||||||
} letter_t;
|
} letter_t;
|
||||||
|
|
||||||
letter_t small_font[] = {
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ nl_gx_width, nl_gx_height, nl_gx_bitmap }, /* \001 == \n gx */
|
|
||||||
{ comma_gx_width, comma_gx_height, comma_gx_bitmap }, /* \002 == comma gx */
|
|
||||||
{ arrow_gx_width, arrow_gx_height, arrow_gx_bitmap }, /* \003 == \-> gx */
|
|
||||||
{ equal_gx_width, equal_gx_height, equal_gx_bitmap }, /* \004 == equal gx */
|
|
||||||
{ pi_gx_width, pi_gx_height, pi_gx_bitmap }, /* \005 == pi gx */
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 }, /* # 16 */
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ blank_width, blank_height, blank_bitmap }, /* # 32 */
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ hash_width, hash_height, hash_bitmap },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ lbrace_width, lbrace_height, lbrace_bitmap },
|
|
||||||
{ rbrace_width, rbrace_height, rbrace_bitmap },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ comma_width, comma_height, comma_bitmap },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ slash_width, slash_height, slash_bitmap },
|
|
||||||
{ 0, 0, 0 }, /* # 48 */
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ two_width, two_height, two_bitmap },
|
|
||||||
{ three_width, three_height, three_bitmap },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ small_colon_width, small_colon_height, small_colon_bitmap },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ equal_width, equal_height, equal_bitmap },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 }, /* # 64 */
|
|
||||||
{ A_width, A_height, A_bitmap },
|
|
||||||
{ B_width, B_height, B_bitmap },
|
|
||||||
{ C_width, C_height, C_bitmap },
|
|
||||||
{ D_width, D_height, D_bitmap },
|
|
||||||
{ E_width, E_height, E_bitmap },
|
|
||||||
{ F_width, F_height, F_bitmap },
|
|
||||||
{ G_width, G_height, G_bitmap },
|
|
||||||
{ H_width, H_height, H_bitmap },
|
|
||||||
{ I_width, I_height, I_bitmap },
|
|
||||||
{ J_width, J_height, J_bitmap },
|
|
||||||
{ K_width, K_height, K_bitmap },
|
|
||||||
{ L_width, L_height, L_bitmap },
|
|
||||||
{ M_width, M_height, M_bitmap },
|
|
||||||
{ N_width, N_height, N_bitmap },
|
|
||||||
{ O_width, O_height, O_bitmap },
|
|
||||||
{ P_width, P_height, P_bitmap }, /* # 80 */
|
|
||||||
{ Q_width, Q_height, Q_bitmap },
|
|
||||||
{ R_width, R_height, R_bitmap },
|
|
||||||
{ S_width, S_height, S_bitmap },
|
|
||||||
{ T_width, T_height, T_bitmap },
|
|
||||||
{ U_width, U_height, U_bitmap },
|
|
||||||
{ V_width, V_height, V_bitmap },
|
|
||||||
{ W_width, W_height, W_bitmap },
|
|
||||||
{ X_width, X_height, X_bitmap },
|
|
||||||
{ Y_width, Y_height, Y_bitmap },
|
|
||||||
{ Z_width, Z_height, Z_bitmap },
|
|
||||||
{ lbracket_width, lbracket_height, lbracket_bitmap },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ rbracket_width, rbracket_height, rbracket_bitmap },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ under_width, under_height, under_bitmap },
|
|
||||||
{ 0, 0, 0 }, /* # 96 */
|
|
||||||
{ arrow_width, arrow_height, arrow_bitmap }, /* a == left arrow */
|
|
||||||
{ diff_width, diff_height, diff_bitmap }, /* b == differential */
|
|
||||||
{ integral_width, integral_height, integral_bitmap }, /* c == integral */
|
|
||||||
{ sigma_width, sigma_height, sigma_bitmap }, /* d == sigma */
|
|
||||||
{ sqr_width, sqr_height, sqr_bitmap }, /* e == sqr */
|
|
||||||
{ root_width, root_height, root_bitmap }, /* f == root */
|
|
||||||
{ pow10_width, pow10_height, pow10_bitmap }, /* g == pow10 */
|
|
||||||
{ exp_width, exp_height, exp_bitmap }, /* h == exp */
|
|
||||||
{ prog_width, prog_height, prog_bitmap }, /* i == << >> */
|
|
||||||
{ string_width, string_height, string_bitmap }, /* j == " " */
|
|
||||||
{ nl_width, nl_height, nl_bitmap }, /* k == New Line */
|
|
||||||
{ pi_width, pi_height, pi_bitmap }, /* l == pi */
|
|
||||||
{ angle_width, angle_height, angle_bitmap }, /* m == angle */
|
|
||||||
{ sqr_gx_width, sqr_gx_height, sqr_gx_bitmap }, /* n == sqr gx */
|
|
||||||
{ root_gx_width, root_gx_height, root_gx_bitmap }, /* o == root gx */
|
|
||||||
{ pow10_gx_width, pow10_gx_height, pow10_gx_bitmap }, /* p == pow10 gx */
|
|
||||||
{ exp_gx_width, exp_gx_height, exp_gx_bitmap }, /* q == exp gx */
|
|
||||||
{ parens_gx_width, parens_gx_height, parens_gx_bitmap }, /* r == ( ) gx */
|
|
||||||
{ hash_gx_width, hash_gx_height, hash_gx_bitmap }, /* s == # gx */
|
|
||||||
{ bracket_gx_width, bracket_gx_height, bracket_gx_bitmap }, /* t == [] gx */
|
|
||||||
{ under_gx_width, under_gx_height, under_gx_bitmap }, /* u == _ gx */
|
|
||||||
{ prog_gx_width, prog_gx_height, prog_gx_bitmap }, /* v == << >> gx */
|
|
||||||
{ quote_gx_width, quote_gx_height, quote_gx_bitmap }, /* w == " " gx */
|
|
||||||
{ curly_gx_width, curly_gx_height, curly_gx_bitmap }, /* x == {} gx */
|
|
||||||
{ colon_gx_width, colon_gx_height, colon_gx_bitmap }, /* y == :: gx */
|
|
||||||
{ angle_gx_width, angle_gx_height, angle_gx_bitmap }, /* z == angle gx */
|
|
||||||
{ lcurly_width, lcurly_height, lcurly_bitmap },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ rcurly_width, rcurly_height, rcurly_bitmap },
|
|
||||||
{ 0, 0, 0 },
|
|
||||||
{ 0, 0, 0 } };
|
|
||||||
|
|
||||||
/*************/
|
/*************/
|
||||||
/* variables */
|
/* variables */
|
||||||
/*************/
|
/*************/
|
||||||
int last_annunc_state = -1;
|
|
||||||
|
|
||||||
display_t display;
|
|
||||||
|
|
||||||
unsigned char disp_buf[ DISP_ROWS ][ NIBS_PER_BUFFER_ROW ];
|
|
||||||
unsigned char lcd_buffer[ DISP_ROWS ][ NIBS_PER_BUFFER_ROW ];
|
|
||||||
|
|
||||||
#endif /* _UI_INNER_H */
|
#endif /* _UI_INNER_H */
|
||||||
|
|
606
src/ui_sdl.c
606
src/ui_sdl.c
|
@ -51,17 +51,17 @@
|
||||||
/* typedef */
|
/* typedef */
|
||||||
/***********/
|
/***********/
|
||||||
|
|
||||||
typedef struct color_t {
|
typedef struct ui_sdl__color_t {
|
||||||
const char* name;
|
const char* name;
|
||||||
int r, g, b;
|
int r, g, b;
|
||||||
} color_t;
|
} ui_sdl__color_t;
|
||||||
|
|
||||||
typedef struct keypad_t {
|
typedef struct ui_sdl__keypad_t {
|
||||||
unsigned int width;
|
unsigned int width;
|
||||||
unsigned int height;
|
unsigned int height;
|
||||||
} keypad_t;
|
} ui_sdl__keypad_t;
|
||||||
|
|
||||||
typedef struct button_t {
|
typedef struct ui_sdl__button_t {
|
||||||
const char* name;
|
const char* name;
|
||||||
short pressed;
|
short pressed;
|
||||||
short extra;
|
short extra;
|
||||||
|
@ -85,11 +85,11 @@ typedef struct button_t {
|
||||||
|
|
||||||
SDL_Surface* surfaceup;
|
SDL_Surface* surfaceup;
|
||||||
SDL_Surface* surfacedown;
|
SDL_Surface* surfacedown;
|
||||||
} button_t;
|
} ui_sdl__button_t;
|
||||||
|
|
||||||
// This mimicks the structure formerly lcd.c, except with SDL surfaces instead
|
// This mimicks the structure formerly lcd.c, except with SDL surfaces instead
|
||||||
// of Pixmaps.
|
// of Pixmaps.
|
||||||
typedef struct ann_struct {
|
typedef struct ui_sdl__ann_struct_t {
|
||||||
int bit;
|
int bit;
|
||||||
int x;
|
int x;
|
||||||
int y;
|
int y;
|
||||||
|
@ -99,62 +99,57 @@ typedef struct ann_struct {
|
||||||
|
|
||||||
SDL_Surface* surfaceon;
|
SDL_Surface* surfaceon;
|
||||||
SDL_Surface* surfaceoff;
|
SDL_Surface* surfaceoff;
|
||||||
} ann_struct_t;
|
} ui_sdl__ann_struct_t;
|
||||||
|
|
||||||
typedef struct SDLWINDOW {
|
|
||||||
SDL_Surface *oldsurf, *surf;
|
|
||||||
int x, y;
|
|
||||||
} SDLWINDOW_t;
|
|
||||||
|
|
||||||
/*************/
|
/*************/
|
||||||
/* variables */
|
/* variables */
|
||||||
/*************/
|
/*************/
|
||||||
keypad_t keypad;
|
ui_sdl__keypad_t keypad;
|
||||||
color_t* colors;
|
ui_sdl__color_t* sdl_colors;
|
||||||
|
|
||||||
color_t colors_sx[] = { { "white", 255, 255, 255 },
|
ui_sdl__color_t sdl_colors_sx[] = { { "white", 255, 255, 255 },
|
||||||
{ "left", 255, 166, 0 },
|
{ "left", 255, 166, 0 },
|
||||||
{ "right", 0, 210, 255 },
|
{ "right", 0, 210, 255 },
|
||||||
{ "but_top", 109, 93, 93 },
|
{ "but_top", 109, 93, 93 },
|
||||||
{ "button", 90, 77, 77 },
|
{ "button", 90, 77, 77 },
|
||||||
{ "but_bot", 76, 65, 65 },
|
{ "but_bot", 76, 65, 65 },
|
||||||
{ "lcd_col", 202, 221, 92 },
|
{ "lcd_col", 202, 221, 92 },
|
||||||
{ "pix_col", 0, 0, 128 },
|
{ "pix_col", 0, 0, 128 },
|
||||||
{ "pad_top", 109, 78, 78 },
|
{ "pad_top", 109, 78, 78 },
|
||||||
{ "pad", 90, 64, 64 },
|
{ "pad", 90, 64, 64 },
|
||||||
{ "pad_bot", 76, 54, 54 },
|
{ "pad_bot", 76, 54, 54 },
|
||||||
{ "disp_pad_top", 155, 118, 84 },
|
{ "disp_pad_top", 155, 118, 84 },
|
||||||
{ "disp_pad", 124, 94, 67 },
|
{ "disp_pad", 124, 94, 67 },
|
||||||
{ "disp_pad_bot", 100, 75, 53 },
|
{ "disp_pad_bot", 100, 75, 53 },
|
||||||
{ "logo", 204, 169, 107 },
|
{ "logo", 204, 169, 107 },
|
||||||
{ "logo_back", 64, 64, 64 },
|
{ "logo_back", 64, 64, 64 },
|
||||||
{ "label", 202, 184, 144 },
|
{ "label", 202, 184, 144 },
|
||||||
{ "frame", 0, 0, 0 },
|
{ "frame", 0, 0, 0 },
|
||||||
{ "underlay", 60, 42, 42 },
|
{ "underlay", 60, 42, 42 },
|
||||||
{ "black", 0, 0, 0 },
|
{ "black", 0, 0, 0 },
|
||||||
{ 0 } };
|
{ 0 } };
|
||||||
|
|
||||||
color_t colors_gx[] = { { "white", 255, 255, 255 },
|
ui_sdl__color_t sdl_colors_gx[] = { { "white", 255, 255, 255 },
|
||||||
{ "left", 255, 186, 255 },
|
{ "left", 255, 186, 255 },
|
||||||
{ "right", 0, 255, 204 },
|
{ "right", 0, 255, 204 },
|
||||||
{ "but_top", 104, 104, 104 },
|
{ "but_top", 104, 104, 104 },
|
||||||
{ "button", 88, 88, 88 },
|
{ "button", 88, 88, 88 },
|
||||||
{ "but_bot", 74, 74, 74 },
|
{ "but_bot", 74, 74, 74 },
|
||||||
{ "lcd_col", 202, 221, 92 },
|
{ "lcd_col", 202, 221, 92 },
|
||||||
{ "pix_col", 0, 0, 128 },
|
{ "pix_col", 0, 0, 128 },
|
||||||
{ "pad_top", 88, 88, 88 },
|
{ "pad_top", 88, 88, 88 },
|
||||||
{ "pad", 74, 74, 74 },
|
{ "pad", 74, 74, 74 },
|
||||||
{ "pad_bot", 64, 64, 64 },
|
{ "pad_bot", 64, 64, 64 },
|
||||||
{ "disp_pad_top", 128, 128, 138 },
|
{ "disp_pad_top", 128, 128, 138 },
|
||||||
{ "disp_pad", 104, 104, 110 },
|
{ "disp_pad", 104, 104, 110 },
|
||||||
{ "disp_pad_bot", 84, 84, 90 },
|
{ "disp_pad_bot", 84, 84, 90 },
|
||||||
{ "logo", 176, 176, 184 },
|
{ "logo", 176, 176, 184 },
|
||||||
{ "logo_back", 104, 104, 110 },
|
{ "logo_back", 104, 104, 110 },
|
||||||
{ "label", 240, 240, 240 },
|
{ "label", 240, 240, 240 },
|
||||||
{ "frame", 0, 0, 0 },
|
{ "frame", 0, 0, 0 },
|
||||||
{ "underlay", 104, 104, 110 },
|
{ "underlay", 104, 104, 110 },
|
||||||
{ "black", 0, 0, 0 },
|
{ "black", 0, 0, 0 },
|
||||||
{ 0 } };
|
{ 0 } };
|
||||||
|
|
||||||
// This will take the value of the defines, but can be run-time modified
|
// This will take the value of the defines, but can be run-time modified
|
||||||
unsigned KEYBOARD_HEIGHT, KEYBOARD_WIDTH, TOP_SKIP, SIDE_SKIP, BOTTOM_SKIP,
|
unsigned KEYBOARD_HEIGHT, KEYBOARD_WIDTH, TOP_SKIP, SIDE_SKIP, BOTTOM_SKIP,
|
||||||
|
@ -164,9 +159,9 @@ unsigned KEYBOARD_HEIGHT, KEYBOARD_WIDTH, TOP_SKIP, SIDE_SKIP, BOTTOM_SKIP,
|
||||||
|
|
||||||
unsigned int ARGBColors[ BLACK + 1 ];
|
unsigned int ARGBColors[ BLACK + 1 ];
|
||||||
|
|
||||||
button_t* buttons = 0;
|
ui_sdl__button_t* buttons = 0;
|
||||||
|
|
||||||
button_t buttons_sx[] = {
|
ui_sdl__button_t buttons_sx[] = {
|
||||||
{ "A",
|
{ "A",
|
||||||
0,
|
0,
|
||||||
0,
|
0,
|
||||||
|
@ -490,7 +485,7 @@ button_t buttons_sx[] = {
|
||||||
|
|
||||||
{ 0 } };
|
{ 0 } };
|
||||||
|
|
||||||
button_t buttons_gx[] = {
|
ui_sdl__button_t buttons_gx[] = {
|
||||||
{ "A",
|
{ "A",
|
||||||
0,
|
0,
|
||||||
0,
|
0,
|
||||||
|
@ -814,9 +809,7 @@ button_t buttons_gx[] = {
|
||||||
|
|
||||||
{ 0 } };
|
{ 0 } };
|
||||||
|
|
||||||
/* x48_lcd.c */
|
ui_sdl__ann_struct_t ann_tbl[] = {
|
||||||
|
|
||||||
ann_struct_t ann_tbl[] = {
|
|
||||||
{ ANN_LEFT, 16, 4, ann_left_width, ann_left_height, ann_left_bitmap, 0, 0 },
|
{ ANN_LEFT, 16, 4, ann_left_width, ann_left_height, ann_left_bitmap, 0, 0 },
|
||||||
{ ANN_RIGHT, 61, 4, ann_right_width, ann_right_height, ann_right_bitmap, 0,
|
{ ANN_RIGHT, 61, 4, ann_right_width, ann_right_height, ann_right_bitmap, 0,
|
||||||
0 },
|
0 },
|
||||||
|
@ -828,7 +821,136 @@ ann_struct_t ann_tbl[] = {
|
||||||
0 },
|
0 },
|
||||||
{ ANN_IO, 241, 4, ann_io_width, ann_io_height, ann_io_bitmap, 0, 0 },
|
{ ANN_IO, 241, 4, ann_io_width, ann_io_height, ann_io_bitmap, 0, 0 },
|
||||||
{ 0 } };
|
{ 0 } };
|
||||||
/* \ x48_lcd.c */
|
|
||||||
|
letter_t sdl_small_font[] = {
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ nl_gx_width, nl_gx_height, nl_gx_bitmap }, /* \001 == \n gx */
|
||||||
|
{ comma_gx_width, comma_gx_height, comma_gx_bitmap }, /* \002 == comma gx */
|
||||||
|
{ arrow_gx_width, arrow_gx_height, arrow_gx_bitmap }, /* \003 == \-> gx */
|
||||||
|
{ equal_gx_width, equal_gx_height, equal_gx_bitmap }, /* \004 == equal gx */
|
||||||
|
{ pi_gx_width, pi_gx_height, pi_gx_bitmap }, /* \005 == pi gx */
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 }, /* # 16 */
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ blank_width, blank_height, blank_bitmap }, /* # 32 */
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ hash_width, hash_height, hash_bitmap },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ lbrace_width, lbrace_height, lbrace_bitmap },
|
||||||
|
{ rbrace_width, rbrace_height, rbrace_bitmap },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ comma_width, comma_height, comma_bitmap },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ slash_width, slash_height, slash_bitmap },
|
||||||
|
{ 0, 0, 0 }, /* # 48 */
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ two_width, two_height, two_bitmap },
|
||||||
|
{ three_width, three_height, three_bitmap },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ small_colon_width, small_colon_height, small_colon_bitmap },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ equal_width, equal_height, equal_bitmap },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 }, /* # 64 */
|
||||||
|
{ A_width, A_height, A_bitmap },
|
||||||
|
{ B_width, B_height, B_bitmap },
|
||||||
|
{ C_width, C_height, C_bitmap },
|
||||||
|
{ D_width, D_height, D_bitmap },
|
||||||
|
{ E_width, E_height, E_bitmap },
|
||||||
|
{ F_width, F_height, F_bitmap },
|
||||||
|
{ G_width, G_height, G_bitmap },
|
||||||
|
{ H_width, H_height, H_bitmap },
|
||||||
|
{ I_width, I_height, I_bitmap },
|
||||||
|
{ J_width, J_height, J_bitmap },
|
||||||
|
{ K_width, K_height, K_bitmap },
|
||||||
|
{ L_width, L_height, L_bitmap },
|
||||||
|
{ M_width, M_height, M_bitmap },
|
||||||
|
{ N_width, N_height, N_bitmap },
|
||||||
|
{ O_width, O_height, O_bitmap },
|
||||||
|
{ P_width, P_height, P_bitmap }, /* # 80 */
|
||||||
|
{ Q_width, Q_height, Q_bitmap },
|
||||||
|
{ R_width, R_height, R_bitmap },
|
||||||
|
{ S_width, S_height, S_bitmap },
|
||||||
|
{ T_width, T_height, T_bitmap },
|
||||||
|
{ U_width, U_height, U_bitmap },
|
||||||
|
{ V_width, V_height, V_bitmap },
|
||||||
|
{ W_width, W_height, W_bitmap },
|
||||||
|
{ X_width, X_height, X_bitmap },
|
||||||
|
{ Y_width, Y_height, Y_bitmap },
|
||||||
|
{ Z_width, Z_height, Z_bitmap },
|
||||||
|
{ lbracket_width, lbracket_height, lbracket_bitmap },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ rbracket_width, rbracket_height, rbracket_bitmap },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ under_width, under_height, under_bitmap },
|
||||||
|
{ 0, 0, 0 }, /* # 96 */
|
||||||
|
{ arrow_width, arrow_height, arrow_bitmap }, /* a == left arrow */
|
||||||
|
{ diff_width, diff_height, diff_bitmap }, /* b == differential */
|
||||||
|
{ integral_width, integral_height, integral_bitmap }, /* c == integral */
|
||||||
|
{ sigma_width, sigma_height, sigma_bitmap }, /* d == sigma */
|
||||||
|
{ sqr_width, sqr_height, sqr_bitmap }, /* e == sqr */
|
||||||
|
{ root_width, root_height, root_bitmap }, /* f == root */
|
||||||
|
{ pow10_width, pow10_height, pow10_bitmap }, /* g == pow10 */
|
||||||
|
{ exp_width, exp_height, exp_bitmap }, /* h == exp */
|
||||||
|
{ prog_width, prog_height, prog_bitmap }, /* i == << >> */
|
||||||
|
{ string_width, string_height, string_bitmap }, /* j == " " */
|
||||||
|
{ nl_width, nl_height, nl_bitmap }, /* k == New Line */
|
||||||
|
{ pi_width, pi_height, pi_bitmap }, /* l == pi */
|
||||||
|
{ angle_width, angle_height, angle_bitmap }, /* m == angle */
|
||||||
|
{ sqr_gx_width, sqr_gx_height, sqr_gx_bitmap }, /* n == sqr gx */
|
||||||
|
{ root_gx_width, root_gx_height, root_gx_bitmap }, /* o == root gx */
|
||||||
|
{ pow10_gx_width, pow10_gx_height, pow10_gx_bitmap }, /* p == pow10 gx */
|
||||||
|
{ exp_gx_width, exp_gx_height, exp_gx_bitmap }, /* q == exp gx */
|
||||||
|
{ parens_gx_width, parens_gx_height, parens_gx_bitmap }, /* r == ( ) gx */
|
||||||
|
{ hash_gx_width, hash_gx_height, hash_gx_bitmap }, /* s == # gx */
|
||||||
|
{ bracket_gx_width, bracket_gx_height, bracket_gx_bitmap }, /* t == [] gx */
|
||||||
|
{ under_gx_width, under_gx_height, under_gx_bitmap }, /* u == _ gx */
|
||||||
|
{ prog_gx_width, prog_gx_height, prog_gx_bitmap }, /* v == << >> gx */
|
||||||
|
{ quote_gx_width, quote_gx_height, quote_gx_bitmap }, /* w == " " gx */
|
||||||
|
{ curly_gx_width, curly_gx_height, curly_gx_bitmap }, /* x == {} gx */
|
||||||
|
{ colon_gx_width, colon_gx_height, colon_gx_bitmap }, /* y == :: gx */
|
||||||
|
{ angle_gx_width, angle_gx_height, angle_gx_bitmap }, /* z == angle gx */
|
||||||
|
{ lcurly_width, lcurly_height, lcurly_bitmap },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ rcurly_width, rcurly_height, rcurly_bitmap },
|
||||||
|
{ 0, 0, 0 },
|
||||||
|
{ 0, 0, 0 } };
|
||||||
|
|
||||||
// State to displayed zoomed last pressed key
|
// State to displayed zoomed last pressed key
|
||||||
SDL_Surface* showkeylastsurf = 0;
|
SDL_Surface* showkeylastsurf = 0;
|
||||||
|
@ -836,6 +958,13 @@ int showkeylastx, showkeylasty, showkeylastkey;
|
||||||
|
|
||||||
SDL_Surface* sdlwindow;
|
SDL_Surface* sdlwindow;
|
||||||
|
|
||||||
|
int sdl_last_annunc_state = -1;
|
||||||
|
|
||||||
|
// display_t sdl_display;
|
||||||
|
|
||||||
|
unsigned char sdl_disp_buf[ DISP_ROWS ][ NIBS_PER_BUFFER_ROW ];
|
||||||
|
unsigned char sdl_lcd_buffer[ DISP_ROWS ][ NIBS_PER_BUFFER_ROW ];
|
||||||
|
|
||||||
/****************************/
|
/****************************/
|
||||||
/* functions implementation */
|
/* functions implementation */
|
||||||
/****************************/
|
/****************************/
|
||||||
|
@ -885,14 +1014,14 @@ SDL_Surface* SDLCreateSurfFromData( unsigned int w, unsigned int h,
|
||||||
return surf;
|
return surf;
|
||||||
}
|
}
|
||||||
|
|
||||||
int SmallTextWidth( const char* string, unsigned int length ) {
|
int sdl_SmallTextWidth( const char* string, unsigned int length ) {
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
int w;
|
int w;
|
||||||
|
|
||||||
w = 0;
|
w = 0;
|
||||||
for ( i = 0; i < length; i++ ) {
|
for ( i = 0; i < length; i++ ) {
|
||||||
if ( small_font[ ( int )string[ i ] ].h != 0 ) {
|
if ( sdl_small_font[ ( int )string[ i ] ].h != 0 ) {
|
||||||
w += small_font[ ( int )string[ i ] ].w + 1;
|
w += sdl_small_font[ ( int )string[ i ] ].w + 1;
|
||||||
} else {
|
} else {
|
||||||
if ( verbose )
|
if ( verbose )
|
||||||
fprintf( stderr, "Unknown small letter 0x00%x\n",
|
fprintf( stderr, "Unknown small letter 0x00%x\n",
|
||||||
|
@ -909,12 +1038,12 @@ void SDLDrawSmallString( int x, int y, const char* string, unsigned int length,
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
|
||||||
for ( i = 0; i < length; i++ ) {
|
for ( i = 0; i < length; i++ ) {
|
||||||
if ( small_font[ ( int )string[ i ] ].h != 0 ) {
|
if ( sdl_small_font[ ( int )string[ i ] ].h != 0 ) {
|
||||||
int w = small_font[ ( int )string[ i ] ].w;
|
int w = sdl_small_font[ ( int )string[ i ] ].w;
|
||||||
int h = small_font[ ( int )string[ i ] ].h;
|
int h = sdl_small_font[ ( int )string[ i ] ].h;
|
||||||
|
|
||||||
SDL_Surface* surf = SDLCreateSurfFromData(
|
SDL_Surface* surf = SDLCreateSurfFromData(
|
||||||
w, h, small_font[ ( int )string[ i ] ].bits, coloron,
|
w, h, sdl_small_font[ ( int )string[ i ] ].bits, coloron,
|
||||||
coloroff );
|
coloroff );
|
||||||
|
|
||||||
SDL_Rect srect;
|
SDL_Rect srect;
|
||||||
|
@ -924,13 +1053,13 @@ void SDLDrawSmallString( int x, int y, const char* string, unsigned int length,
|
||||||
srect.w = w;
|
srect.w = w;
|
||||||
srect.h = h;
|
srect.h = h;
|
||||||
drect.x = x;
|
drect.x = x;
|
||||||
drect.y = ( int )( y - small_font[ ( int )string[ i ] ].h );
|
drect.y = ( int )( y - sdl_small_font[ ( int )string[ i ] ].h );
|
||||||
drect.w = w;
|
drect.w = w;
|
||||||
drect.h = h;
|
drect.h = h;
|
||||||
SDL_BlitSurface( surf, &srect, sdlwindow, &drect );
|
SDL_BlitSurface( surf, &srect, sdlwindow, &drect );
|
||||||
SDL_FreeSurface( surf );
|
SDL_FreeSurface( surf );
|
||||||
}
|
}
|
||||||
x += SmallTextWidth( &string[ i ], 1 );
|
x += sdl_SmallTextWidth( &string[ i ], 1 );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -987,7 +1116,7 @@ void SDLInit( void ) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void button_pressed( int b ) {
|
void sdl_button_pressed( int b ) {
|
||||||
int code;
|
int code;
|
||||||
|
|
||||||
// Check not already pressed (may be important: avoids a useless do_kbd_int)
|
// Check not already pressed (may be important: avoids a useless do_kbd_int)
|
||||||
|
@ -1015,7 +1144,7 @@ void button_pressed( int b ) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void button_released( int b ) {
|
void sdl_button_released( int b ) {
|
||||||
int code;
|
int code;
|
||||||
|
|
||||||
// Check not already released (not critical)
|
// Check not already released (not critical)
|
||||||
|
@ -1039,8 +1168,8 @@ void SDLCreateColors( void ) {
|
||||||
unsigned i;
|
unsigned i;
|
||||||
|
|
||||||
for ( i = WHITE; i < BLACK; i++ )
|
for ( i = WHITE; i < BLACK; i++ )
|
||||||
ARGBColors[ i ] = 0xff000000 | ( colors[ i ].r << 16 ) |
|
ARGBColors[ i ] = 0xff000000 | ( sdl_colors[ i ].r << 16 ) |
|
||||||
( colors[ i ].g << 8 ) | colors[ i ].b;
|
( sdl_colors[ i ].g << 8 ) | sdl_colors[ i ].b;
|
||||||
|
|
||||||
// Adjust the LCD color according to the contrast
|
// Adjust the LCD color according to the contrast
|
||||||
int contrast, r, g, b;
|
int contrast, r, g, b;
|
||||||
|
@ -1051,9 +1180,10 @@ void SDLCreateColors( void ) {
|
||||||
if ( contrast > 0x13 )
|
if ( contrast > 0x13 )
|
||||||
contrast = 0x13;
|
contrast = 0x13;
|
||||||
|
|
||||||
r = ( 0x13 - contrast ) * ( colors[ LCD ].r / 0x10 );
|
r = ( 0x13 - contrast ) * ( sdl_colors[ LCD ].r / 0x10 );
|
||||||
g = ( 0x13 - contrast ) * ( colors[ LCD ].g / 0x10 );
|
g = ( 0x13 - contrast ) * ( sdl_colors[ LCD ].g / 0x10 );
|
||||||
b = 128 - ( ( 0x13 - contrast ) * ( ( 128 - colors[ LCD ].b ) / 0x10 ) );
|
b = 128 -
|
||||||
|
( ( 0x13 - contrast ) * ( ( 128 - sdl_colors[ LCD ].b ) / 0x10 ) );
|
||||||
ARGBColors[ PIXEL ] = 0xff000000 | ( r << 16 ) | ( g << 8 ) | b;
|
ARGBColors[ PIXEL ] = 0xff000000 | ( r << 16 ) | ( g << 8 ) | b;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1082,22 +1212,6 @@ void SDLCreateAnnunc( void ) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ui__adjust_contrast() {
|
|
||||||
SDLCreateColors();
|
|
||||||
SDLCreateAnnunc();
|
|
||||||
|
|
||||||
// redraw LCD
|
|
||||||
memset( disp_buf, 0, sizeof( disp_buf ) );
|
|
||||||
memset( lcd_buffer, 0, sizeof( lcd_buffer ) );
|
|
||||||
|
|
||||||
ui__update_LCD();
|
|
||||||
|
|
||||||
// redraw annunc
|
|
||||||
last_annunc_state = -1;
|
|
||||||
|
|
||||||
ui__draw_annunc();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Find which key is pressed, if any.
|
// Find which key is pressed, if any.
|
||||||
// Returns -1 is no key is pressed
|
// Returns -1 is no key is pressed
|
||||||
int SDLCoordinateToKey( unsigned int x, unsigned int y ) {
|
int SDLCoordinateToKey( unsigned int x, unsigned int y ) {
|
||||||
|
@ -1891,8 +2005,8 @@ void SDLDrawKeysLabelsLeft( void ) {
|
||||||
colorfg = ARGBColors[ LEFT ];
|
colorfg = ARGBColors[ LEFT ];
|
||||||
|
|
||||||
x = ( pw + 1 -
|
x = ( pw + 1 -
|
||||||
SmallTextWidth( buttons[ i ].left,
|
sdl_SmallTextWidth( buttons[ i ].left,
|
||||||
strlen( buttons[ i ].left ) ) ) /
|
strlen( buttons[ i ].left ) ) ) /
|
||||||
2;
|
2;
|
||||||
if ( opt_gx )
|
if ( opt_gx )
|
||||||
y = 14;
|
y = 14;
|
||||||
|
@ -1920,16 +2034,16 @@ void SDLDrawKeysLabelsLeft( void ) {
|
||||||
// centered label
|
// centered label
|
||||||
x = offset_x + buttons[ i ].x +
|
x = offset_x + buttons[ i ].x +
|
||||||
( 1 + buttons[ i ].w -
|
( 1 + buttons[ i ].w -
|
||||||
SmallTextWidth( buttons[ i ].left,
|
sdl_SmallTextWidth( buttons[ i ].left,
|
||||||
strlen( buttons[ i ].left ) ) ) /
|
strlen( buttons[ i ].left ) ) ) /
|
||||||
2;
|
2;
|
||||||
} else {
|
} else {
|
||||||
// label to the left
|
// label to the left
|
||||||
wl = SmallTextWidth( buttons[ i ].left,
|
wl = sdl_SmallTextWidth( buttons[ i ].left,
|
||||||
strlen( buttons[ i ].left ) );
|
strlen( buttons[ i ].left ) );
|
||||||
wr = SmallTextWidth( buttons[ i ].right,
|
wr = sdl_SmallTextWidth( buttons[ i ].right,
|
||||||
strlen( buttons[ i ].right ) );
|
strlen( buttons[ i ].right ) );
|
||||||
ws = SmallTextWidth( " ", 1 );
|
ws = sdl_SmallTextWidth( " ", 1 );
|
||||||
|
|
||||||
x = offset_x + buttons[ i ].x +
|
x = offset_x + buttons[ i ].x +
|
||||||
( 1 + buttons[ i ].w - ( wl + wr + ws ) ) / 2;
|
( 1 + buttons[ i ].w - ( wl + wr + ws ) ) / 2;
|
||||||
|
@ -1970,8 +2084,8 @@ void SDLDrawKeysLabelsRight( void ) {
|
||||||
colorfg = ARGBColors[ RIGHT ];
|
colorfg = ARGBColors[ RIGHT ];
|
||||||
|
|
||||||
x = ( pw + 1 -
|
x = ( pw + 1 -
|
||||||
SmallTextWidth( buttons[ i ].right,
|
sdl_SmallTextWidth( buttons[ i ].right,
|
||||||
strlen( buttons[ i ].right ) ) ) /
|
strlen( buttons[ i ].right ) ) ) /
|
||||||
2;
|
2;
|
||||||
if ( opt_gx )
|
if ( opt_gx )
|
||||||
y = 14;
|
y = 14;
|
||||||
|
@ -2000,16 +2114,16 @@ void SDLDrawKeysLabelsRight( void ) {
|
||||||
// centered label
|
// centered label
|
||||||
x = offset_x + buttons[ i ].x +
|
x = offset_x + buttons[ i ].x +
|
||||||
( 1 + buttons[ i ].w -
|
( 1 + buttons[ i ].w -
|
||||||
SmallTextWidth( buttons[ i ].right,
|
sdl_SmallTextWidth( buttons[ i ].right,
|
||||||
strlen( buttons[ i ].right ) ) ) /
|
strlen( buttons[ i ].right ) ) ) /
|
||||||
2;
|
2;
|
||||||
} else {
|
} else {
|
||||||
// label to the right
|
// label to the right
|
||||||
wl = SmallTextWidth( buttons[ i ].left,
|
wl = sdl_SmallTextWidth( buttons[ i ].left,
|
||||||
strlen( buttons[ i ].left ) );
|
strlen( buttons[ i ].left ) );
|
||||||
wr = SmallTextWidth( buttons[ i ].right,
|
wr = sdl_SmallTextWidth( buttons[ i ].right,
|
||||||
strlen( buttons[ i ].right ) );
|
strlen( buttons[ i ].right ) );
|
||||||
ws = SmallTextWidth( " ", 1 );
|
ws = sdl_SmallTextWidth( " ", 1 );
|
||||||
|
|
||||||
x = offset_x + buttons[ i ].x +
|
x = offset_x + buttons[ i ].x +
|
||||||
( 1 + buttons[ i ].w - ( wl + wr + ws ) ) / 2 + wl + ws;
|
( 1 + buttons[ i ].w - ( wl + wr + ws ) ) / 2 + wl + ws;
|
||||||
|
@ -2046,7 +2160,7 @@ void SDLDrawKeysLetters( void ) {
|
||||||
y = offset_y + buttons[ i ].y + buttons[ i ].h + 1;
|
y = offset_y + buttons[ i ].y + buttons[ i ].h + 1;
|
||||||
} else {
|
} else {
|
||||||
x = offset_x + buttons[ i ].x + buttons[ i ].w -
|
x = offset_x + buttons[ i ].x + buttons[ i ].w -
|
||||||
SmallTextWidth( buttons[ i ].letter, 1 ) / 2 + 5;
|
sdl_SmallTextWidth( buttons[ i ].letter, 1 ) / 2 + 5;
|
||||||
y = offset_y + buttons[ i ].y + buttons[ i ].h - 2;
|
y = offset_y + buttons[ i ].y + buttons[ i ].h - 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2077,7 +2191,8 @@ void SDLDrawKeysLabelsBottom( void ) {
|
||||||
|
|
||||||
x = offset_x + buttons[ i ].x +
|
x = offset_x + buttons[ i ].x +
|
||||||
( 1 + buttons[ i ].w -
|
( 1 + buttons[ i ].w -
|
||||||
SmallTextWidth( buttons[ i ].sub, strlen( buttons[ i ].sub ) ) ) /
|
sdl_SmallTextWidth( buttons[ i ].sub,
|
||||||
|
strlen( buttons[ i ].sub ) ) ) /
|
||||||
2;
|
2;
|
||||||
y = offset_y + buttons[ i ].y + buttons[ i ].h + small_ascent + 2;
|
y = offset_y + buttons[ i ].y + buttons[ i ].h + small_ascent + 2;
|
||||||
SDLDrawSmallString( x, y, buttons[ i ].sub, strlen( buttons[ i ].sub ),
|
SDLDrawSmallString( x, y, buttons[ i ].sub, strlen( buttons[ i ].sub ),
|
||||||
|
@ -2341,8 +2456,8 @@ void SDLDrawNibble( int nx, int ny, int val ) {
|
||||||
|
|
||||||
for ( x = 0; x < 4; x++ ) {
|
for ( x = 0; x < 4; x++ ) {
|
||||||
// Check if bit is on
|
// Check if bit is on
|
||||||
// char c = lcd_buffer[y/2][x>>2]; // The 4 lower bits
|
// char c = sdl_lcd_buffer[y/2][x>>2]; // The 4 lower
|
||||||
// in a byte are used (1 nibble per byte)
|
// bits in a byte are used (1 nibble per byte)
|
||||||
if ( nx + x >= 131 ) // Clip at 131 pixels (some nibble writes may
|
if ( nx + x >= 131 ) // Clip at 131 pixels (some nibble writes may
|
||||||
// go beyond the range, but are not visible)
|
// go beyond the range, but are not visible)
|
||||||
break;
|
break;
|
||||||
|
@ -2455,7 +2570,7 @@ inline void SDLUIFeedback( void ) {}
|
||||||
static int button_release_all( void ) {
|
static int button_release_all( void ) {
|
||||||
for ( int b = BUTTON_A; b <= LAST_BUTTON; b++ )
|
for ( int b = BUTTON_A; b <= LAST_BUTTON; b++ )
|
||||||
if ( buttons[ b ].pressed ) {
|
if ( buttons[ b ].pressed ) {
|
||||||
button_released( b );
|
sdl_button_released( b );
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -2485,7 +2600,99 @@ void SDLDrawSerialDevices() {
|
||||||
stringColor( sdlwindow, 10, 240, text, 0xffffffff );
|
stringColor( sdlwindow, 10, 240, text, 0xffffffff );
|
||||||
}
|
}
|
||||||
|
|
||||||
int ui__get_event( void ) {
|
static inline void draw_nibble( int c, int r, int val ) {
|
||||||
|
int x, y;
|
||||||
|
|
||||||
|
x = ( c * 4 ); // x: start in pixels
|
||||||
|
|
||||||
|
if ( r <= display.lines )
|
||||||
|
x -= 2 * display.offset;
|
||||||
|
y = r; // y: start in pixels
|
||||||
|
|
||||||
|
val &= 0x0f;
|
||||||
|
if ( val != sdl_lcd_buffer[ r ][ c ] ) {
|
||||||
|
sdl_lcd_buffer[ r ][ c ] = val;
|
||||||
|
}
|
||||||
|
if ( val != sdl_lcd_buffer[ r ][ c ] )
|
||||||
|
sdl_lcd_buffer[ r ][ c ] = val;
|
||||||
|
|
||||||
|
SDLDrawNibble( x, y, val );
|
||||||
|
}
|
||||||
|
|
||||||
|
/* void ui_sdl__draw_nibble( int c, int r, int val ) { draw_nibble( c, r, val );
|
||||||
|
* }
|
||||||
|
*/
|
||||||
|
|
||||||
|
static inline void draw_row( long addr, int row ) {
|
||||||
|
int i, v;
|
||||||
|
int line_length;
|
||||||
|
|
||||||
|
line_length = NIBBLES_PER_ROW;
|
||||||
|
if ( ( display.offset > 3 ) && ( row <= display.lines ) )
|
||||||
|
line_length += 2;
|
||||||
|
for ( i = 0; i < line_length; i++ ) {
|
||||||
|
v = read_nibble( addr + i );
|
||||||
|
if ( v != sdl_disp_buf[ row ][ i ] ) {
|
||||||
|
sdl_disp_buf[ row ][ i ] = v;
|
||||||
|
draw_nibble( i, row, v );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void SDLCreateHP( void ) {
|
||||||
|
unsigned int width, height;
|
||||||
|
|
||||||
|
if ( show_ui_chrome ) {
|
||||||
|
width = KEYBOARD_WIDTH + 2 * SIDE_SKIP;
|
||||||
|
height = DISPLAY_OFFSET_Y + DISPLAY_HEIGHT + DISP_KBD_SKIP +
|
||||||
|
KEYBOARD_HEIGHT + BOTTOM_SKIP;
|
||||||
|
} else {
|
||||||
|
width = KEYBOARD_WIDTH;
|
||||||
|
height = DISPLAY_HEIGHT;
|
||||||
|
}
|
||||||
|
|
||||||
|
keypad.width = width;
|
||||||
|
keypad.height = height;
|
||||||
|
|
||||||
|
sdl_colors = opt_gx ? sdl_colors_gx : sdl_colors_sx;
|
||||||
|
|
||||||
|
// we allocate memory for the buttons because we need to modify
|
||||||
|
// their coordinates, and we don't want to change the original buttons_gx or
|
||||||
|
// buttons_sx
|
||||||
|
if ( buttons ) {
|
||||||
|
free( buttons );
|
||||||
|
buttons = 0;
|
||||||
|
}
|
||||||
|
buttons = ( ui_sdl__button_t* )malloc( sizeof( buttons_gx ) );
|
||||||
|
|
||||||
|
if ( opt_gx )
|
||||||
|
memcpy( buttons, buttons_gx, sizeof( buttons_gx ) );
|
||||||
|
else
|
||||||
|
memcpy( buttons, buttons_sx, sizeof( buttons_sx ) );
|
||||||
|
|
||||||
|
SDLCreateColors();
|
||||||
|
|
||||||
|
if ( show_ui_chrome ) {
|
||||||
|
int cut = buttons[ BUTTON_MTH ].y + KEYBOARD_OFFSET_Y - 19;
|
||||||
|
|
||||||
|
SDLDrawBackground( width, cut, width, height );
|
||||||
|
SDLDrawMore( cut, KEYBOARD_OFFSET_Y, keypad.width, keypad.height );
|
||||||
|
SDLDrawLogo();
|
||||||
|
SDLDrawBezel();
|
||||||
|
SDLDrawKeypad();
|
||||||
|
|
||||||
|
SDLDrawSerialDevices();
|
||||||
|
}
|
||||||
|
|
||||||
|
SDLDrawBackgroundLCD();
|
||||||
|
|
||||||
|
SDL_UpdateRect( sdlwindow, 0, 0, 0, 0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**********/
|
||||||
|
/* public */
|
||||||
|
/**********/
|
||||||
|
int ui_sdl__get_event( void ) {
|
||||||
SDL_Event event;
|
SDL_Event event;
|
||||||
int hpkey;
|
int hpkey;
|
||||||
int rv;
|
int rv;
|
||||||
|
@ -2557,7 +2764,7 @@ int ui__get_event( void ) {
|
||||||
*/
|
*/
|
||||||
/* // time */
|
/* // time */
|
||||||
/* { */
|
/* { */
|
||||||
/* button_pressed( hpkey ); */
|
/* sdl_button_pressed( hpkey ); */
|
||||||
/* rv = 1; */
|
/* rv = 1; */
|
||||||
/* // Start timer */
|
/* // Start timer */
|
||||||
/* lastticks = SDL_GetTicks(); */
|
/* lastticks = SDL_GetTicks(); */
|
||||||
|
@ -2587,7 +2794,7 @@ int ui__get_event( void ) {
|
||||||
if ( !buttons[ hpkey ].pressed ) // Key can't be pressed
|
if ( !buttons[ hpkey ].pressed ) // Key can't be pressed
|
||||||
// when down
|
// when down
|
||||||
{
|
{
|
||||||
button_pressed( hpkey );
|
sdl_button_pressed( hpkey );
|
||||||
rv = 1;
|
rv = 1;
|
||||||
lasthpkey = hpkey;
|
lasthpkey = hpkey;
|
||||||
// Start timer
|
// Start timer
|
||||||
|
@ -2621,14 +2828,14 @@ int ui__get_event( void ) {
|
||||||
|
|
||||||
// Avoid pressing if it is already pressed
|
// Avoid pressing if it is already pressed
|
||||||
if ( !buttons[ hpkey ].pressed ) {
|
if ( !buttons[ hpkey ].pressed ) {
|
||||||
button_pressed( hpkey );
|
sdl_button_pressed( hpkey );
|
||||||
rv = 1;
|
rv = 1;
|
||||||
SDLUIFeedback();
|
SDLUIFeedback();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
keyispressed = -1;
|
keyispressed = -1;
|
||||||
|
|
||||||
button_released( hpkey );
|
sdl_button_released( hpkey );
|
||||||
rv = 1;
|
rv = 1;
|
||||||
SDLUIFeedback();
|
SDLUIFeedback();
|
||||||
}
|
}
|
||||||
|
@ -2668,47 +2875,7 @@ int ui__get_event( void ) {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* x48_lcd.c */
|
void ui_sdl__update_LCD( void ) {
|
||||||
|
|
||||||
static inline void draw_nibble( int c, int r, int val ) {
|
|
||||||
int x, y;
|
|
||||||
|
|
||||||
x = ( c * 4 ); // x: start in pixels
|
|
||||||
|
|
||||||
if ( r <= display.lines )
|
|
||||||
x -= 2 * display.offset;
|
|
||||||
y = r; // y: start in pixels
|
|
||||||
|
|
||||||
val &= 0x0f;
|
|
||||||
if ( val != lcd_buffer[ r ][ c ] ) {
|
|
||||||
lcd_buffer[ r ][ c ] = val;
|
|
||||||
}
|
|
||||||
if ( val != lcd_buffer[ r ][ c ] )
|
|
||||||
lcd_buffer[ r ][ c ] = val;
|
|
||||||
|
|
||||||
SDLDrawNibble( x, y, val );
|
|
||||||
}
|
|
||||||
|
|
||||||
/* void ui__draw_nibble( int c, int r, int val ) { draw_nibble( c, r, val ); }
|
|
||||||
*/
|
|
||||||
|
|
||||||
static inline void draw_row( long addr, int row ) {
|
|
||||||
int i, v;
|
|
||||||
int line_length;
|
|
||||||
|
|
||||||
line_length = NIBBLES_PER_ROW;
|
|
||||||
if ( ( display.offset > 3 ) && ( row <= display.lines ) )
|
|
||||||
line_length += 2;
|
|
||||||
for ( i = 0; i < line_length; i++ ) {
|
|
||||||
v = read_nibble( addr + i );
|
|
||||||
if ( v != disp_buf[ row ][ i ] ) {
|
|
||||||
disp_buf[ row ][ i ] = v;
|
|
||||||
draw_nibble( i, row, v );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void ui__update_LCD( void ) {
|
|
||||||
int i, j;
|
int i, j;
|
||||||
long addr;
|
long addr;
|
||||||
static int old_offset = -1;
|
static int old_offset = -1;
|
||||||
|
@ -2717,16 +2884,16 @@ void ui__update_LCD( void ) {
|
||||||
if ( display.on ) {
|
if ( display.on ) {
|
||||||
addr = display.disp_start;
|
addr = display.disp_start;
|
||||||
if ( display.offset != old_offset ) {
|
if ( display.offset != old_offset ) {
|
||||||
memset( disp_buf, 0xf0,
|
memset( sdl_disp_buf, 0xf0,
|
||||||
( size_t )( ( display.lines + 1 ) * NIBS_PER_BUFFER_ROW ) );
|
( size_t )( ( display.lines + 1 ) * NIBS_PER_BUFFER_ROW ) );
|
||||||
memset( lcd_buffer, 0xf0,
|
memset( sdl_lcd_buffer, 0xf0,
|
||||||
( size_t )( ( display.lines + 1 ) * NIBS_PER_BUFFER_ROW ) );
|
( size_t )( ( display.lines + 1 ) * NIBS_PER_BUFFER_ROW ) );
|
||||||
old_offset = display.offset;
|
old_offset = display.offset;
|
||||||
}
|
}
|
||||||
if ( display.lines != old_lines ) {
|
if ( display.lines != old_lines ) {
|
||||||
memset( &disp_buf[ 56 ][ 0 ], 0xf0,
|
memset( &sdl_disp_buf[ 56 ][ 0 ], 0xf0,
|
||||||
( size_t )( 8 * NIBS_PER_BUFFER_ROW ) );
|
( size_t )( 8 * NIBS_PER_BUFFER_ROW ) );
|
||||||
memset( &lcd_buffer[ 56 ][ 0 ], 0xf0,
|
memset( &sdl_lcd_buffer[ 56 ][ 0 ], 0xf0,
|
||||||
( size_t )( 8 * NIBS_PER_BUFFER_ROW ) );
|
( size_t )( 8 * NIBS_PER_BUFFER_ROW ) );
|
||||||
old_lines = display.lines;
|
old_lines = display.lines;
|
||||||
}
|
}
|
||||||
|
@ -2742,7 +2909,7 @@ void ui__update_LCD( void ) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
memset( disp_buf, 0xf0, sizeof( disp_buf ) );
|
memset( sdl_disp_buf, 0xf0, sizeof( sdl_disp_buf ) );
|
||||||
for ( i = 0; i < 64; i++ ) {
|
for ( i = 0; i < 64; i++ ) {
|
||||||
for ( j = 0; j < NIBBLES_PER_ROW; j++ ) {
|
for ( j = 0; j < NIBBLES_PER_ROW; j++ ) {
|
||||||
draw_nibble( j, i, 0x00 );
|
draw_nibble( j, i, 0x00 );
|
||||||
|
@ -2751,7 +2918,7 @@ void ui__update_LCD( void ) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ui__disp_draw_nibble( word_20 addr, word_4 val ) {
|
void ui_sdl__disp_draw_nibble( word_20 addr, word_4 val ) {
|
||||||
long offset;
|
long offset;
|
||||||
int x, y;
|
int x, y;
|
||||||
|
|
||||||
|
@ -2763,42 +2930,42 @@ void ui__disp_draw_nibble( word_20 addr, word_4 val ) {
|
||||||
y = offset / display.nibs_per_line;
|
y = offset / display.nibs_per_line;
|
||||||
if ( y < 0 || y > 63 )
|
if ( y < 0 || y > 63 )
|
||||||
return;
|
return;
|
||||||
if ( val != disp_buf[ y ][ x ] ) {
|
if ( val != sdl_disp_buf[ y ][ x ] ) {
|
||||||
disp_buf[ y ][ x ] = val;
|
sdl_disp_buf[ y ][ x ] = val;
|
||||||
draw_nibble( x, y, val );
|
draw_nibble( x, y, val );
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
for ( y = 0; y < display.lines; y++ ) {
|
for ( y = 0; y < display.lines; y++ ) {
|
||||||
if ( val != disp_buf[ y ][ x ] ) {
|
if ( val != sdl_disp_buf[ y ][ x ] ) {
|
||||||
disp_buf[ y ][ x ] = val;
|
sdl_disp_buf[ y ][ x ] = val;
|
||||||
draw_nibble( x, y, val );
|
draw_nibble( x, y, val );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ui__menu_draw_nibble( word_20 addr, word_4 val ) {
|
void ui_sdl__menu_draw_nibble( word_20 addr, word_4 val ) {
|
||||||
long offset;
|
long offset;
|
||||||
int x, y;
|
int x, y;
|
||||||
|
|
||||||
offset = ( addr - display.menu_start );
|
offset = ( addr - display.menu_start );
|
||||||
x = offset % NIBBLES_PER_ROW;
|
x = offset % NIBBLES_PER_ROW;
|
||||||
y = display.lines + ( offset / NIBBLES_PER_ROW ) + 1;
|
y = display.lines + ( offset / NIBBLES_PER_ROW ) + 1;
|
||||||
if ( val != disp_buf[ y ][ x ] ) {
|
if ( val != sdl_disp_buf[ y ][ x ] ) {
|
||||||
disp_buf[ y ][ x ] = val;
|
sdl_disp_buf[ y ][ x ] = val;
|
||||||
draw_nibble( x, y, val );
|
draw_nibble( x, y, val );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ui__draw_annunc( void ) {
|
void ui_sdl__draw_annunc( void ) {
|
||||||
int val;
|
int val;
|
||||||
|
|
||||||
val = display.annunc;
|
val = display.annunc;
|
||||||
|
|
||||||
if ( val == last_annunc_state )
|
if ( val == sdl_last_annunc_state )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
last_annunc_state = val;
|
sdl_last_annunc_state = val;
|
||||||
|
|
||||||
char sdl_annuncstate[ 6 ];
|
char sdl_annuncstate[ 6 ];
|
||||||
for ( int i = 0; ann_tbl[ i ].bit; i++ )
|
for ( int i = 0; ann_tbl[ i ].bit; i++ )
|
||||||
|
@ -2808,7 +2975,23 @@ void ui__draw_annunc( void ) {
|
||||||
SDLDrawAnnunc( sdl_annuncstate );
|
SDLDrawAnnunc( sdl_annuncstate );
|
||||||
}
|
}
|
||||||
|
|
||||||
void ui__init_LCD( void ) {
|
void ui_sdl__adjust_contrast() {
|
||||||
|
SDLCreateColors();
|
||||||
|
SDLCreateAnnunc();
|
||||||
|
|
||||||
|
// redraw LCD
|
||||||
|
memset( sdl_disp_buf, 0, sizeof( sdl_disp_buf ) );
|
||||||
|
memset( sdl_lcd_buffer, 0, sizeof( sdl_lcd_buffer ) );
|
||||||
|
|
||||||
|
ui_sdl__update_LCD();
|
||||||
|
|
||||||
|
// redraw annunc
|
||||||
|
sdl_last_annunc_state = -1;
|
||||||
|
|
||||||
|
ui_sdl__draw_annunc();
|
||||||
|
}
|
||||||
|
|
||||||
|
void ui_sdl__init_LCD( void ) {
|
||||||
display.on = ( int )( saturn.disp_io & 0x8 ) >> 3;
|
display.on = ( int )( saturn.disp_io & 0x8 ) >> 3;
|
||||||
|
|
||||||
display.disp_start = ( saturn.disp_addr & 0xffffe );
|
display.disp_start = ( saturn.disp_addr & 0xffffe );
|
||||||
|
@ -2836,63 +3019,12 @@ void ui__init_LCD( void ) {
|
||||||
|
|
||||||
display.annunc = saturn.annunc;
|
display.annunc = saturn.annunc;
|
||||||
|
|
||||||
memset( disp_buf, 0xf0, sizeof( disp_buf ) );
|
memset( sdl_disp_buf, 0xf0, sizeof( sdl_disp_buf ) );
|
||||||
memset( lcd_buffer, 0xf0, sizeof( lcd_buffer ) );
|
memset( sdl_lcd_buffer, 0xf0, sizeof( sdl_lcd_buffer ) );
|
||||||
}
|
|
||||||
/* \ x48_lcd.c */
|
|
||||||
|
|
||||||
void SDLCreateHP( void ) {
|
|
||||||
unsigned int width, height;
|
|
||||||
|
|
||||||
if ( show_ui_chrome ) {
|
|
||||||
width = KEYBOARD_WIDTH + 2 * SIDE_SKIP;
|
|
||||||
height = DISPLAY_OFFSET_Y + DISPLAY_HEIGHT + DISP_KBD_SKIP +
|
|
||||||
KEYBOARD_HEIGHT + BOTTOM_SKIP;
|
|
||||||
} else {
|
|
||||||
width = KEYBOARD_WIDTH;
|
|
||||||
height = DISPLAY_HEIGHT;
|
|
||||||
}
|
|
||||||
|
|
||||||
keypad.width = width;
|
|
||||||
keypad.height = height;
|
|
||||||
|
|
||||||
colors = opt_gx ? colors_gx : colors_sx;
|
|
||||||
|
|
||||||
// we allocate memory for the buttons because we need to modify
|
|
||||||
// their coordinates, and we don't want to change the original buttons_gx or
|
|
||||||
// buttons_sx
|
|
||||||
if ( buttons ) {
|
|
||||||
free( buttons );
|
|
||||||
buttons = 0;
|
|
||||||
}
|
|
||||||
buttons = ( button_t* )malloc( sizeof( buttons_gx ) );
|
|
||||||
|
|
||||||
if ( opt_gx )
|
|
||||||
memcpy( buttons, buttons_gx, sizeof( buttons_gx ) );
|
|
||||||
else
|
|
||||||
memcpy( buttons, buttons_sx, sizeof( buttons_sx ) );
|
|
||||||
|
|
||||||
SDLCreateColors();
|
|
||||||
|
|
||||||
if ( show_ui_chrome ) {
|
|
||||||
int cut = buttons[ BUTTON_MTH ].y + KEYBOARD_OFFSET_Y - 19;
|
|
||||||
|
|
||||||
SDLDrawBackground( width, cut, width, height );
|
|
||||||
SDLDrawMore( cut, KEYBOARD_OFFSET_Y, keypad.width, keypad.height );
|
|
||||||
SDLDrawLogo();
|
|
||||||
SDLDrawBezel();
|
|
||||||
SDLDrawKeypad();
|
|
||||||
|
|
||||||
SDLDrawSerialDevices();
|
|
||||||
}
|
|
||||||
|
|
||||||
SDLDrawBackgroundLCD();
|
|
||||||
|
|
||||||
SDL_UpdateRect( sdlwindow, 0, 0, 0, 0 );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void init_ui( int argc, char** argv ) {
|
void init_sdl_ui( int argc, char** argv ) {
|
||||||
SDLInit();
|
SDLInit();
|
||||||
SDLCreateHP();
|
SDLCreateHP();
|
||||||
ui__init_LCD();
|
ui_sdl__init_LCD();
|
||||||
}
|
}
|
||||||
|
|
1410
src/ui_x11.c
1410
src/ui_x11.c
File diff suppressed because it is too large
Load diff
Loading…
Reference in a new issue