code-shuffling++

This commit is contained in:
Gwenhael Le Moine 2023-09-15 17:59:13 +02:00
parent de336e4821
commit 5ba6943af6
No known key found for this signature in database
GPG key ID: FDFE3669426707A7
2 changed files with 66 additions and 60 deletions

View file

@ -25,7 +25,7 @@ extern int ui__get_event( void );
extern void ui__update_LCD( void ); extern void ui__update_LCD( void );
/* used in: hp48_emulate.c */ /* used in: hp48_emulate.c */
extern void ui__adjust_contrast(); extern void ui__adjust_contrast( void );
extern void ui__draw_annunc( void ); extern void ui__draw_annunc( void );
/* used in: debugger.c, ui_sdl.c */ /* used in: debugger.c, ui_sdl.c */

View file

@ -136,6 +136,13 @@
#define _KEYBOARD_OFFSET_X SIDE_SKIP #define _KEYBOARD_OFFSET_X SIDE_SKIP
#define _KEYBOARD_OFFSET_Y ( TOP_SKIP + DISPLAY_HEIGHT + DISP_KBD_SKIP ) #define _KEYBOARD_OFFSET_Y ( TOP_SKIP + DISPLAY_HEIGHT + DISP_KBD_SKIP )
// Control how the screen update is performed: at regular intervals (delayed)
// or immediatly Note: this is only for the LCD. The annunciators and the
// buttons are always immediately updated
// #define DELAYEDDISPUPDATE
// Interval in millisecond between screen updates
#define DISPUPDATEINTERVAL 200
/***********/ /***********/
/* typedef */ /* typedef */
/***********/ /***********/
@ -199,52 +206,14 @@ typedef struct SDLWINDOW {
int x, y; int x, y;
} SDLWINDOW_t; } SDLWINDOW_t;
/*************************/ typedef struct sdltohpkeymap_t {
/* Functions' prototypes */ SDLKey sdlkey;
/*************************/ int hpkey;
void redraw_annunc( void ); } sdltohpkeymap_t;
void redraw_LCD( void );
void ShowConnections();
void SDLDrawAnnunc( char* annunc );
void SDLCreateAnnunc( void );
void SDLDrawNibble( int nx, int ny, int val );
void SDLDrawKeypad( void );
void SDLDrawButtons( void );
SDL_Surface* SDLCreateSurfFromData( unsigned int w, unsigned int h,
unsigned char* data, unsigned int coloron,
unsigned int coloroff );
SDL_Surface* SDLCreateARGBSurfFromData( unsigned int w, unsigned int h,
unsigned char* data,
unsigned int xpcolor );
void SDLDrawSmallString( int x, int y, const char* string, unsigned int length,
unsigned int coloron, unsigned int coloroff );
void SDLCreateColors( void );
void SDLDrawKeyLetter( void );
unsigned SDLBGRA2ARGB( unsigned color );
void SDLDrawBezel();
void SDLDrawMore( unsigned int cut, unsigned int offset_y, int keypad_width,
int keypad_height );
void SDLDrawLogo();
void SDLDrawBackground( int width, int height, int w_top, int h_top );
void SDLUIShowKey( int hpkey );
void SDLUIHideKey( void );
void SDLUIFeedback( void );
SDLWINDOW_t SDLCreateWindow( int x, int y, int w, int h, unsigned color,
int framewidth, int inverted );
void SDLShowWindow( SDLWINDOW_t* win );
void SDLSHideWindow( SDLWINDOW_t* win );
void SDLARGBTo( unsigned color, unsigned* a, unsigned* r, unsigned* g,
unsigned* b );
unsigned SDLToARGB( unsigned a, unsigned r, unsigned g, unsigned b );
void SDLMessageBox( int w, int h, const char* title, const char* text[],
unsigned color, unsigned colortext, int center );
void SDLEventWaitClickOrKey( void );
void SDLShowInformation( void );
void SDLInit( void );
void SDLCreateHP( void );
/*************/
/* variables */
/*************/
disp_t disp; disp_t disp;
keypad_t keypad; keypad_t keypad;
@ -430,13 +399,6 @@ unsigned KEYBOARD_HEIGHT, KEYBOARD_WIDTH, TOP_SKIP, SIDE_SKIP, BOTTOM_SKIP,
DISPLAY_OFFSET_Y, DISP_FRAME, KEYBOARD_OFFSET_X, KEYBOARD_OFFSET_Y, DISPLAY_OFFSET_Y, DISP_FRAME, KEYBOARD_OFFSET_X, KEYBOARD_OFFSET_Y,
KBD_UPLINE; KBD_UPLINE;
// Control how the screen update is performed: at regular intervals (delayed)
// or immediatly Note: this is only for the LCD. The annunciators and the
// buttons are always immediately updated
// #define DELAYEDDISPUPDATE
// Interval in millisecond between screen updates
#define DISPUPDATEINTERVAL 200
unsigned int ARGBColors[ BLACK + 1 ]; unsigned int ARGBColors[ BLACK + 1 ];
button_t* buttons = 0; button_t* buttons = 0;
@ -1111,11 +1073,6 @@ ann_struct_t ann_tbl[] = {
{ 0 } }; { 0 } };
/* \ x48_lcd.c */ /* \ x48_lcd.c */
typedef struct sdltohpkeymap_t {
SDLKey sdlkey;
int hpkey;
} sdltohpkeymap_t;
sdltohpkeymap_t sdltohpkeymap[] = { sdltohpkeymap_t sdltohpkeymap[] = {
// Numbers // Numbers
{ SDLK_0, BUTTON_0 }, { SDLK_0, BUTTON_0 },
@ -1199,6 +1156,55 @@ sdltohpkeymap_t sdltohpkeymap[] = {
SDL_Surface* sdlwindow; SDL_Surface* sdlwindow;
/*************************/
/* Functions' prototypes */
/*************************/
void redraw_annunc( void );
void redraw_LCD( void );
void SDLDrawSerialDevices();
void SDLDrawAnnunc( char* annunc );
void SDLCreateAnnunc( void );
void SDLDrawNibble( int nx, int ny, int val );
void SDLDrawKeypad( void );
void SDLDrawButtons( void );
SDL_Surface* SDLCreateSurfFromData( unsigned int w, unsigned int h,
unsigned char* data, unsigned int coloron,
unsigned int coloroff );
SDL_Surface* SDLCreateARGBSurfFromData( unsigned int w, unsigned int h,
unsigned char* data,
unsigned int xpcolor );
void SDLDrawSmallString( int x, int y, const char* string, unsigned int length,
unsigned int coloron, unsigned int coloroff );
void SDLCreateColors( void );
void SDLDrawKeyLetter( void );
unsigned SDLBGRA2ARGB( unsigned color );
void SDLDrawBezel();
void SDLDrawMore( unsigned int cut, unsigned int offset_y, int keypad_width,
int keypad_height );
void SDLDrawLogo();
void SDLDrawBackground( int width, int height, int w_top, int h_top );
void SDLUIShowKey( int hpkey );
void SDLUIHideKey( void );
void SDLUIFeedback( void );
SDLWINDOW_t SDLCreateWindow( int x, int y, int w, int h, unsigned color,
int framewidth, int inverted );
void SDLShowWindow( SDLWINDOW_t* win );
void SDLSHideWindow( SDLWINDOW_t* win );
void SDLARGBTo( unsigned color, unsigned* a, unsigned* r, unsigned* g,
unsigned* b );
unsigned SDLToARGB( unsigned a, unsigned r, unsigned g, unsigned b );
void SDLMessageBox( int w, int h, const char* title, const char* text[],
unsigned color, unsigned colortext, int center );
void SDLEventWaitClickOrKey( void );
void SDLShowInformation( void );
void SDLInit( void );
void SDLCreateHP( void );
/****************************/
/* functions implementation */
/****************************/
void SDLInit( void ) { void SDLInit( void ) {
// Initialize SDL // Initialize SDL
if ( SDL_Init( SDL_INIT_VIDEO ) < 0 ) { if ( SDL_Init( SDL_INIT_VIDEO ) < 0 ) {
@ -1363,7 +1369,7 @@ void SDLCreateHP( void ) {
SDLDrawBezel(); SDLDrawBezel();
SDLDrawKeypad(); SDLDrawKeypad();
ShowConnections(); SDLDrawSerialDevices();
SDL_UpdateRect( sdlwindow, 0, 0, 0, 0 ); SDL_UpdateRect( sdlwindow, 0, 0, 0, 0 );
} }
@ -2921,7 +2927,7 @@ static int button_release_all( void ) {
return 0; return 0;
} }
void ShowConnections() { void SDLDrawSerialDevices() {
char text[ 1024 ]; char text[ 1024 ];
if ( verbose ) { if ( verbose ) {