diff options
author | Nicolas Bacca | 2002-10-22 22:58:34 +0000 |
---|---|---|
committer | Nicolas Bacca | 2002-10-22 22:58:34 +0000 |
commit | eaf9e6a78d98e100dcab642ddeb443e07d0573ea (patch) | |
tree | d3ce1a0c7bc794f8d63553b36a9cb4ee8c254426 | |
parent | 2297129a67d877c778ac7dbe33e22adb4f5c34b3 (diff) | |
download | scummvm-rg350-eaf9e6a78d98e100dcab642ddeb443e07d0573ea.tar.gz scummvm-rg350-eaf9e6a78d98e100dcab642ddeb443e07d0573ea.tar.bz2 scummvm-rg350-eaf9e6a78d98e100dcab642ddeb443e07d0573ea.zip |
New rendering, overlay, add optional support for GameX
svn-id: r5260
-rw-r--r-- | backends/wince/screen.cpp | 593 | ||||
-rw-r--r-- | backends/wince/screen.h | 20 |
2 files changed, 518 insertions, 95 deletions
diff --git a/backends/wince/screen.cpp b/backends/wince/screen.cpp index 7dac8759ba..78b318e254 100644 --- a/backends/wince/screen.cpp +++ b/backends/wince/screen.cpp @@ -28,12 +28,16 @@ #include "gx.h" #include "screen.h" #include "resource.h" +#include "dynamic_imports.h" #define COLORCONV565(r,g,b) \ (((r&0xf8)<<(11-3))|((g&0xfc)<<(5-2))|((b&0xf8)>>3)) #define COLORCONV555(r,g,b) \ (((r&0xf8)<<(10-3))|((g&0xf8)<<(5-2))|((b&0xf8)>>3)) #define COLORCONVMONO(r,g,b) ((((3*r>>3)+(g>>1)+(b>>3))>>colorscale)^invert) +#define RED_FROM_565(x) ((((x)>>11)&0x1F) << 3) +#define GREEN_FROM_565(x) ((((x)>>5)&0x3F) << 2) +#define BLUE_FROM_565(x) (((x)&0x1F) << 3) #define MAX_CLR 0x100 static UBYTE palRed[MAX_CLR]; @@ -49,24 +53,26 @@ extern UBYTE item_toolbar[]; extern UBYTE item_toolbar_colors[]; extern UBYTE item_toolbarPortrait[]; extern UBYTE item_toolbarPortrait_colors[]; -extern UBYTE item_keyboard[]; -extern UBYTE item_keyboard_colors[]; -extern UBYTE item_keyboardPortrait[]; -extern UBYTE item_keyboardPortrait_colors[]; extern UBYTE item_disk[]; extern UBYTE item_disk_colors[]; extern UBYTE item_skip[]; extern UBYTE item_skip_colors[]; -extern UBYTE item_soundOn[]; -extern UBYTE item_soundOn_colors[]; extern UBYTE item_soundOff[]; extern UBYTE item_soundOff_colors[]; -extern UBYTE item_monkeyLandscape[]; -extern UBYTE item_monkeyLandscape_colors[]; +extern UBYTE item_soundOn[]; +extern UBYTE item_soundOn_colors[]; extern UBYTE item_monkeyPortrait[]; extern UBYTE item_monkeyPortrait_colors[]; +extern UBYTE item_monkeyLandscape[]; +extern UBYTE item_monkeyLandscape_colors[]; +extern UBYTE item_keyboard[]; +extern UBYTE item_keyboard_colors[]; +extern UBYTE item_keyboardPortrait[]; +extern UBYTE item_keyboardPortrait_colors[]; extern UBYTE item_loading[]; extern UBYTE item_loading_colors[]; +extern UBYTE item_startup[]; +extern UBYTE item_startup_colors[]; extern bool sound_activated; @@ -77,6 +83,15 @@ bool draw_keyboard; GXDisplayProperties gxdp; int active; +UBYTE decomp[320 * 240]; +UBYTE comment_zone[8 * 220]; +UBYTE highlighted_zone[8 * 220]; +int _highlighted_index = -1; + +bool _gfx_mode_switch; +int _game_selection_X_offset; +int _game_selection_Y_offset; + struct tScreenGeometry { long width; @@ -92,6 +107,7 @@ struct tScreenGeometry tScreenGeometry geom[3]; +tScreenGeometry portrait_geometry; int currentScreenMode = 0; int useMode = 0; @@ -106,6 +122,7 @@ UBYTE *toolbar = NULL; typedef void (*tCls)(); typedef void (*tBlt)(UBYTE*); typedef void (*tBlt_part)(UBYTE*,int, int, int, int, UBYTE*); +typedef void (*tSet_565)(INT16 *buffer, int pitch, int x, int y, int width, int height); void mono_Cls(); void mono_Blt(UBYTE*); @@ -120,12 +137,50 @@ void hicolor555_Blt(UBYTE*); void hicolor555_Blt_part(UBYTE*, int, int, int, int, UBYTE*); void hicolor565_Blt(UBYTE*); void hicolor565_Blt_part(UBYTE*, int, int, int, int, UBYTE*); +void hicolor565_Get_565(INT16*, int, int, int, int, int); +void hicolor565_Set_565(INT16*, int, int, int, int, int); +void hicolor555_Set_565(INT16*, int, int, int, int, int); +void palette_Set_565(INT16*, int, int, int, int, int); +void mono_Set_565(INT16*, int, int, int, int, int); + + +void NULL_Get_565(INT16*, int, int, int, int, int); +void NULL_Set_565(INT16*, int, int, int, int, int); void palette_update(); +void printString(const char *, int, int, int, int = -1); +static byte textfont[] = {0,0,99,1,226,8,4,8,6,8,6,0,0,0,0,0,0,0,0,0,0,0,8,2,1,8,0,0,0,0,0,0,0,0,0,0,0,0,4,3,7,8,7,7,8,4,5,5,8,7,4,7,3,8,7,7,7,7,8,7,7,7,7,7,3,4,7,5,7,7,8,7,7,7,7,7,7,7,7,5,7,7, +7,8,7,7,7,7,7,7,7,7,7,8,7,7,7,5,8,5,8,8,7,7,7,6,7,7,7,7,7,5,6,7,5,8,7,7,7,7,7,7,7,7,7,8,7,7,7,5,3,5,0,8,7,7,7,7,7,7,0,6,7,7,7,5,5,5,7,0,6,8,8,7,7,7,7,7,0,7,7,0,0, +0,0,0,7,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,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,7,0,0,0,0,0,0,0,0,1,3,6,12, +24,62,3,0,128,192,96,48,24,124,192,0,0,3,62,24,12,6,3,1,0,192,124,24,48,96,192,128,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,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,237,74,72,0,0,0,0,0,128,128,128,0,0,0,0,0,0,0,0,0,0,0,0,0,60,66,153,161,161,153,66,60,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,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,0,0,0,0,0, +0,0,0,0,0,0,0,0,0,96,96,96,96,0,0,96,0,102,102,102,0,0,0,0,0,102,102,255,102,255,102,102,0,24,62,96,60,6,124,24,0,98,102,12,24,48,102,70,0,60,102,60,56,103,102,63,0,96,48,16,0,0,0,0,0,24,48,96,96,96,48,24,0,96,48,24,24,24,48,96,0, +0,102,60,255,60,102,0,0,0,24,24,126,24,24,0,0,0,0,0,0,0,48,48,96,0,0,0,126,0,0,0,0,0,0,0,0,0,96,96,0,0,3,6,12,24,48,96,0,60,102,102,102,102,102,60,0,24,24,56,24,24,24,126,0,60,102,6,12,48,96,126,0,60,102,6,28,6,102,60,0,6, +14,30,102,127,6,6,0,126,96,124,6,6,102,60,0,60,102,96,124,102,102,60,0,126,102,12,24,24,24,24,0,60,102,102,60,102,102,60,0,60,102,102,62,6,102,60,0,0,0,96,0,0,96,0,0,0,0,48,0,0,48,48,96,14,24,48,96,48,24,14,0,0,0,120,0,120,0,0,0,112,24, +12,6,12,24,112,0,60,102,6,12,24,0,24,0,0,0,0,255,255,0,0,0,24,60,102,126,102,102,102,0,124,102,102,124,102,102,124,0,60,102,96,96,96,102,60,0,120,108,102,102,102,108,120,0,126,96,96,120,96,96,126,0,126,96,96,120,96,96,96,0,60,102,96,110,102,102,60,0,102,102,102, +126,102,102,102,0,120,48,48,48,48,48,120,0,30,12,12,12,12,108,56,0,102,108,120,112,120,108,102,0,96,96,96,96,96,96,126,0,99,119,127,107,99,99,99,0,102,118,126,126,110,102,102,0,60,102,102,102,102,102,60,0,124,102,102,124,96,96,96,0,60,102,102,102,102,60,14,0,124,102,102,124, +120,108,102,0,60,102,96,60,6,102,60,0,126,24,24,24,24,24,24,0,102,102,102,102,102,102,60,0,102,102,102,102,102,60,24,0,99,99,99,107,127,119,99,0,102,102,60,24,60,102,102,0,102,102,102,60,24,24,24,0,126,6,12,24,48,96,126,0,120,96,96,96,96,96,120,0,3,6,12,24,48, +96,192,0,120,24,24,24,24,24,120,0,0,0,0,0,0,219,219,0,0,0,0,0,0,0,0,255,102,102,102,0,0,0,0,0,0,0,60,6,62,102,62,0,0,96,96,124,102,102,124,0,0,0,60,96,96,96,60,0,0,6,6,62,102,102,62,0,0,0,60,102,126,96,60,0,0,14,24,62,24,24, +24,0,0,0,62,102,102,62,6,124,0,96,96,124,102,102,102,0,0,48,0,112,48,48,120,0,0,12,0,12,12,12,12,120,0,96,96,108,120,108,102,0,0,112,48,48,48,48,120,0,0,0,102,127,127,107,99,0,0,0,124,102,102,102,102,0,0,0,60,102,102,102,60,0,0,0,124,102,102,124,96, +96,0,0,62,102,102,62,6,6,0,0,124,102,96,96,96,0,0,0,62,96,60,6,124,0,0,24,126,24,24,24,14,0,0,0,102,102,102,102,62,0,0,0,102,102,102,60,24,0,0,0,99,107,127,62,54,0,0,0,102,60,24,60,102,0,0,0,102,102,102,62,12,120,0,0,126,12,24,48,126,0, +24,48,48,96,48,48,24,0,96,96,96,0,96,96,96,0,96,48,48,24,48,48,96,0,0,0,0,0,0,0,0,0,8,12,14,255,255,14,12,8,60,102,96,96,102,60,24,56,102,0,102,102,102,102,62,0,12,24,60,102,126,96,60,0,24,36,60,6,62,102,62,0,102,0,60,6,62,102,62,0,48, +24,60,6,62,102,62,0,0,0,0,0,0,0,0,0,0,60,96,96,96,60,24,56,24,36,60,102,126,96,60,0,102,0,60,102,126,96,60,0,48,24,60,102,126,96,60,0,0,216,0,112,48,48,120,0,48,72,0,112,48,48,120,0,96,48,0,112,48,48,120,0,102,24,60,102,126,102,102,0,0,0, +0,0,0,0,0,0,24,48,124,96,120,96,124,0,0,0,108,26,126,216,110,0,30,40,40,126,72,136,142,0,24,36,60,102,102,102,60,0,102,0,60,102,102,102,60,0,48,24,60,102,102,102,60,0,24,36,0,102,102,102,62,0,48,24,102,102,102,102,62,0,0,0,0,0,0,0,0,0,102,60,102, +102,102,102,60,0,102,0,102,102,102,102,60,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,12,24,60,6,62,102,62,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,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,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,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,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,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,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,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,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,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,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,0,0,0,0,0,0,0,0,0,0,0,0, +0,0,0,0,0,0,28,54,54,124,102,102,124,64,0,0,0}; + static tCls pCls = NULL; static tBlt pBlt = NULL; static tBlt_part pBlt_part = NULL; +static tSet_565 pSet_565 = NULL; static int _geometry_w; static int _geometry_h; @@ -133,6 +188,26 @@ static int _saved_geometry_h; HWND hWndMain; +unsigned char *image_expand(unsigned char *src) { + int i = 0; + int j; + int expanded = 0; + + for (;;) { + if (!src[i]) { + if (!src[i + 1]) + break; + for (j=0; j<src[i + 1]; j++) + decomp[expanded++] = src[i+2]; + i += 3; + } + else + decomp[expanded++] = src[i++]; + } + + return decomp; +} + void SetScreenMode(int mode) { @@ -151,7 +226,7 @@ void GraphicsSuspend() if(active) { active = 0; - GXSuspend(); + dynamicGXSuspend(); } } @@ -160,7 +235,7 @@ void GraphicsResume() if(!active) { active = 1; - GXResume(); + dynamicGXResume(); } palette_update(); @@ -168,7 +243,7 @@ void GraphicsResume() void GraphicsOff(void) { - GXCloseDisplay(); + dynamicGXCloseDisplay(); active = 0; } @@ -202,18 +277,41 @@ void RestoreScreenGeometry() { geom[2].lineLimit = _geometry_w * _geometry_h; } -int GraphicsOn(HWND hWndMain_param) +int GraphicsOn(HWND hWndMain_param, bool gfx_mode_switch) { hWndMain = hWndMain_param; - GXOpenDisplay(hWndMain, GX_FULLSCREEN); + dynamicGXOpenDisplay(hWndMain, GX_FULLSCREEN); + + _gfx_mode_switch = gfx_mode_switch; + + if (_gfx_mode_switch) { + _game_selection_X_offset = GAME_SELECTION_X_OFFSET; + _game_selection_Y_offset = GAME_SELECTION_Y_OFFSET; + } + else { + _game_selection_X_offset = 0; + _game_selection_Y_offset = 0; + } - gxdp = GXGetDisplayProperties(); + gxdp = dynamicGXGetDisplayProperties(); + + // Possible Aero problem + + if (gxdp.cbxPitch == 61440 && + gxdp.cbyPitch == -2 && + gxdp.ffFormat == 0x18 + ) { + gxdp.cbxPitch = 640; + gxdp.cbyPitch = -2; + gxdp.ffFormat = kfDirect | kfDirect565; + } if(gxdp.ffFormat & kfDirect565) { pCls = hicolor_Cls; pBlt = hicolor565_Blt; pBlt_part = hicolor565_Blt_part; + pSet_565 = hicolor565_Set_565; filter_available = 1; smooth_filter = 1; toolbar_available = 1; @@ -223,6 +321,7 @@ int GraphicsOn(HWND hWndMain_param) pCls = hicolor_Cls; pBlt = hicolor555_Blt; pBlt_part = hicolor555_Blt_part; + pSet_565 = hicolor555_Set_565; filter_available = 1; smooth_filter = 1; toolbar_available = 1; @@ -232,6 +331,7 @@ int GraphicsOn(HWND hWndMain_param) pCls = mono_Cls; pBlt = mono_Blt; pBlt_part = mono_Blt_part; + pSet_565 = mono_Set_565; if(gxdp.ffFormat & kfDirectInverted) invert = (1<<gxdp.cBPP)-1; @@ -247,6 +347,7 @@ int GraphicsOn(HWND hWndMain_param) pCls = palette_Cls; pBlt = palette_Blt; pBlt_part = palette_Blt_part; + pSet_565 = palette_Set_565; toolbar_available = 1; } @@ -261,15 +362,24 @@ int GraphicsOn(HWND hWndMain_param) } // portrait - geom[0].width = gxdp.cxWidth; // 240 - geom[0].height = gxdp.cyHeight; // 320 + portrait_geometry.width = gxdp.cxWidth; // 240 + portrait_geometry.height = gxdp.cyHeight; // 320 + portrait_geometry.startoffset = 0; + portrait_geometry.sourceoffset = 0; + portrait_geometry.linestep = gxdp.cbyPitch; + portrait_geometry.pixelstep = gxdp.cbxPitch; + portrait_geometry.xSkipMask = gxdp.cxWidth < 320 ? 0x00000003 : 0xffffffff; + portrait_geometry.xLimit = 320; // skip 1/4 + portrait_geometry.lineLimit = 320*200; + geom[0].width = gxdp.cxWidth; + geom[0].height = gxdp.cyHeight; geom[0].startoffset = 0; geom[0].sourceoffset = 0; geom[0].linestep = gxdp.cbyPitch; geom[0].pixelstep = gxdp.cbxPitch; - geom[0].xSkipMask = gxdp.cxWidth < 320 ? 0x00000003 : 0xffffffff; - geom[0].xLimit = 320; // skip 1/4 - geom[0].lineLimit = 320*200; + geom[0].xSkipMask = 0xffffffff; + geom[0].xLimit = 240; + geom[0].lineLimit = 320*240; // left handed landscape geom[1].width = gxdp.cyHeight; // 320 @@ -397,7 +507,7 @@ void mono_Cls() return; linestep = (pixelstep > 0) ? -1 : 1; - scraddr = (UBYTE*)GXBeginDraw(); + scraddr = (UBYTE*)dynamicGXBeginDraw(); if(scraddr) { for(y=0; y<geom[0].height*gxdp.cBPP/8; y++) @@ -410,7 +520,7 @@ void mono_Cls() } scraddr += linestep; } - GXEndDraw(); + dynamicGXEndDraw(); } } @@ -419,7 +529,7 @@ void palette_Cls() int x, y; UBYTE* dst; UBYTE *scraddr; - scraddr = (UBYTE*)GXBeginDraw(); + scraddr = (UBYTE*)dynamicGXBeginDraw(); if(scraddr) { for(y=0; y<geom[useMode].height; y++) @@ -432,7 +542,7 @@ void palette_Cls() } scraddr += geom[useMode].linestep; } - GXEndDraw(); + dynamicGXEndDraw(); } } @@ -441,7 +551,7 @@ void hicolor_Cls() int x, y; UBYTE* dst; UBYTE *scraddr; - scraddr = (UBYTE*)GXBeginDraw(); + scraddr = (UBYTE*)dynamicGXBeginDraw(); if(scraddr) { for(y=0; y<geom[useMode].height; y++) @@ -454,7 +564,7 @@ void hicolor_Cls() } scraddr += geom[useMode].linestep; } - GXEndDraw(); + dynamicGXEndDraw(); } } @@ -465,56 +575,61 @@ void Cls() } int counter = 0; -/* -void drawToolbarItem(UBYTE* palette, UBYTE* item, int dest_x, int dest_y, int width_item, int height_item) { - - int x,y,z; - UBYTE* dst; - UBYTE *scraddr; +void drawSoundItem(int x, int y) { + if (!sound_activated) + pBlt_part(image_expand(item_soundOn), x, y, 32, 32, item_soundOn_colors); + else + pBlt_part(image_expand(item_soundOff), x, y, 32, 32, item_soundOff_colors); +} - scraddr = (UBYTE*)GXBeginDraw(); - if(scraddr) - { - scraddr += dest_y * geom[useMode].linestep; +void drawWait() { + pBlt_part(image_expand(item_toolbar), 0, 0, 320, 40, item_toolbar_colors); + pBlt_part(image_expand(item_loading), 28, 10, 100, 25, item_loading_colors); +} - z = 0; +void drawBlankGameSelection() { + //int i; + image_expand(item_startup); + /* Store empty comment */ + memcpy(comment_zone, decomp + (206 * 220), 8 * 220); + pBlt_part(decomp, _game_selection_X_offset, _game_selection_Y_offset, 220, 250, item_startup_colors); +} - for (y=dest_y; y<dest_y + height_item; y++) { - dst = scraddr + geom[useMode].startoffset + dest_x * geom[useMode].pixelstep; - for (x=dest_x; x<dest_x + width_item; x++) { - if(gxdp.ffFormat & kfDirect565) - *(unsigned short*)dst = - COLORCONV565(palette[item[z] * 3], palette[item[z] * 3 + 1], palette[item[z] * 3 + 2]); - else if(gxdp.ffFormat & kfDirect555) - *(unsigned short*)dst = - COLORCONV555(palette[item[z] * 3], palette[item[z] * 3 + 1], palette[item[z] * 3 + 2]); - else if((gxdp.ffFormat & kfDirect) && (gxdp.cBPP <= 8)) - *(unsigned short*)dst = - COLORCONVMONO(palette[item[z] * 3], palette[item[z] * 3 + 1], palette[item[z] * 3 + 2]); +void drawCommentString(char *comment) { + /* Erase old comment */ + memcpy(decomp + (206 * 220), comment_zone, 8 * 220); + /* Draw new comment */ + printString(comment, 24, 206, 2); + pBlt_part(decomp + (206 * 220), _game_selection_X_offset, _game_selection_Y_offset + 206, 220, 8, item_startup_colors); +} +void drawStandardString(char *game, int index) { + printString(game, 24, 70 + (15 * index), 2); + //pBlt_part(decomp, GAME_SELECTION_X_OFFSET + 24, GAME_SELECTION_Y_OFFSET + 70 + (12 * index), 220, 8, item_startup_colors); + pBlt_part(decomp + ((70 + (15 * index)) * 220), _game_selection_X_offset, _game_selection_Y_offset + 70 + (15 * index), 220, 8, item_startup_colors); +} - dst += geom[useMode].pixelstep; - //z += 3; - z += 1; - } - scraddr += geom[useMode].linestep; - } +void drawHighlightedString(char *game, int index) { + /* Replace former highlighted string */ + if (_highlighted_index != -1) { + memcpy(decomp + ((70 + (15 * _highlighted_index)) * 220), highlighted_zone, 8 * 220); + pBlt_part(decomp + ((70 + (15 * _highlighted_index)) * 220), _game_selection_X_offset, _game_selection_Y_offset + 70 + (15 * _highlighted_index), 220, 8, item_startup_colors); } - GXEndDraw(); + /* Save non highlighted string */ + _highlighted_index = index; + memcpy(highlighted_zone, decomp + ((70 + (15 * index)) * 220), 8 * 220); + /* Draw new highlighted string */ + printString(game, 24, 70 + (15 * index), 2, 3); + pBlt_part(decomp + ((70 + (15 * index)) * 220), _game_selection_X_offset, _game_selection_Y_offset + 70 + (15 * index), 220, 8, item_startup_colors); } -*/ - -void drawSoundItem(int x, int y) { - if (sound_activated) - pBlt_part(item_soundOn, x, y, 32, 32, item_soundOn_colors); - else - pBlt_part(item_soundOff, x, y, 32, 32, item_soundOff_colors); +void resetLastHighlighted() { + _highlighted_index = -1; } -void drawWait() { - pBlt_part(item_toolbar, 0, 0, 320, 40, item_toolbar_colors); - pBlt_part(item_loading, 28, 10, 100, 25, item_loading_colors); +void reducePortraitGeometry() { + if (_gfx_mode_switch) + memcpy(&geom[0], &portrait_geometry, sizeof(tScreenGeometry)); } void drawAllToolbar() { @@ -523,42 +638,46 @@ void drawAllToolbar() { if (currentScreenMode) { if (draw_keyboard) { - pBlt_part(item_keyboard, 0, 200, 320, 40, item_keyboard_colors); + pBlt_part(image_expand(item_keyboard), 0, 200, 320, 40, item_keyboard_colors); } else { - pBlt_part(item_toolbar, 0, 200, 320, 40, item_toolbar_colors); + pBlt_part(image_expand(item_toolbar), 0, 200, 320, 40, item_toolbar_colors); x = 10; y = 204; - pBlt_part(item_disk, x, y, 32, 32, item_disk_colors); + pBlt_part(image_expand(item_disk), x, y, 32, 32, item_disk_colors); x += 40; - pBlt_part(item_skip, x, y, 32, 32, item_skip_colors); + pBlt_part(image_expand(item_skip), x, y, 32, 32, item_skip_colors); x += 40; drawSoundItem(x, y); - x += 40; - pBlt_part(item_monkeyPortrait, x, y, 32, 32, - item_monkeyPortrait_colors); + if (_gfx_mode_switch) { + x += 40; + pBlt_part(image_expand(item_monkeyPortrait), x, y, 32, 32, + item_monkeyPortrait_colors); + } } } else { if (draw_keyboard) { - pBlt_part(item_keyboardPortrait, 0, 240, 320, 80, + pBlt_part(image_expand(item_keyboardPortrait), 0, 240, 320, 80, item_keyboardPortrait_colors); } else { - pBlt_part(item_toolbarPortrait, 0, 240, 320, 80, + pBlt_part(image_expand(item_toolbarPortrait), 0, 240, 320, 80, item_toolbarPortrait_colors); /*drawToolbarItem(item_toolbarPortrait_colors, item_toolbarPortrait, 0, 240, 240, 80);*/ x = 10; y = 240; - pBlt_part(item_disk, x, y, 32, 32, item_disk_colors); + pBlt_part(image_expand(item_disk), x, y, 32, 32, item_disk_colors); x += 40; - pBlt_part(item_skip, x, y, 32, 32, item_skip_colors); + pBlt_part(image_expand(item_skip), x, y, 32, 32, item_skip_colors); x += 40; drawSoundItem(x, y); - x += 40; - pBlt_part(item_monkeyLandscape, x, y, 32, 32, - item_monkeyLandscape_colors); + if (_gfx_mode_switch) { + x += 40; + pBlt_part(image_expand(item_monkeyLandscape), x, y, 32, 32, + item_monkeyLandscape_colors); + } } } @@ -594,9 +713,11 @@ ToolbarSelected getToolbarSelection (int x, int y) { test_x += 40; if (isInBox(x, y, test_x, test_y, test_x + 32, test_y + 32)) return ToolbarSound; - test_x += 40; - if (isInBox(x, y, test_x, test_y, test_x + 32, test_y + 32)) - return ToolbarMode; + if (_gfx_mode_switch) { + test_x += 40; + if (isInBox(x, y, test_x, test_y, test_x + 32, test_y + 32)) + return ToolbarMode; + } return ToolbarNone; } @@ -612,6 +733,12 @@ void Blt(UBYTE * scr_ptr) } +void checkToolbar() { + if (toolbar_available && !toolbar_drawn && !hide_toolbar) + drawAllToolbar(); +} + +/* *************************** MONO DISPLAY ********************************* */ #define ADVANCE_PARTIAL(address, step) \ bitshift += gxdp.cBPP; \ @@ -636,6 +763,63 @@ void Blt(UBYTE * scr_ptr) bitmask >>= gxdp.cBPP; +void mono_Set_565(INT16 *buffer, int pitch, int x, int y, int width, int height) { + + static UBYTE *scraddr; + static UBYTE *dst; + static long pixelstep; + static long linestep; + static UBYTE bitmask; + static int bitshift; + + scraddr = (UBYTE*)dynamicGXBeginDraw(); + pixelstep = geom[useMode].pixelstep; + linestep = (pixelstep > 0) ? -1 : 1; + bitshift = 0; + bitmask = (1<<gxdp.cBPP)-1; + + if(scraddr) + { + int lines = 0; + int current = 0; + + scraddr += geom[useMode].startoffset; + scraddr += y * linestep; + + while(lines != height) + { + int i; + current = 0; + + dst = scraddr; + + /* skip non updated pixels for this line */ + for (i=0; i < x; i++) + dst += pixelstep; + + /* Turtle warning !!! */ + + for (i=0; i<width; i++) { + + *dst = ((*dst)&~bitmask)|(COLORCONVMONO( + RED_FROM_565(*(buffer + i)), + GREEN_FROM_565(*(buffer + i)), + BLUE_FROM_565(*(buffer + i))) << bitshift); + + dst += pixelstep; + } + + ADVANCE_PARTIAL(scraddr, linestep); + + buffer += pitch; + lines++; + } + } + + dynamicGXEndDraw(); +} + + void mono_Blt(UBYTE *src_ptr) { mono_Blt_part(src_ptr, 0, 0, _geometry_w, _geometry_h, NULL); } @@ -675,7 +859,7 @@ void mono_Blt_part(UBYTE * scr_ptr, int x, int y, int width, int height, linestep = geom[useMode].linestep; skipmask = geom[useMode].xSkipMask; - scraddr = (UBYTE*)GXBeginDraw(); + scraddr = (UBYTE*)dynamicGXBeginDraw(); if(pixelstep) { @@ -1024,9 +1208,63 @@ void mono_Blt_part(UBYTE * scr_ptr, int x, int y, int width, int height, } } } - GXEndDraw(); + dynamicGXEndDraw(); +} + +/* *************************** PALETTED DISPLAY ********************************* */ + +void palette_Set_565(INT16 *buffer, int pitch, int x, int y, int width, int height) { + + static UBYTE *scraddr; + static UBYTE *dst; + static long pixelstep; + static long linestep; + unsigned char color_match[500]; + memset(color_match, 255, sizeof(color_match)); + + scraddr = (UBYTE*)dynamicGXBeginDraw(); + + pixelstep = geom[useMode].pixelstep; + linestep = geom[useMode].linestep; + + if(scraddr) + { + int lines = 0; + int current = 0; + + scraddr += geom[useMode].startoffset; + scraddr += y * linestep; + + while(lines != height) + { + int i; + current = 0; + + dst = scraddr; + + /* skip non updated pixels for this line */ + for (i=0; i < x; i++) + dst += pixelstep; + + /* HUGE Turtle warning !!! */ + + for (i=0; i<width; i++) { + + *dst++ = best_match(RED_FROM_565(*(buffer + i)), + GREEN_FROM_565(*(buffer + i)), + BLUE_FROM_565(*(buffer + i)), 236) + 10; + } + + buffer += pitch; + scraddr += linestep; + lines++; + } + } + + dynamicGXEndDraw(); } + void palette_Blt(UBYTE *src_ptr) { palette_Blt_part(src_ptr, 0, 0, _geometry_w, _geometry_h, NULL); } @@ -1042,6 +1280,8 @@ void palette_Blt_part(UBYTE * scr_ptr,int x, int y, int width, int height, static long pixelstep; static long linestep; static long skipmask; + unsigned char color_match[500]; + memset(color_match, 255, sizeof(color_match)); // Special code is used to deal with packed pixels in monochrome mode static UBYTE bitmask; @@ -1064,7 +1304,7 @@ void palette_Blt_part(UBYTE * scr_ptr,int x, int y, int width, int height, linestep = geom[useMode].linestep; skipmask = geom[useMode].xSkipMask; - scraddr = (UBYTE*)GXBeginDraw(); + scraddr = (UBYTE*)dynamicGXBeginDraw(); if(scraddr) { @@ -1102,9 +1342,7 @@ void palette_Blt_part(UBYTE * scr_ptr,int x, int y, int width, int height, else *dst = staticTranslate[*src-236]; } else { - unsigned char color_match[500]; // Turtle warning !!! - memset(color_match, 255, sizeof(color_match)); if (color_match[*src] == 255) color_match[*src] = best_match(own_palette[(3 * *src)], @@ -1144,9 +1382,7 @@ void palette_Blt_part(UBYTE * scr_ptr,int x, int y, int width, int height, *dst = staticTranslate[*src-236]; } else { - unsigned char color_match[500]; // Turtle warning !!! - memset(color_match, 255, sizeof(color_match)); if (color_match[*src] == 255) color_match[*src] = best_match(own_palette[(3 * *src)], @@ -1163,10 +1399,62 @@ void palette_Blt_part(UBYTE * scr_ptr,int x, int y, int width, int height, } } - GXEndDraw(); + dynamicGXEndDraw(); + } +} + +/* ********************************* 555 DISPLAY ********************************* */ + +void hicolor555_Set_565(INT16 *buffer, int pitch, int x, int y, int width, int height) { + + static UBYTE *scraddr; + static UBYTE *dst; + static long pixelstep; + static long linestep; + + scraddr = (UBYTE*)dynamicGXBeginDraw(); + + pixelstep = geom[useMode].pixelstep; + linestep = geom[useMode].linestep; + + if(scraddr) + { + int lines = 0; + int current = 0; + + scraddr += geom[useMode].startoffset; + scraddr += y * linestep; + + while(lines != height) + { + int i; + current = 0; + + dst = scraddr; + + /* skip non updated pixels for this line */ + for (i=0; i < x; i++) + dst += pixelstep; + + /* Turtle warning !!! */ + + for (i=0; i<width; i++) { + *(unsigned short*)dst = COLORCONV555( + RED_FROM_565(*(buffer + i)), GREEN_FROM_565(*(buffer + i)), BLUE_FROM_565(*(buffer + i)) + ); + dst += 2; + } + + buffer += pitch; + scraddr += linestep; + lines++; + } } + + dynamicGXEndDraw(); } + void hicolor555_Blt(UBYTE *src_ptr) { hicolor555_Blt_part(src_ptr, 0, 0, _geometry_w, _geometry_h, NULL); } @@ -1201,7 +1489,7 @@ void hicolor555_Blt_part(UBYTE * scr_ptr,int x, int y, int width, int height, linestep = geom[useMode].linestep; skipmask = geom[useMode].xSkipMask; - scraddr = (UBYTE*)GXBeginDraw(); + scraddr = (UBYTE*)dynamicGXBeginDraw(); if(scraddr) { @@ -1360,14 +1648,62 @@ void hicolor555_Blt_part(UBYTE * scr_ptr,int x, int y, int width, int height, } } - GXEndDraw(); + dynamicGXEndDraw(); } } +/* ********************************* 565 DISPLAY ********************************* */ + + void hicolor565_Blt(UBYTE *src_ptr) { hicolor565_Blt_part(src_ptr, 0, 0, _geometry_w, _geometry_h, NULL); } + +void hicolor565_Set_565(INT16 *buffer, int pitch, int x, int y, int width, int height) { + + static UBYTE *scraddr; + static UBYTE *dst; + static long pixelstep; + static long linestep; + + scraddr = (UBYTE*)dynamicGXBeginDraw(); + + pixelstep = geom[useMode].pixelstep; + linestep = geom[useMode].linestep; + + if(scraddr) + { + int lines = 0; + int current = 0; + + scraddr += geom[useMode].startoffset; + scraddr += y * linestep; + + while(lines != height) + { + int i; + current = 0; + + dst = scraddr; + + + /* skip non updated pixels for this line */ + + for (i=0; i < x; i++) + dst += pixelstep; + + memcpy(dst, buffer, width * 2); + + buffer += pitch; + scraddr += linestep; + lines++; + } + } + + dynamicGXEndDraw(); +} + void hicolor565_Blt_part(UBYTE * scr_ptr, int x, int y, int width, int height, UBYTE * own_palette) { @@ -1397,7 +1733,7 @@ void hicolor565_Blt_part(UBYTE * scr_ptr, int x, int y, int width, int height, linestep = geom[useMode].linestep; skipmask = geom[useMode].xSkipMask; - scraddr = (UBYTE*)GXBeginDraw(); + scraddr = (UBYTE*)dynamicGXBeginDraw(); if(scraddr) { @@ -1556,10 +1892,12 @@ void hicolor565_Blt_part(UBYTE * scr_ptr, int x, int y, int width, int height, } } - GXEndDraw(); + dynamicGXEndDraw(); } } +/* ************************** STYLUS TRANSLATION ************************* */ + void Translate(int* px, int* py) { @@ -1585,4 +1923,71 @@ void Translate(int* px, int* py) } } +/* ************************** LAUNCHER FONT STUFF ************************* */ + +void printChar(const char str, int xx, int yy, int textcolor, int highlight) +{ + unsigned int buffer = 0, mask = 0, x, y; + byte *tmp; + byte *ptr; + + tmp = &textfont[0]; + tmp += 224 + (str + 1) * 8; + + ptr = decomp + (yy * 220) + xx; + + for (y = 0; y < 8; y++) { + for (x = 0; x < 8; x++) { + unsigned char color; + if ((mask >>= 1) == 0) { + buffer = *tmp++; + mask = 0x80; + } + color = ((buffer & mask) != 0); + if (color) + ptr[x] = textcolor; + else if (highlight > 0) + ptr[x] = highlight; + } + if (highlight > 0) { + int i; + for (i=9; i<220; i++) + ptr[x] = highlight; + } + ptr += 220; + } + +} +void printString(const char *str, int x, int y, int textcolor, int highlight) +{ + for (uint letter = 0; letter < strlen(str); letter++) + printChar(str[letter], x + (letter * 8), y, textcolor, highlight); +} + + +/* ************************** DIRECT BLT IMPLEMENTATION ************************* */ + + +void Get_565(UBYTE *src, INT16 *buffer, int pitch, int x, int y, int width, int height) { + int i,j; + UBYTE *tempo = (UBYTE*)buffer; + + // Dumb conversion to 565 + + for (i=0; i<240; i++) { + for (j=0; j<320; j++) { + *buffer++ = COLORCONV565(palRed[*src], palGreen[*src], palBlue[*src]); + src++; + } + } +} + +void Set_565(INT16 *buffer, int pitch, int x, int y, int width, int height) { + pSet_565(buffer, pitch, x, y, width, height); +} + +void NULL_Set_565(INT16 *buffer, int pitch, int x, int y, int width, int height) { +} + + #endif diff --git a/backends/wince/screen.h b/backends/wince/screen.h index c7eb2b3af5..7a9f7dac09 100644 --- a/backends/wince/screen.h +++ b/backends/wince/screen.h @@ -28,22 +28,40 @@ #define UBYTE unsigned char #endif +#ifndef INT16 +#define INT16 signed short +#endif + +#define GAME_SELECTION_X_OFFSET 15 +#define GAME_SELECTION_Y_OFFSET 25 + void SetScreenGeometry(int w, int h); void LimitScreenGeometry(); void RestoreScreenGeometry(); -int GraphicsOn(HWND hWndMain); +int GraphicsOn(HWND hWndMain, bool gfx_mode_switch); void GraphicsOff(); void GraphicsSuspend(); void GraphicsResume(); void SetPalEntry(int ent, UBYTE r, UBYTE g, UBYTE b); void Blt(UBYTE * scr_ptr); +void checkToolbar(); + +void Get_565(UBYTE *src, INT16 *buffer, int pitch, int x, int y, int width, int height); +void Set_565(INT16 *buffer, int pitch, int x, int y, int width, int height); /* meaning: 0 - portrait, 1 - left hand landscape, 2 - right hand landscape */ void SetScreenMode(int mode); int GetScreenMode(); void drawWait(); +void drawBlankGameSelection(); +void reducePortraitGeometry(); +void drawCommentString(char *); +void drawStandardString(char *, int); +void drawHighlightedString(char *, int); +void resetLastHighlighted(); + void Translate(int* x, int* y); typedef enum ToolbarSelected { |