mirror of https://github.com/stella-emu/stella.git
Massive update of the wince port. Works almost correctly on smartphones, pocket pcs need some testing.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@842 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
parent
330c27224c
commit
00b702cdc0
|
@ -1,12 +1,14 @@
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#include <gx.h>
|
|
||||||
#include "FrameBufferWinCE.hxx"
|
#include "FrameBufferWinCE.hxx"
|
||||||
#include "Console.hxx"
|
#include "Console.hxx"
|
||||||
#include "OSystem.hxx"
|
#include "OSystem.hxx"
|
||||||
#include "Font.hxx"
|
#include "Font.hxx"
|
||||||
|
|
||||||
|
#define OPTPIXAVERAGE(pix1,pix2) ( ((((pix1 & optgreenmaskN) + (pix2 & optgreenmaskN)) >> 1) & optgreenmaskN) | ((((pix1 & optgreenmask) + (pix2 & optgreenmask)) >> 1) & optgreenmask) )
|
||||||
|
|
||||||
FrameBufferWinCE::FrameBufferWinCE(OSystem *osystem)
|
FrameBufferWinCE::FrameBufferWinCE(OSystem *osystem)
|
||||||
: FrameBuffer(osystem), myDstScreen(NULL), SubsystemInited(false), displacement(0)
|
: FrameBuffer(osystem), myDstScreen(NULL), SubsystemInited(false), displacement(0),
|
||||||
|
issmartphone(true), islandscape(false), displaymode(0)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,7 +19,7 @@ FrameBufferWinCE::~FrameBufferWinCE()
|
||||||
void FrameBufferWinCE::setPalette(const uInt32* palette)
|
void FrameBufferWinCE::setPalette(const uInt32* palette)
|
||||||
{
|
{
|
||||||
//setup palette
|
//setup palette
|
||||||
GXDisplayProperties gxdp = GXGetDisplayProperties();
|
gxdp = GXGetDisplayProperties();
|
||||||
for (uInt16 i=0; i<256; i++)
|
for (uInt16 i=0; i<256; i++)
|
||||||
{
|
{
|
||||||
uInt8 r = (uInt8) ((palette[i] & 0xFF0000) >> 16);
|
uInt8 r = (uInt8) ((palette[i] & 0xFF0000) >> 16);
|
||||||
|
@ -35,7 +37,7 @@ void FrameBufferWinCE::setPalette(const uInt32* palette)
|
||||||
|
|
||||||
bool FrameBufferWinCE::initSubsystem()
|
bool FrameBufferWinCE::initSubsystem()
|
||||||
{
|
{
|
||||||
GXDisplayProperties gxdp = GXGetDisplayProperties();
|
gxdp = GXGetDisplayProperties();
|
||||||
for (int i=0; i<kNumColors - 256; i++)
|
for (int i=0; i<kNumColors - 256; i++)
|
||||||
{
|
{
|
||||||
uInt8 r = (ourGUIColors[i][0] & 0xFF);
|
uInt8 r = (ourGUIColors[i][0] & 0xFF);
|
||||||
|
@ -49,26 +51,130 @@ bool FrameBufferWinCE::initSubsystem()
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
// screen extents
|
// screen extents
|
||||||
//GXDisplayProperties gxdp = GXGetDisplayProperties();
|
if(gxdp.ffFormat & kfDirect565)
|
||||||
pixelstep = gxdp.cbxPitch;
|
{
|
||||||
linestep = gxdp.cbyPitch;
|
optgreenmask = 0x7E0;
|
||||||
|
optgreenmaskN = 0xF81F;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
optgreenmask = 0x3E0;
|
||||||
|
optgreenmaskN = 0x7C1F;
|
||||||
|
}
|
||||||
|
|
||||||
scrwidth = gxdp.cxWidth;
|
scrwidth = gxdp.cxWidth;
|
||||||
scrheight = gxdp.cyHeight;
|
scrheight = gxdp.cyHeight;
|
||||||
|
if (scrwidth == 176 && scrheight == 220)
|
||||||
|
issmartphone = true;
|
||||||
|
else
|
||||||
|
issmartphone = false;
|
||||||
|
islandscape = false;
|
||||||
|
setmode(0);
|
||||||
|
|
||||||
SubsystemInited = false;
|
SubsystemInited = false;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void FrameBufferWinCE::setmode(uInt8 mode)
|
||||||
|
{
|
||||||
|
displaymode = mode % 3;
|
||||||
|
switch (displaymode)
|
||||||
|
{
|
||||||
|
// portrait
|
||||||
|
case 0:
|
||||||
|
pixelstep = gxdp.cbxPitch;
|
||||||
|
linestep = gxdp.cbyPitch;
|
||||||
|
islandscape = false;
|
||||||
|
break;
|
||||||
|
|
||||||
|
// landscape
|
||||||
|
case 1:
|
||||||
|
pixelstep = - gxdp.cbyPitch;
|
||||||
|
linestep = gxdp.cbxPitch;
|
||||||
|
islandscape = true;
|
||||||
|
break;
|
||||||
|
|
||||||
|
// inverted landscape
|
||||||
|
case 2:
|
||||||
|
pixelstep = gxdp.cbyPitch;
|
||||||
|
linestep = - gxdp.cbxPitch;
|
||||||
|
islandscape = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
pixelsteptimes5 = pixelstep * 5;
|
||||||
|
pixelsteptimes6 = pixelstep * 6;
|
||||||
|
SubsystemInited = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
int FrameBufferWinCE::rotatedisplay(void)
|
||||||
|
{
|
||||||
|
displaymode = (displaymode + 1) % 3;
|
||||||
|
setmode(displaymode);
|
||||||
|
wipescreen();
|
||||||
|
return displaymode;
|
||||||
|
}
|
||||||
|
|
||||||
void FrameBufferWinCE::lateinit(void)
|
void FrameBufferWinCE::lateinit(void)
|
||||||
{
|
{
|
||||||
|
int w;
|
||||||
myWidth = myOSystem->console().mediaSource().width();
|
myWidth = myOSystem->console().mediaSource().width();
|
||||||
myHeight = myOSystem->console().mediaSource().height();
|
myHeight = myOSystem->console().mediaSource().height();
|
||||||
if (scrwidth > myWidth)
|
|
||||||
displacement = (scrwidth - myWidth) / 2 * pixelstep;
|
if (issmartphone)
|
||||||
|
if (!islandscape)
|
||||||
|
w = myWidth;
|
||||||
|
else
|
||||||
|
w = (int) ((float) myWidth * 11.0 / 8.0 + 0.5);
|
||||||
else
|
else
|
||||||
displacement = 0;
|
if (!islandscape)
|
||||||
if (scrheight > myHeight)
|
w = (int) ((float) myWidth * 3.0 / 2.0 + 0.5);
|
||||||
displacement += (scrheight - myHeight) / 2 * linestep;
|
else
|
||||||
|
w = myWidth * 2;
|
||||||
|
|
||||||
|
switch (displaymode)
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
if (scrwidth > w)
|
||||||
|
displacement = (scrwidth - w) / 2 * gxdp.cbxPitch;
|
||||||
|
else
|
||||||
|
displacement = 0;
|
||||||
|
if (scrheight > myHeight)
|
||||||
|
{
|
||||||
|
displacement += (scrheight - myHeight) / 2 * gxdp.cbyPitch;
|
||||||
|
minydim = myHeight;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
minydim = scrheight;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 1:
|
||||||
|
displacement = gxdp.cbyPitch*(gxdp.cyHeight-1);
|
||||||
|
if (scrwidth > myHeight)
|
||||||
|
{
|
||||||
|
minydim = myHeight;
|
||||||
|
displacement += (scrwidth - myHeight) / 2 * gxdp.cbxPitch;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
minydim = scrwidth;
|
||||||
|
if (scrheight > w)
|
||||||
|
displacement -= (scrheight - w) / 2 * gxdp.cbyPitch;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 2:
|
||||||
|
displacement = gxdp.cbxPitch*(gxdp.cxWidth-1);
|
||||||
|
if (scrwidth > myHeight)
|
||||||
|
{
|
||||||
|
minydim = myHeight;
|
||||||
|
displacement -= (scrwidth - myHeight) / 2 * gxdp.cbxPitch;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
minydim = scrwidth;
|
||||||
|
if (scrheight > w)
|
||||||
|
displacement += (scrheight - w) / 2 * gxdp.cbyPitch;
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
SubsystemInited = true;
|
SubsystemInited = true;
|
||||||
}
|
}
|
||||||
|
@ -80,14 +186,13 @@ void FrameBufferWinCE::preFrameUpdate()
|
||||||
|
|
||||||
void FrameBufferWinCE::drawMediaSource()
|
void FrameBufferWinCE::drawMediaSource()
|
||||||
{
|
{
|
||||||
|
// TODO: define these static, also x & y
|
||||||
uInt8 *sc, *sp;
|
uInt8 *sc, *sp;
|
||||||
uInt8 *d, *pl;
|
uInt8 *d, *pl;
|
||||||
|
uInt16 pix1, pix2;
|
||||||
|
|
||||||
if (!SubsystemInited)
|
if (!SubsystemInited)
|
||||||
{
|
|
||||||
lateinit();
|
lateinit();
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( (d = myDstScreen) == NULL )
|
if ( (d = myDstScreen) == NULL )
|
||||||
return;
|
return;
|
||||||
|
@ -96,27 +201,162 @@ void FrameBufferWinCE::drawMediaSource()
|
||||||
pl = d;
|
pl = d;
|
||||||
sc = myOSystem->console().mediaSource().currentFrameBuffer();
|
sc = myOSystem->console().mediaSource().currentFrameBuffer();
|
||||||
sp = myOSystem->console().mediaSource().previousFrameBuffer();
|
sp = myOSystem->console().mediaSource().previousFrameBuffer();
|
||||||
for (uInt16 y=0; y<myHeight; y++)
|
|
||||||
|
if (issmartphone && islandscape == 0)
|
||||||
{
|
{
|
||||||
for (uInt16 x=0; x<(myWidth>>2); x++)
|
// straight
|
||||||
|
for (uInt16 y=0; y<myHeight; y++)
|
||||||
{
|
{
|
||||||
if ( *((uInt32 *) sc) != *((uInt32 *) sp) )
|
for (uInt16 x=0; x<(myWidth>>2); x++)
|
||||||
{
|
{
|
||||||
*((uInt16 *)d) = pal[*sc++]; d += pixelstep;
|
if ( *((uInt32 *) sc) != *((uInt32 *) sp) )
|
||||||
*((uInt16 *)d) = pal[*sc++]; d += pixelstep;
|
{
|
||||||
*((uInt16 *)d) = pal[*sc++]; d += pixelstep;
|
*((uInt16 *)d) = pal[*sc++]; d += pixelstep;
|
||||||
*((uInt16 *)d) = pal[*sc++]; d += pixelstep;
|
*((uInt16 *)d) = pal[*sc++]; d += pixelstep;
|
||||||
|
*((uInt16 *)d) = pal[*sc++]; d += pixelstep;
|
||||||
|
*((uInt16 *)d) = pal[*sc++]; d += pixelstep;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
sc += 4;
|
||||||
|
d += (pixelstep << 2);
|
||||||
|
}
|
||||||
|
sp += 4;
|
||||||
}
|
}
|
||||||
else
|
d = pl + linestep;
|
||||||
{
|
pl = d;
|
||||||
sc += 4;
|
|
||||||
d += (pixelstep << 2);
|
|
||||||
}
|
|
||||||
sp += 4;
|
|
||||||
}
|
}
|
||||||
d = pl + linestep;
|
|
||||||
pl = d;
|
|
||||||
}
|
}
|
||||||
|
else if (issmartphone && islandscape)
|
||||||
|
{
|
||||||
|
for (uInt16 y=0; y<minydim; y++)
|
||||||
|
{
|
||||||
|
for (uInt16 x=0; x<(myWidth>>2); x++)
|
||||||
|
{
|
||||||
|
// 11/8
|
||||||
|
// **X**
|
||||||
|
if ( *((uInt32 *) sc) != *((uInt32 *) sp) )
|
||||||
|
{
|
||||||
|
*((uInt16 *)d) = pal[*sc++]; d += pixelstep;
|
||||||
|
pix1 = pal[*sc++]; pix2 = pal[*sc++];
|
||||||
|
*((uInt16 *)d) = pix1; d += pixelstep;
|
||||||
|
*((uInt16 *)d) = OPTPIXAVERAGE(pix1,pix2); d += pixelstep;
|
||||||
|
*((uInt16 *)d) = pix2; d += pixelstep;
|
||||||
|
*((uInt16 *)d) = pal[*sc++]; d += pixelstep;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
sc += 4;
|
||||||
|
d += pixelsteptimes5;
|
||||||
|
}
|
||||||
|
sp += 4;
|
||||||
|
if (++x>=(myWidth>>2)) break;
|
||||||
|
|
||||||
|
// *X**X*
|
||||||
|
if ( *((uInt32 *) sc) != *((uInt32 *) sp) )
|
||||||
|
{
|
||||||
|
pix1 = pal[*sc++]; pix2 = pal[*sc++];
|
||||||
|
*((uInt16 *)d) = pix1; d += pixelstep;
|
||||||
|
*((uInt16 *)d) = OPTPIXAVERAGE(pix1,pix2); d += pixelstep;
|
||||||
|
*((uInt16 *)d) = pix2; d += pixelstep;
|
||||||
|
pix1 = pal[*sc++]; pix2 = pal[*sc++];
|
||||||
|
*((uInt16 *)d) = pix1; d += pixelstep;
|
||||||
|
*((uInt16 *)d) = OPTPIXAVERAGE(pix1,pix2); d += pixelstep;
|
||||||
|
*((uInt16 *)d) = pix2; d += pixelstep;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
sc += 4;
|
||||||
|
d += pixelsteptimes6;
|
||||||
|
}
|
||||||
|
sp += 4;
|
||||||
|
}
|
||||||
|
d = pl + linestep;
|
||||||
|
pl = d;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (issmartphone == 0 && islandscape == 0)
|
||||||
|
{
|
||||||
|
// 3/2
|
||||||
|
for (uInt16 y=0; y<myHeight; y++)
|
||||||
|
{
|
||||||
|
for (uInt16 x=0; x<(myWidth>>2); x++)
|
||||||
|
{
|
||||||
|
if ( *((uInt32 *) sc) != *((uInt32 *) sp) )
|
||||||
|
{
|
||||||
|
pix1 = pal[*sc++]; pix2 = pal[*sc++];
|
||||||
|
*((uInt16 *)d) = pix1; d += pixelstep;
|
||||||
|
*((uInt16 *)d) = OPTPIXAVERAGE(pix1,pix2); d += pixelstep;
|
||||||
|
*((uInt16 *)d) = pix2; d += pixelstep;
|
||||||
|
pix1 = pal[*sc++]; pix2 = pal[*sc++];
|
||||||
|
*((uInt16 *)d) = pix1; d += pixelstep;
|
||||||
|
*((uInt16 *)d) = OPTPIXAVERAGE(pix1,pix2); d += pixelstep;
|
||||||
|
*((uInt16 *)d) = pix2; d += pixelstep;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
sc += 4;
|
||||||
|
d += pixelsteptimes6;
|
||||||
|
}
|
||||||
|
sp += 4;
|
||||||
|
}
|
||||||
|
d = pl + linestep;
|
||||||
|
pl = d;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (issmartphone == 0 && islandscape)
|
||||||
|
{
|
||||||
|
// 2/1
|
||||||
|
for (uInt16 y=0; y<myHeight; y++)
|
||||||
|
{
|
||||||
|
for (uInt16 x=0; x<(myWidth>>2); x++)
|
||||||
|
{
|
||||||
|
if ( *((uInt32 *) sc) != *((uInt32 *) sp) )
|
||||||
|
{
|
||||||
|
pix1 = pal[*sc++]; pix2 = pal[*sc++];
|
||||||
|
*((uInt16 *)d) = pix1; d += pixelstep;
|
||||||
|
*((uInt16 *)d) = OPTPIXAVERAGE(pix1,pix2); d += pixelstep;
|
||||||
|
pix1 = pal[*sc++];
|
||||||
|
*((uInt16 *)d) = pix2; d += pixelstep;
|
||||||
|
*((uInt16 *)d) = OPTPIXAVERAGE(pix1,pix2); d += pixelstep;
|
||||||
|
pix2 = pal[*sc++];
|
||||||
|
*((uInt16 *)d) = pix1; d += pixelstep;
|
||||||
|
*((uInt16 *)d) = OPTPIXAVERAGE(pix1,pix2); d += pixelstep;
|
||||||
|
pix1 = pal[*sc++];
|
||||||
|
*((uInt16 *)d) = pix2; d += pixelstep;
|
||||||
|
*((uInt16 *)d) = OPTPIXAVERAGE(pix1,pix2); d += pixelstep;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
sc += 4;
|
||||||
|
d += (pixelstep << 3);
|
||||||
|
}
|
||||||
|
sp += 4;
|
||||||
|
}
|
||||||
|
d = pl + linestep;
|
||||||
|
pl = d;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void FrameBufferWinCE::wipescreen(void)
|
||||||
|
{
|
||||||
|
uInt8 *d;
|
||||||
|
|
||||||
|
if (!SubsystemInited)
|
||||||
|
lateinit();
|
||||||
|
|
||||||
|
if (&(myOSystem->console().mediaSource()) != NULL)
|
||||||
|
{
|
||||||
|
uInt8 *s = myOSystem->console().mediaSource().currentFrameBuffer();
|
||||||
|
memset(s, 0, myWidth*myHeight-1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( (d = (uInt8 *) GXBeginDraw()) == NULL )
|
||||||
|
return;
|
||||||
|
for (int i=0; i < scrwidth*scrheight; i++, *((uInt16 *)d) = 0, d += 2);
|
||||||
|
GXEndDraw();
|
||||||
}
|
}
|
||||||
|
|
||||||
void FrameBufferWinCE::postFrameUpdate()
|
void FrameBufferWinCE::postFrameUpdate()
|
||||||
|
@ -130,7 +370,6 @@ void FrameBufferWinCE::drawChar(const GUI::Font* font, uInt8 c, uInt32 x, uInt32
|
||||||
const FontDesc& desc = myfont->desc();
|
const FontDesc& desc = myfont->desc();
|
||||||
|
|
||||||
if (!myDstScreen) return;
|
if (!myDstScreen) return;
|
||||||
//if (!SubsystemInited) {lateinit(false); return;}
|
|
||||||
|
|
||||||
if(c < desc.firstchar || c >= desc.firstchar + desc.size)
|
if(c < desc.firstchar || c >= desc.firstchar + desc.size)
|
||||||
{
|
{
|
||||||
|
@ -139,26 +378,29 @@ void FrameBufferWinCE::drawChar(const GUI::Font* font, uInt8 c, uInt32 x, uInt32
|
||||||
c = desc.defaultchar;
|
c = desc.defaultchar;
|
||||||
}
|
}
|
||||||
|
|
||||||
const Int32 w = myfont->getCharWidth(c);
|
const Int32 w = myfont->getCharWidth(c) >> 1;
|
||||||
const Int32 h = myfont->getFontHeight();
|
const Int32 h = myfont->getFontHeight();
|
||||||
c -= desc.firstchar;
|
c -= desc.firstchar;
|
||||||
const uInt16* tmp = desc.bits + (desc.offset ? desc.offset[c] : (c * h));
|
const uInt16* tmp = desc.bits + (desc.offset ? desc.offset[c] : (c * h));
|
||||||
|
|
||||||
|
if (x<0 || y<0 || (x>>1)+w>scrwidth || y+h>scrheight) return;
|
||||||
|
|
||||||
uInt8 *d = myDstScreen + (y/* >> 1*/) * linestep + (x >> 1) * pixelstep;
|
uInt8 *d = myDstScreen + (y/* >> 1*/) * linestep + (x >> 1) * pixelstep;
|
||||||
uInt32 stride = (scrwidth - w) * pixelstep;
|
uInt32 stride = (scrwidth - w) * pixelstep;
|
||||||
uInt16 col = guipal[((int) color) - 256];
|
uInt16 col = guipal[((int) color) - 256];
|
||||||
|
uInt16 col2 = (col >> 1) & 0xFFE0;
|
||||||
|
|
||||||
for(int y2 = 0; y2 < h; y2++)
|
for(int y2 = 0; y2 < h; y2++)
|
||||||
{
|
{
|
||||||
const uInt16 buffer = *tmp++;
|
const uInt16 buffer = *tmp++;
|
||||||
uInt16 mask = 0x8000;
|
uInt16 mask = 0x8000;
|
||||||
|
|
||||||
for(int x2 = 0; x2 < w; x2++, mask >>= 1)
|
for(int x2 = 0; x2 < w; x2++, mask >>= 2)
|
||||||
{
|
{
|
||||||
if ((buffer & mask) != 0)
|
if (((buffer & mask) != 0) ^ ((buffer & mask>>1) != 0))
|
||||||
{
|
*((uInt16 *)d) = col2;
|
||||||
|
else if (((buffer & mask) != 0) && ((buffer & mask>>1) != 0))
|
||||||
*((uInt16 *)d) = col;
|
*((uInt16 *)d) = col;
|
||||||
}
|
|
||||||
d += pixelstep;
|
d += pixelstep;
|
||||||
}
|
}
|
||||||
d += stride;
|
d += stride;
|
||||||
|
@ -193,36 +435,38 @@ uInt32 FrameBufferWinCE::mapRGB(Uint8 r, Uint8 g, Uint8 b)
|
||||||
void FrameBufferWinCE::hLine(uInt32 x, uInt32 y, uInt32 x2, OverlayColor color)
|
void FrameBufferWinCE::hLine(uInt32 x, uInt32 y, uInt32 x2, OverlayColor color)
|
||||||
{
|
{
|
||||||
if (!myDstScreen) return;
|
if (!myDstScreen) return;
|
||||||
//if (!SubsystemInited) {lateinit(false); return;}
|
|
||||||
int kx = x >> 1; int ky = y/* >> 1*/; int kx2 = x2>> 1;
|
int kx = x >> 1; int ky = y/* >> 1*/; int kx2 = x2>> 1;
|
||||||
|
|
||||||
|
//if (kx<0 || ky<0 || kx2<0 || kx+kx2>scrwidth || ky>scrheight) return;
|
||||||
|
if (kx<0) kx=0; if (ky<0) ky=0; if (ky>scrheight-1) return; if (kx2>scrwidth-1) kx2=scrwidth-1;
|
||||||
|
|
||||||
uInt8 *d = myDstScreen + ky * linestep + kx * pixelstep;
|
uInt8 *d = myDstScreen + ky * linestep + kx * pixelstep;
|
||||||
uInt16 col = guipal[((int) color) - 256];
|
uInt16 col = guipal[((int) color) - 256];
|
||||||
for (;kx < kx2; kx++)
|
for (;kx < kx2; kx++, *((uInt16 *)d) = col, d += pixelstep);
|
||||||
{
|
|
||||||
*((uInt16 *)d) = col;
|
|
||||||
d += pixelstep;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void FrameBufferWinCE::vLine(uInt32 x, uInt32 y, uInt32 y2, OverlayColor color)
|
void FrameBufferWinCE::vLine(uInt32 x, uInt32 y, uInt32 y2, OverlayColor color)
|
||||||
{
|
{
|
||||||
if (!myDstScreen) return;
|
if (!myDstScreen) return;
|
||||||
//if (!SubsystemInited) {lateinit(false); return;}
|
int kx = x >> 1; int ky = y/* >> 1*/; int ky2 = y2 /*>> 1*/;
|
||||||
int kx = x >> 1; int ky = y/* >> 1*/; int ky2 = y2>> 1;
|
|
||||||
|
//if (kx<0 || ky<0 || ky2<0 || ky+ky2>scrheight || kx>scrwidth) return;
|
||||||
|
if (kx<0) kx=0; if (ky<0) ky=0; if (kx>scrwidth-1) return; if (ky2>scrheight-1) ky2=scrheight-1;
|
||||||
|
|
||||||
uInt8 *d = myDstScreen + ky * linestep + kx * pixelstep;
|
uInt8 *d = myDstScreen + ky * linestep + kx * pixelstep;
|
||||||
uInt16 col = guipal[((int) color) - 256];
|
uInt16 col = guipal[((int) color) - 256];
|
||||||
for (;ky < ky2; ky++)
|
for (;ky < ky2; ky++, *((uInt16 *)d) = col, d += linestep);
|
||||||
{
|
|
||||||
*((uInt16 *)d) = col;
|
|
||||||
d += linestep;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void FrameBufferWinCE::fillRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h, OverlayColor color)
|
void FrameBufferWinCE::fillRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h, OverlayColor color)
|
||||||
{
|
{
|
||||||
if (!myDstScreen) return;
|
if (!myDstScreen) return;
|
||||||
//if (!SubsystemInited) {lateinit(false); return;}
|
|
||||||
int kx = x >> 1; int ky = y/* >> 1*/; int kw = (w >> 1) - 1; int kh = h /*>> 1*/;
|
int kx = x >> 1; int ky = y/* >> 1*/; int kw = (w >> 1) - 1; int kh = h /*>> 1*/;
|
||||||
|
|
||||||
|
//if (kx<0 || ky<0 || kw<0 || kh<0 || kx+kw>scrwidth || ky+kh>scrheight) return;
|
||||||
|
if (kx<0) kx=0; if (ky<0) ky=0;if (kw<0) kw=0; if (kh<0) kh=0;
|
||||||
|
if (kx+kw>scrwidth-1) kw=scrwidth-kx-1; if (ky+kh>scrheight-1) kh=scrheight-ky-1;
|
||||||
|
|
||||||
uInt8 *d = myDstScreen + ky * linestep + kx * pixelstep;
|
uInt8 *d = myDstScreen + ky * linestep + kx * pixelstep;
|
||||||
uInt16 col = guipal[((int) color) - 256];
|
uInt16 col = guipal[((int) color) - 256];
|
||||||
uInt32 stride = (scrwidth - kw - 1) * pixelstep;
|
uInt32 stride = (scrwidth - kw - 1) * pixelstep;
|
||||||
|
@ -251,3 +495,10 @@ void FrameBufferWinCE::addDirtyRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uInt32 FrameBufferWinCE::lineDim()
|
||||||
|
{
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
#ifndef FRAMEBUFFER_WINCE_HXX
|
#ifndef FRAMEBUFFER_WINCE_HXX
|
||||||
#define FRAMEBUFFER_WINCE_HXX
|
#define FRAMEBUFFER_WINCE_HXX
|
||||||
|
|
||||||
|
#include <gx.h>
|
||||||
#include "bspf.hxx"
|
#include "bspf.hxx"
|
||||||
#include "FrameBuffer.hxx"
|
#include "FrameBuffer.hxx"
|
||||||
#include "OSystem.hxx"
|
#include "OSystem.hxx"
|
||||||
|
@ -28,6 +29,10 @@ class FrameBufferWinCE : public FrameBuffer
|
||||||
virtual void drawBitmap(uInt32* bitmap, Int32 x, Int32 y, OverlayColor color, Int32 h = 8);
|
virtual void drawBitmap(uInt32* bitmap, Int32 x, Int32 y, OverlayColor color, Int32 h = 8);
|
||||||
virtual void translateCoords(Int32* x, Int32* y);
|
virtual void translateCoords(Int32* x, Int32* y);
|
||||||
virtual void addDirtyRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h);
|
virtual void addDirtyRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h);
|
||||||
|
virtual uInt32 lineDim();
|
||||||
|
void wipescreen(void);
|
||||||
|
void setmode(uInt8 mode);
|
||||||
|
int rotatedisplay(void);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
|
@ -36,9 +41,16 @@ class FrameBufferWinCE : public FrameBuffer
|
||||||
// uInt32 myXstart, myYstart;
|
// uInt32 myXstart, myYstart;
|
||||||
// uInt8 *currentFrame, *previousFrame;
|
// uInt8 *currentFrame, *previousFrame;
|
||||||
uInt16 pal[256], myWidth, myHeight, guipal[kNumColors-256], scrwidth, scrheight;
|
uInt16 pal[256], myWidth, myHeight, guipal[kNumColors-256], scrwidth, scrheight;
|
||||||
uInt32 pixelstep, linestep, displacement;
|
Int32 pixelstep, linestep;
|
||||||
|
uInt32 displacement;
|
||||||
bool SubsystemInited;
|
bool SubsystemInited;
|
||||||
uInt8 *myDstScreen;
|
uInt8 *myDstScreen;
|
||||||
|
|
||||||
|
bool issmartphone, islandscape;
|
||||||
|
uInt16 minydim, optgreenmaskN, optgreenmask;
|
||||||
|
Int32 pixelsteptimes5, pixelsteptimes6;
|
||||||
|
GXDisplayProperties gxdp;
|
||||||
|
uInt8 displaymode;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
|
@ -5,9 +5,10 @@
|
||||||
#include "OSystem.hxx"
|
#include "OSystem.hxx"
|
||||||
#include "OSystemWinCE.hxx"
|
#include "OSystemWinCE.hxx"
|
||||||
#include "SoundWinCE.hxx"
|
#include "SoundWinCE.hxx"
|
||||||
|
#include "FrameBufferWinCE.hxx"
|
||||||
//#include <sstream>
|
//#include <sstream>
|
||||||
extern void KeyCheck(void);
|
extern void KeyCheck(void);
|
||||||
int EventHandlerState;
|
extern int EventHandlerState;
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
OSystemWinCE::OSystemWinCE()
|
OSystemWinCE::OSystemWinCE()
|
||||||
|
@ -15,7 +16,7 @@ OSystemWinCE::OSystemWinCE()
|
||||||
string basedir = ((string) getcwd()) + '\\';
|
string basedir = ((string) getcwd()) + '\\';
|
||||||
setBaseDir(basedir);
|
setBaseDir(basedir);
|
||||||
|
|
||||||
string stateDir = basedir + "state\\";
|
string stateDir = basedir;// + "state\\";
|
||||||
setStateDir(stateDir);
|
setStateDir(stateDir);
|
||||||
|
|
||||||
setPropertiesDir(basedir, basedir);
|
setPropertiesDir(basedir, basedir);
|
||||||
|
@ -43,19 +44,15 @@ void OSystemWinCE::setFramerate(uInt32 framerate)
|
||||||
void OSystemWinCE::mainLoop()
|
void OSystemWinCE::mainLoop()
|
||||||
{
|
{
|
||||||
|
|
||||||
// These variables are common to both timing options
|
|
||||||
// and are needed to calculate the overall frames per second.
|
|
||||||
uInt32 frameTime = 0, numberOfFrames = 0;
|
uInt32 frameTime = 0, numberOfFrames = 0;
|
||||||
|
|
||||||
// Set up less accurate timing stuff
|
|
||||||
uInt32 startTime, virtualTime, currentTime;
|
uInt32 startTime, virtualTime, currentTime;
|
||||||
|
|
||||||
// Set the base for the timers
|
|
||||||
virtualTime = GetTickCount();
|
virtualTime = GetTickCount();
|
||||||
frameTime = 0;
|
frameTime = 0;
|
||||||
|
|
||||||
// Main game loop
|
// Main game loop
|
||||||
MSG msg;
|
MSG msg;
|
||||||
|
int laststate = -1;
|
||||||
for(;;)
|
for(;;)
|
||||||
{
|
{
|
||||||
while (PeekMessage(&msg, NULL, 0U, 0U, PM_REMOVE))
|
while (PeekMessage(&msg, NULL, 0U, 0U, PM_REMOVE))
|
||||||
|
@ -76,6 +73,10 @@ void OSystemWinCE::mainLoop()
|
||||||
startTime = GetTickCount();
|
startTime = GetTickCount();
|
||||||
|
|
||||||
EventHandlerState = (int) myEventHandler->state();
|
EventHandlerState = (int) myEventHandler->state();
|
||||||
|
if ((laststate != -1) && (laststate != EventHandlerState) && (EventHandlerState != 2))
|
||||||
|
((FrameBufferWinCE *)myFrameBuffer)->wipescreen();
|
||||||
|
laststate = EventHandlerState;
|
||||||
|
|
||||||
myEventHandler->poll(startTime);
|
myEventHandler->poll(startTime);
|
||||||
myFrameBuffer->update();
|
myFrameBuffer->update();
|
||||||
((SoundWinCE *)mySound)->update();
|
((SoundWinCE *)mySound)->update();
|
||||||
|
@ -84,6 +85,8 @@ void OSystemWinCE::mainLoop()
|
||||||
virtualTime += myTimePerFrame;
|
virtualTime += myTimePerFrame;
|
||||||
if(currentTime < virtualTime)
|
if(currentTime < virtualTime)
|
||||||
Sleep(virtualTime - currentTime);
|
Sleep(virtualTime - currentTime);
|
||||||
|
else
|
||||||
|
virtualTime = currentTime;
|
||||||
|
|
||||||
currentTime = GetTickCount() - startTime;
|
currentTime = GetTickCount() - startTime;
|
||||||
frameTime += currentTime;
|
frameTime += currentTime;
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#include <gx.h>
|
|
||||||
#include "EventHandler.hxx"
|
#include "EventHandler.hxx"
|
||||||
#include "OSystemWinCE.hxx"
|
#include "OSystemWinCE.hxx"
|
||||||
#include "SettingsWinCE.hxx"
|
#include "SettingsWinCE.hxx"
|
||||||
#include "PropsSet.hxx"
|
#include "PropsSet.hxx"
|
||||||
#include "FSNode.hxx"
|
#include "FSNode.hxx"
|
||||||
|
#include "FrameBufferWinCE.hxx"
|
||||||
|
|
||||||
#define KEYSCHECK_ASYNC
|
#define KEYSCHECK_ASYNC
|
||||||
|
|
||||||
|
@ -17,20 +17,30 @@ struct key2event
|
||||||
};
|
};
|
||||||
extern key2event keycodes[2][MAX_KEYS];
|
extern key2event keycodes[2][MAX_KEYS];
|
||||||
extern void KeySetup(void);
|
extern void KeySetup(void);
|
||||||
|
extern void KeySetMode(int);
|
||||||
|
|
||||||
OSystemWinCE* theOSystem = (OSystemWinCE*) NULL;
|
OSystemWinCE* theOSystem = (OSystemWinCE*) NULL;
|
||||||
HWND hWnd;
|
HWND hWnd;
|
||||||
|
uInt16 rotkeystate = 0;
|
||||||
|
|
||||||
|
|
||||||
void KeyCheck(void)
|
void KeyCheck(void)
|
||||||
{
|
{
|
||||||
#ifdef KEYSCHECK_ASYNC
|
#ifdef KEYSCHECK_ASYNC
|
||||||
if (GetAsyncKeyState(keycodes[0][K_QUIT].keycode) & 0x8000)
|
if (GetAsyncKeyState(VK_F3))
|
||||||
{
|
{
|
||||||
PostQuitMessage(0);
|
if (rotkeystate == 0)
|
||||||
return;
|
KeySetMode( ((FrameBufferWinCE *) (&(theOSystem->frameBuffer())))->rotatedisplay() );
|
||||||
|
rotkeystate = 1;
|
||||||
}
|
}
|
||||||
for (int i=0; i<MAX_KEYS-1; i++)
|
else
|
||||||
keycodes[0][i].state = ((uInt16) GetAsyncKeyState(keycodes[0][i].keycode)) >> 15;
|
rotkeystate = 0;
|
||||||
|
|
||||||
|
for (int i=0; i<MAX_KEYS; i++)
|
||||||
|
if (GetAsyncKeyState(keycodes[0][i].keycode))
|
||||||
|
keycodes[0][i].state = 1;
|
||||||
|
else
|
||||||
|
keycodes[0][i].state = 0;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,33 +54,30 @@ void CleanUp(void)
|
||||||
|
|
||||||
LRESULT CALLBACK WindowProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam )
|
LRESULT CALLBACK WindowProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam )
|
||||||
{
|
{
|
||||||
static PAINTSTRUCT ps;
|
|
||||||
|
|
||||||
switch (uMsg)
|
switch (uMsg)
|
||||||
{
|
{
|
||||||
case WM_KEYDOWN:
|
case WM_KEYDOWN:
|
||||||
|
if (wParam == VK_F3)
|
||||||
|
{
|
||||||
|
if (rotkeystate == 0)
|
||||||
|
KeySetMode( ((FrameBufferWinCE *) (&(theOSystem->frameBuffer())))->rotatedisplay() );
|
||||||
|
rotkeystate = 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
rotkeystate = 0;
|
||||||
#ifndef KEYSCHECK_ASYNC
|
#ifndef KEYSCHECK_ASYNC
|
||||||
uInt8 i;
|
uInt8 i;
|
||||||
if (wParam == keycodes[K_QUIT].keycode)
|
for (i=0; i<MAX_KEYS; i++)
|
||||||
PostQuitMessage(0);
|
if (wParam == keycodes[0][i].keycode)
|
||||||
else
|
keycodes[0][i].state = 1;
|
||||||
for (i=0; i<MAX_KEYS-1; i++)
|
|
||||||
if (wParam == keycodes[i].keycode)
|
|
||||||
{
|
|
||||||
theConsole->eventHandler().event()->set(keycodes[i].event,1);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case WM_KEYUP:
|
case WM_KEYUP:
|
||||||
#ifndef KEYSCHECK_ASYNC
|
#ifndef KEYSCHECK_ASYNC
|
||||||
for (i=0; i<MAX_KEYS-1; i++)
|
for (i=0; i<MAX_KEYS; i++)
|
||||||
if (wParam == keycodes[i].keycode)
|
if (wParam == keycodes[0][i].keycode)
|
||||||
{
|
keycodes[0][i].state = 0;
|
||||||
theConsole->eventHandler().event()->set(keycodes[i].event,0);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
@ -91,13 +98,8 @@ LRESULT CALLBACK WindowProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam )
|
||||||
case WM_HIBERNATE:
|
case WM_HIBERNATE:
|
||||||
GXResume();
|
GXResume();
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case WM_PAINT:
|
|
||||||
BeginPaint(hWnd, &ps);
|
|
||||||
EndPaint(hWnd, &ps);
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return DefWindowProc(hwnd, uMsg, wParam, lParam);
|
return DefWindowProc(hwnd, uMsg, wParam, lParam);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -110,7 +112,7 @@ int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPWSTR lpCmdLin
|
||||||
hWnd = CreateWindow(wndname, wndname, WS_VISIBLE, 0, 0, GetSystemMetrics(SM_CXSCREEN),
|
hWnd = CreateWindow(wndname, wndname, WS_VISIBLE, 0, 0, GetSystemMetrics(SM_CXSCREEN),
|
||||||
GetSystemMetrics(SM_CYSCREEN), NULL, NULL, hInstance, NULL);
|
GetSystemMetrics(SM_CYSCREEN), NULL, NULL, hInstance, NULL);
|
||||||
if (!hWnd) return 1;
|
if (!hWnd) return 1;
|
||||||
SetWindowPos(hWnd, HWND_TOPMOST, 0, 0, 0, 0, SWP_NOMOVE|SWP_NOSIZE);
|
SetWindowPos(hWnd, HWND_TOP, 0, 0, 0, 0, SWP_NOMOVE|SWP_NOSIZE);
|
||||||
|
|
||||||
MSG msg;
|
MSG msg;
|
||||||
while (PeekMessage(&msg, NULL, 0U, 0U, PM_REMOVE))
|
while (PeekMessage(&msg, NULL, 0U, 0U, PM_REMOVE))
|
||||||
|
@ -119,6 +121,19 @@ int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPWSTR lpCmdLin
|
||||||
DispatchMessage(&msg);
|
DispatchMessage(&msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LOGFONT f = {11, 0, 0, 0, FW_NORMAL, FALSE, FALSE, FALSE, DEFAULT_CHARSET, OUT_DEFAULT_PRECIS,
|
||||||
|
OUT_DEFAULT_PRECIS, DEFAULT_QUALITY, DEFAULT_PITCH, _T("")};
|
||||||
|
HFONT hFnt = CreateFontIndirect(&f);
|
||||||
|
HDC hDC = GetDC(hWnd);
|
||||||
|
SelectObject(hDC, hFnt);
|
||||||
|
RECT RWnd;
|
||||||
|
GetClipBox(hDC, &RWnd);
|
||||||
|
SetTextColor(hDC, 0xA0A0A0);
|
||||||
|
SetBkColor(hDC, 0);
|
||||||
|
DrawText(hDC, _T("PocketStella Initializing..."), -1, &RWnd, DT_CENTER | DT_VCENTER);
|
||||||
|
ReleaseDC(hWnd, hDC);
|
||||||
|
DeleteObject(hFnt);
|
||||||
|
|
||||||
theOSystem = new OSystemWinCE();
|
theOSystem = new OSystemWinCE();
|
||||||
SettingsWinCE theSettings(theOSystem);
|
SettingsWinCE theSettings(theOSystem);
|
||||||
theOSystem->settings().loadConfig();
|
theOSystem->settings().loadConfig();
|
||||||
|
@ -146,12 +161,7 @@ int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPWSTR lpCmdLin
|
||||||
if (!FilesystemNode::fileExists(romfile))
|
if (!FilesystemNode::fileExists(romfile))
|
||||||
theOSystem->createLauncher();
|
theOSystem->createLauncher();
|
||||||
else
|
else
|
||||||
{
|
|
||||||
/*TCHAR tmp[200];
|
|
||||||
MultiByteToWideChar(CP_ACP, 0, romfile.c_str(), strlen(romfile.c_str()) + 1, tmp, 200);
|
|
||||||
MessageBox(hWnd, tmp, _T("..."),0);*/
|
|
||||||
theOSystem->createConsole(romfile);
|
theOSystem->createConsole(romfile);
|
||||||
}
|
|
||||||
|
|
||||||
theOSystem->mainLoop();
|
theOSystem->mainLoop();
|
||||||
|
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -224,6 +224,20 @@ void SoundWinCE::processFragment(uInt8* stream, Int32 length)
|
||||||
float position = 0.0;
|
float position = 0.0;
|
||||||
float remaining = length;
|
float remaining = length;
|
||||||
|
|
||||||
|
if(myRegWriteQueue.duration() >
|
||||||
|
(9.0 / myDisplayFrameRate))
|
||||||
|
{
|
||||||
|
float removed = 0.0;
|
||||||
|
while(removed < ((9.0 - 1) / myDisplayFrameRate))
|
||||||
|
{
|
||||||
|
RegWrite& info = myRegWriteQueue.front();
|
||||||
|
removed += info.delta;
|
||||||
|
myTIASound.set(info.addr, info.value);
|
||||||
|
myRegWriteQueue.dequeue();
|
||||||
|
}
|
||||||
|
// cout << "Removed Items from RegWriteQueue!" << endl;
|
||||||
|
}
|
||||||
|
|
||||||
while(remaining > 0.0)
|
while(remaining > 0.0)
|
||||||
{
|
{
|
||||||
if(myRegWriteQueue.size() == 0)
|
if(myRegWriteQueue.size() == 0)
|
||||||
|
|
|
@ -76,7 +76,7 @@ class SoundWinCE : public Sound
|
||||||
bool myIsMuted;
|
bool myIsMuted;
|
||||||
uInt32 myVolume;
|
uInt32 myVolume;
|
||||||
RegWriteQueue myRegWriteQueue;
|
RegWriteQueue myRegWriteQueue;
|
||||||
//static void CALLBACK SoundWinCE::waveOutProc(HWAVEOUT hwo, UINT uMsg, DWORD dwInstance, DWORD dwParam1, DWORD dwParam2);
|
//static void CALLBACK SoundWinCE::waveOutProc(HWAVEOUT hwo, UINT uMsg, DWORD dwInstance, DWORD dwParam1, DWORD dwParam2);
|
||||||
int myLatency, myMixRate, myBuffnum;
|
int myLatency, myMixRate, myBuffnum;
|
||||||
WAVEHDR *myBuffers;
|
WAVEHDR *myBuffers;
|
||||||
HWAVEOUT myWout;
|
HWAVEOUT myWout;
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
#include "gx.h"
|
#include "gx.h"
|
||||||
|
|
||||||
char *msg = NULL;
|
char *msg = NULL;
|
||||||
extern int EventHandlerState;
|
int EventHandlerState;
|
||||||
|
|
||||||
int time(int dummy)
|
int time(int dummy)
|
||||||
{
|
{
|
||||||
|
@ -16,15 +16,11 @@ char *getcwd(void)
|
||||||
static char cwd[MAX_PATH+1] = "";
|
static char cwd[MAX_PATH+1] = "";
|
||||||
char *plast;
|
char *plast;
|
||||||
|
|
||||||
// if(cwd[0] == 0)
|
GetModuleFileName(NULL, fileUnc, MAX_PATH);
|
||||||
// {
|
WideCharToMultiByte(CP_ACP, 0, fileUnc, -1, cwd, MAX_PATH, NULL, NULL);
|
||||||
GetModuleFileName(NULL, fileUnc, MAX_PATH);
|
plast = strrchr(cwd, '\\');
|
||||||
WideCharToMultiByte(CP_ACP, 0, fileUnc, -1, cwd, MAX_PATH, NULL, NULL);
|
if(plast)
|
||||||
plast = strrchr(cwd, '\\');
|
*plast = 0;
|
||||||
if(plast)
|
|
||||||
*plast = 0;
|
|
||||||
|
|
||||||
// }
|
|
||||||
|
|
||||||
return cwd;
|
return cwd;
|
||||||
}
|
}
|
||||||
|
@ -64,17 +60,49 @@ void KeySetup(void)
|
||||||
keycodes[i][K_FIRE].sdlkey = SDLK_SPACE;
|
keycodes[i][K_FIRE].sdlkey = SDLK_SPACE;
|
||||||
keycodes[i][K_RESET].sdlkey = SDLK_F2;
|
keycodes[i][K_RESET].sdlkey = SDLK_F2;
|
||||||
keycodes[i][K_SELECT].sdlkey = SDLK_F1;
|
keycodes[i][K_SELECT].sdlkey = SDLK_F1;
|
||||||
keycodes[i][K_QUIT].sdlkey = SDLK_q;
|
keycodes[i][K_QUIT].sdlkey = SDLK_ESCAPE;
|
||||||
|
|
||||||
keycodes[i][K_UP].launcherkey = SDLK_UP;
|
keycodes[i][K_UP].launcherkey = SDLK_UP;
|
||||||
keycodes[i][K_DOWN].launcherkey = SDLK_DOWN;
|
keycodes[i][K_DOWN].launcherkey = SDLK_DOWN;
|
||||||
keycodes[i][K_LEFT].launcherkey = SDLK_LEFT;
|
keycodes[i][K_LEFT].launcherkey = SDLK_PAGEUP;
|
||||||
keycodes[i][K_RIGHT].launcherkey = SDLK_RIGHT;
|
keycodes[i][K_RIGHT].launcherkey = SDLK_PAGEDOWN;
|
||||||
keycodes[i][K_RESET].launcherkey = SDLK_RETURN;
|
keycodes[i][K_RESET].launcherkey = SDLK_RETURN;
|
||||||
|
keycodes[i][K_QUIT].launcherkey = SDLK_ESCAPE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void KeySetMode(int mode)
|
||||||
|
{
|
||||||
|
GXKeyList klist = GXGetDefaultKeys(GX_NORMALKEYS);
|
||||||
|
|
||||||
|
for (int i=0; i<2; i++)
|
||||||
|
{
|
||||||
|
switch (mode)
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
keycodes[i][K_UP].keycode = klist.vkUp;
|
||||||
|
keycodes[i][K_DOWN].keycode = klist.vkDown;
|
||||||
|
keycodes[i][K_LEFT].keycode = klist.vkLeft;
|
||||||
|
keycodes[i][K_RIGHT].keycode = klist.vkRight;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 2:
|
||||||
|
keycodes[i][K_UP].keycode = klist.vkRight;
|
||||||
|
keycodes[i][K_DOWN].keycode = klist.vkLeft;
|
||||||
|
keycodes[i][K_LEFT].keycode = klist.vkUp;
|
||||||
|
keycodes[i][K_RIGHT].keycode = klist.vkDown;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 1:
|
||||||
|
keycodes[i][K_UP].keycode = klist.vkLeft;
|
||||||
|
keycodes[i][K_DOWN].keycode = klist.vkRight;
|
||||||
|
keycodes[i][K_LEFT].keycode = klist.vkDown;
|
||||||
|
keycodes[i][K_RIGHT].keycode = klist.vkUp;
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// SDL
|
// SDL
|
||||||
DECLSPEC Uint32 SDLCALL SDL_WasInit(Uint32 flags) { return 0xFFFFFFFF; }
|
DECLSPEC Uint32 SDLCALL SDL_WasInit(Uint32 flags) { return 0xFFFFFFFF; }
|
||||||
|
@ -95,16 +123,21 @@ DECLSPEC int SDLCALL SDL_PollEvent(SDL_Event *event)
|
||||||
if (keycodes[0][i].state != keycodes[1][i].state)
|
if (keycodes[0][i].state != keycodes[1][i].state)
|
||||||
{
|
{
|
||||||
keycodes[1][i].state = keycodes[0][i].state;
|
keycodes[1][i].state = keycodes[0][i].state;
|
||||||
if (keycodes[1][i].state == 1)
|
if (i!=K_QUIT || EventHandlerState!=2)
|
||||||
event->type = event->key.type = SDL_KEYDOWN;
|
{
|
||||||
else
|
if (keycodes[1][i].state == 1)
|
||||||
event->type = event->key.type = SDL_KEYUP;
|
event->type = event->key.type = SDL_KEYDOWN;
|
||||||
if (EventHandlerState == 0)
|
else
|
||||||
|
event->type = event->key.type = SDL_KEYUP;
|
||||||
|
}
|
||||||
|
else if (keycodes[1][i].state == 1)
|
||||||
|
event->type = SDL_QUIT;
|
||||||
|
if (EventHandlerState != 2)
|
||||||
event->key.keysym.sym = keycodes[0][i].sdlkey;
|
event->key.keysym.sym = keycodes[0][i].sdlkey;
|
||||||
else
|
else
|
||||||
event->key.keysym.sym = keycodes[0][i].launcherkey;
|
event->key.keysym.sym = keycodes[0][i].launcherkey;
|
||||||
event->key.keysym.mod = (SDLMod) 0;
|
event->key.keysym.mod = (SDLMod) 0;
|
||||||
event->key.keysym.unicode = 0;
|
event->key.keysym.unicode = '\n'; // hack
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,72 @@
|
||||||
|
//Microsoft Developer Studio generated resource script.
|
||||||
|
//
|
||||||
|
#include "resrc1.h"
|
||||||
|
|
||||||
|
#define APSTUDIO_READONLY_SYMBOLS
|
||||||
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// Generated from the TEXTINCLUDE 2 resource.
|
||||||
|
//
|
||||||
|
#include "resource.h"
|
||||||
|
|
||||||
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
#undef APSTUDIO_READONLY_SYMBOLS
|
||||||
|
|
||||||
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
// English (U.S.) resources
|
||||||
|
/*
|
||||||
|
#if !defined(AFX_RESOURCE_DLL) || defined(AFX_TARG_ENU)
|
||||||
|
#ifdef _WIN32
|
||||||
|
LANGUAGE LANG_ENGLISH, SUBLANG_ENGLISH_US
|
||||||
|
#pragma code_page(1252)
|
||||||
|
#endif //_WIN32
|
||||||
|
*/
|
||||||
|
#ifdef APSTUDIO_INVOKED
|
||||||
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// TEXTINCLUDE
|
||||||
|
//
|
||||||
|
|
||||||
|
1 TEXTINCLUDE DISCARDABLE
|
||||||
|
BEGIN
|
||||||
|
"resrc1.h\0"
|
||||||
|
END
|
||||||
|
|
||||||
|
2 TEXTINCLUDE DISCARDABLE
|
||||||
|
BEGIN
|
||||||
|
"#include ""resource.h""\r\n"
|
||||||
|
"\0"
|
||||||
|
END
|
||||||
|
|
||||||
|
3 TEXTINCLUDE DISCARDABLE
|
||||||
|
BEGIN
|
||||||
|
"\r\n"
|
||||||
|
"\0"
|
||||||
|
END
|
||||||
|
|
||||||
|
#endif // APSTUDIO_INVOKED
|
||||||
|
|
||||||
|
|
||||||
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// Icon
|
||||||
|
//
|
||||||
|
|
||||||
|
// Icon with lowest ID value placed first to ensure application icon
|
||||||
|
// remains consistent on all systems.
|
||||||
|
IDI_STELLA ICON DISCARDABLE "stella.ico"
|
||||||
|
//#endif // English (U.S.) resources
|
||||||
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef APSTUDIO_INVOKED
|
||||||
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// Generated from the TEXTINCLUDE 3 resource.
|
||||||
|
//
|
||||||
|
|
||||||
|
|
||||||
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
#endif // not APSTUDIO_INVOKED
|
||||||
|
|
|
@ -0,0 +1,16 @@
|
||||||
|
//{{NO_DEPENDENCIES}}
|
||||||
|
// Microsoft Developer Studio generated include file.
|
||||||
|
// Used by resource.rc
|
||||||
|
//
|
||||||
|
#define IDI_ICON1 102
|
||||||
|
|
||||||
|
// Next default values for new objects
|
||||||
|
//
|
||||||
|
#ifdef APSTUDIO_INVOKED
|
||||||
|
#ifndef APSTUDIO_READONLY_SYMBOLS
|
||||||
|
#define _APS_NEXT_RESOURCE_VALUE 104
|
||||||
|
#define _APS_NEXT_COMMAND_VALUE 40001
|
||||||
|
#define _APS_NEXT_CONTROL_VALUE 1000
|
||||||
|
#define _APS_NEXT_SYMED_VALUE 101
|
||||||
|
#endif
|
||||||
|
#endif
|
Binary file not shown.
After Width: | Height: | Size: 1.1 KiB |
Loading…
Reference in New Issue