newemuloop: fix some timing regressions; win32: improve map view
This commit is contained in:
parent
3c0646c423
commit
3f291c8e6a
|
@ -719,6 +719,8 @@ void GPU_setMasterBrightness (GPU *gpu, u16 val)
|
||||||
}
|
}
|
||||||
gpu->MasterBrightFactor = (val & 0x1F);
|
gpu->MasterBrightFactor = (val & 0x1F);
|
||||||
gpu->MasterBrightMode = (val>>14);
|
gpu->MasterBrightMode = (val>>14);
|
||||||
|
//printf("MASTER BRIGHTNESS %d to %d at %d\n",gpu->core,gpu->MasterBrightFactor,nds.VCount);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void SetupFinalPixelBlitter (GPU *gpu)
|
void SetupFinalPixelBlitter (GPU *gpu)
|
||||||
|
@ -958,11 +960,11 @@ FORCEINLINE void GPU::renderline_checkWindows(u16 x, bool &draw, bool &effect) c
|
||||||
// PIXEL RENDERING - BGS
|
// PIXEL RENDERING - BGS
|
||||||
/*****************************************************************************/
|
/*****************************************************************************/
|
||||||
|
|
||||||
template<bool BACKDROP> FORCEINLINE void GPU::setFinalBGColorSpecialNone(u16 &color, const u8 x)
|
template<bool BACKDROP> FORCEINLINE void GPU::setFinalBGColorSpecialNone(u16 &color, const u32 x)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
template<bool BACKDROP> FORCEINLINE void GPU::setFinalBGColorSpecialBlend(u16 &color, const u8 x)
|
template<bool BACKDROP> FORCEINLINE void GPU::setFinalBGColorSpecialBlend(u16 &color, const u32 x)
|
||||||
{
|
{
|
||||||
//blend backdrop with what?? this doesn't make sense
|
//blend backdrop with what?? this doesn't make sense
|
||||||
if(BACKDROP) return;
|
if(BACKDROP) return;
|
||||||
|
@ -975,7 +977,7 @@ template<bool BACKDROP> FORCEINLINE void GPU::setFinalBGColorSpecialBlend(u16 &c
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template<bool BACKDROP> FORCEINLINE void GPU::setFinalBGColorSpecialIncrease (u16 &color, const u8 x)
|
template<bool BACKDROP> FORCEINLINE void GPU::setFinalBGColorSpecialIncrease (u16 &color, const u32 x)
|
||||||
{
|
{
|
||||||
if(blend1) // the bg to draw has a special color effect
|
if(blend1) // the bg to draw has a special color effect
|
||||||
{
|
{
|
||||||
|
@ -983,7 +985,7 @@ template<bool BACKDROP> FORCEINLINE void GPU::setFinalBGColorSpecialIncrease (u1
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template<bool BACKDROP> FORCEINLINE void GPU::setFinalBGColorSpecialDecrease(u16 &color, const u8 x)
|
template<bool BACKDROP> FORCEINLINE void GPU::setFinalBGColorSpecialDecrease(u16 &color, const u32 x)
|
||||||
{
|
{
|
||||||
if(blend1) // the bg to draw has a special color effect
|
if(blend1) // the bg to draw has a special color effect
|
||||||
{
|
{
|
||||||
|
@ -991,7 +993,7 @@ template<bool BACKDROP> FORCEINLINE void GPU::setFinalBGColorSpecialDecrease(u16
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template<bool BACKDROP> FORCEINLINE bool GPU::setFinalBGColorSpecialNoneWnd(u16 &color, const u8 x)
|
template<bool BACKDROP> FORCEINLINE bool GPU::setFinalBGColorSpecialNoneWnd(u16 &color, const u32 x)
|
||||||
{
|
{
|
||||||
bool windowDraw = true, windowEffect = true;
|
bool windowDraw = true, windowEffect = true;
|
||||||
|
|
||||||
|
@ -1013,7 +1015,7 @@ template<bool BACKDROP> FORCEINLINE bool GPU::setFinalBGColorSpecialNoneWnd(u16
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
template<bool BACKDROP> FORCEINLINE bool GPU::setFinalBGColorSpecialBlendWnd(u16 &color, const u8 x)
|
template<bool BACKDROP> FORCEINLINE bool GPU::setFinalBGColorSpecialBlendWnd(u16 &color, const u32 x)
|
||||||
{
|
{
|
||||||
bool windowDraw = true, windowEffect = true;
|
bool windowDraw = true, windowEffect = true;
|
||||||
|
|
||||||
|
@ -1036,7 +1038,7 @@ template<bool BACKDROP> FORCEINLINE bool GPU::setFinalBGColorSpecialBlendWnd(u16
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
template<bool BACKDROP> FORCEINLINE bool GPU::setFinalBGColorSpecialIncreaseWnd(u16 &color, const u8 x)
|
template<bool BACKDROP> FORCEINLINE bool GPU::setFinalBGColorSpecialIncreaseWnd(u16 &color, const u32 x)
|
||||||
{
|
{
|
||||||
bool windowDraw = true, windowEffect = true;
|
bool windowDraw = true, windowEffect = true;
|
||||||
|
|
||||||
|
@ -1055,7 +1057,7 @@ template<bool BACKDROP> FORCEINLINE bool GPU::setFinalBGColorSpecialIncreaseWnd(
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
template<bool BACKDROP> FORCEINLINE bool GPU::setFinalBGColorSpecialDecreaseWnd(u16 &color, const u8 x)
|
template<bool BACKDROP> FORCEINLINE bool GPU::setFinalBGColorSpecialDecreaseWnd(u16 &color, const u32 x)
|
||||||
{
|
{
|
||||||
bool windowDraw = true, windowEffect = true;
|
bool windowDraw = true, windowEffect = true;
|
||||||
|
|
||||||
|
@ -1125,7 +1127,7 @@ static void _master_setFinalOBJColor(GPU *gpu, u32 passing, u8 *dst, u16 color,
|
||||||
gpu->bgPixels[x] = 4;
|
gpu->bgPixels[x] = 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
template<bool BACKDROP> FORCEINLINE void GPU::setFinalColorBG(u16 color, u8 x)
|
template<bool BACKDROP> FORCEINLINE void GPU::setFinalColorBG(u16 color, const u32 x)
|
||||||
{
|
{
|
||||||
//It is not safe to assert this here.
|
//It is not safe to assert this here.
|
||||||
//This is probably the best place to enforce it, since almost every single color that comes in here
|
//This is probably the best place to enforce it, since almost every single color that comes in here
|
||||||
|
@ -1173,13 +1175,12 @@ FORCEINLINE void GPU::setFinalColor3d(int dstX, int srcX)
|
||||||
|
|
||||||
//this was forced inline because most of the time it just falls through to setFinalColorBck() and the function call
|
//this was forced inline because most of the time it just falls through to setFinalColorBck() and the function call
|
||||||
//overhead was ridiculous and terrible
|
//overhead was ridiculous and terrible
|
||||||
template<bool MOSAIC, bool BACKDROP> FORCEINLINE void GPU::__setFinalColorBck(u16 color, const u8 x, const bool opaque)
|
template<bool MOSAIC, bool BACKDROP> FORCEINLINE void GPU::__setFinalColorBck(u16 color, const u32 x, const bool opaque)
|
||||||
{
|
{
|
||||||
//I commented out this line to make a point.
|
//I commented out this line to make a point.
|
||||||
//indeed, since x is a u8 we cannot pass in anything >=256
|
//under ordinary circumstances, nobody should pass in something >=256
|
||||||
//but in fact, someone is going to try. specifically, that is the map viewer debug tools
|
//but in fact, someone is going to try. specifically, that is the map viewer debug tools
|
||||||
//which try to render the enter BG. in cases where that is large, it could be up to 1024 wide.
|
//which try to render the enter BG. in cases where that is large, it could be up to 1024 wide.
|
||||||
//I think it survives this truncation to 8bits.
|
|
||||||
//assert(x<256);
|
//assert(x<256);
|
||||||
|
|
||||||
int x_int;
|
int x_int;
|
||||||
|
@ -1582,7 +1583,20 @@ static void lineNull(GPU * gpu)
|
||||||
template<bool MOSAIC> void lineText(GPU * gpu)
|
template<bool MOSAIC> void lineText(GPU * gpu)
|
||||||
{
|
{
|
||||||
BGxOFS * ofs = &gpu->dispx_st->dispx_BGxOFS[gpu->currBgNum];
|
BGxOFS * ofs = &gpu->dispx_st->dispx_BGxOFS[gpu->currBgNum];
|
||||||
renderline_textBG<MOSAIC>(gpu, T1ReadWord((u8 *)&ofs->BGxHOFS, 0), gpu->currLine + T1ReadWord((u8 *)&ofs->BGxVOFS, 0), 256);
|
|
||||||
|
|
||||||
|
|
||||||
|
if(gpu->debug)
|
||||||
|
{
|
||||||
|
const s32 wh = gpu->BGSize[gpu->currBgNum][0];
|
||||||
|
renderline_textBG<MOSAIC>(gpu, 0, gpu->currLine, wh);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
const u16 vofs = T1ReadWord((u8 *)&ofs->BGxVOFS,0);
|
||||||
|
const u16 hofs = T1ReadWord((u8 *)&ofs->BGxHOFS,0);
|
||||||
|
renderline_textBG<MOSAIC>(gpu, hofs, gpu->currLine + vofs, 256);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template<bool MOSAIC> void lineRot(GPU * gpu)
|
template<bool MOSAIC> void lineRot(GPU * gpu)
|
||||||
|
@ -1593,8 +1607,12 @@ template<bool MOSAIC> void lineRot(GPU * gpu)
|
||||||
} else {
|
} else {
|
||||||
parms = &(gpu->dispx_st)->dispx_BG3PARMS;
|
parms = &(gpu->dispx_st)->dispx_BG3PARMS;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(gpu->debug)
|
if(gpu->debug)
|
||||||
rotBG2<MOSAIC>(gpu, 0, (s16)gpu->currLine*256, 256,0, -1,-1, 256);
|
{
|
||||||
|
s32 wh = gpu->BGSize[gpu->currBgNum][0];
|
||||||
|
rotBG2<MOSAIC>(gpu, 0, (s16)gpu->currLine*256, 256,0, 0,-77, wh);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
rotBG2<MOSAIC>(gpu,
|
rotBG2<MOSAIC>(gpu,
|
||||||
|
@ -1620,7 +1638,10 @@ template<bool MOSAIC> void lineExtRot(GPU * gpu)
|
||||||
}
|
}
|
||||||
|
|
||||||
if(gpu->debug)
|
if(gpu->debug)
|
||||||
extRotBG2<MOSAIC>(gpu, 0, (s16)gpu->currLine*256, 256,0, -1,-1, 256);
|
{
|
||||||
|
s32 wh = gpu->BGSize[gpu->currBgNum][0];
|
||||||
|
extRotBG2<MOSAIC>(gpu, 0, (s16)gpu->currLine*256, 256,0, 0,-77, wh);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
extRotBG2<MOSAIC>(gpu,
|
extRotBG2<MOSAIC>(gpu,
|
||||||
|
@ -2468,7 +2489,7 @@ static void GPU_ligne_layer(NDS_Screen * screen, u16 l)
|
||||||
}
|
}
|
||||||
|
|
||||||
//useful for debugging individual layers
|
//useful for debugging individual layers
|
||||||
//if(gpu->core == 0 && i16 != 1) continue;
|
//if(gpu->core == 1 || i16 != 2) continue;
|
||||||
|
|
||||||
if(gpu->curr_mosaic_enabled)
|
if(gpu->curr_mosaic_enabled)
|
||||||
gpu->modeRender<true>(i16);
|
gpu->modeRender<true>(i16);
|
||||||
|
@ -2804,6 +2825,9 @@ void GPU_ligne(NDS_Screen * screen, u16 l)
|
||||||
gpu->refreshAffineStartRegs(-1,-1);
|
gpu->refreshAffineStartRegs(-1,-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//if(gpu->core == 1)
|
||||||
|
// printf("%d\n",l);
|
||||||
|
|
||||||
//blacken the screen if it is turned off by the user
|
//blacken the screen if it is turned off by the user
|
||||||
if(!CommonSettings.showGpu.screens[gpu->core])
|
if(!CommonSettings.showGpu.screens[gpu->core])
|
||||||
{
|
{
|
||||||
|
@ -2812,6 +2836,12 @@ void GPU_ligne(NDS_Screen * screen, u16 l)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//{
|
||||||
|
// extern int currFrameCounter;
|
||||||
|
// u8 * dst = GPU_screen + (screen->offset + l) * 512;
|
||||||
|
// memset(dst,currFrameCounter,512);
|
||||||
|
//}
|
||||||
|
|
||||||
//cache some parameters which are assumed to be stable throughout the rendering of the entire line
|
//cache some parameters which are assumed to be stable throughout the rendering of the entire line
|
||||||
gpu->currLine = (u8)l;
|
gpu->currLine = (u8)l;
|
||||||
u16 mosaic_control = T1ReadWord((u8 *)&gpu->dispx_st->dispx_MISC.MOSAIC, 0);
|
u16 mosaic_control = T1ReadWord((u8 *)&gpu->dispx_st->dispx_MISC.MOSAIC, 0);
|
||||||
|
@ -2874,8 +2904,6 @@ void GPU_ligne(NDS_Screen * screen, u16 l)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
GPU_ligne_MasterBrightness(screen, l);
|
GPU_ligne_MasterBrightness(screen, l);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -728,9 +728,9 @@ struct GPU
|
||||||
u8 MasterBrightMode;
|
u8 MasterBrightMode;
|
||||||
u32 MasterBrightFactor;
|
u32 MasterBrightFactor;
|
||||||
|
|
||||||
u8 bgPixels[256];
|
u8 bgPixels[1024]; //yes indeed, this is oversized. map debug tools try to write to it
|
||||||
|
|
||||||
u8 currLine;
|
u32 currLine;
|
||||||
u8 currBgNum;
|
u8 currBgNum;
|
||||||
bool blend1;
|
bool blend1;
|
||||||
u8* currDst;
|
u8* currDst;
|
||||||
|
@ -779,17 +779,17 @@ struct GPU
|
||||||
void _spriteRender(u8 * dst, u8 * dst_alpha, u8 * typeTab, u8 * prioTab);
|
void _spriteRender(u8 * dst, u8 * dst_alpha, u8 * typeTab, u8 * prioTab);
|
||||||
void spriteRender(u8 * dst, u8 * dst_alpha, u8 * typeTab, u8 * prioTab);
|
void spriteRender(u8 * dst, u8 * dst_alpha, u8 * typeTab, u8 * prioTab);
|
||||||
|
|
||||||
template<bool BACKDROP> void setFinalColorBG(u16 color, u8 x);
|
template<bool BACKDROP> void setFinalColorBG(u16 color, const u32 x);
|
||||||
void setFinalColor3d(int dstX, int srcX);
|
void setFinalColor3d(int dstX, int srcX);
|
||||||
|
|
||||||
template<bool BACKDROP> FORCEINLINE void setFinalBGColorSpecialNone(u16 &color, u8 x);
|
template<bool BACKDROP> FORCEINLINE void setFinalBGColorSpecialNone(u16 &color, const u32 x);
|
||||||
template<bool BACKDROP> FORCEINLINE void setFinalBGColorSpecialBlend(u16 &color, u8 x);
|
template<bool BACKDROP> FORCEINLINE void setFinalBGColorSpecialBlend(u16 &color, const u32 x);
|
||||||
template<bool BACKDROP> FORCEINLINE void setFinalBGColorSpecialIncrease(u16 &color, u8 x);
|
template<bool BACKDROP> FORCEINLINE void setFinalBGColorSpecialIncrease(u16 &color, const u32 x);
|
||||||
template<bool BACKDROP> FORCEINLINE void setFinalBGColorSpecialDecrease(u16 &color, u8 x);
|
template<bool BACKDROP> FORCEINLINE void setFinalBGColorSpecialDecrease(u16 &color, const u32 x);
|
||||||
template<bool BACKDROP> FORCEINLINE bool setFinalBGColorSpecialNoneWnd(u16 &color, u8 x);
|
template<bool BACKDROP> FORCEINLINE bool setFinalBGColorSpecialNoneWnd(u16 &color, const u32 x);
|
||||||
template<bool BACKDROP> FORCEINLINE bool setFinalBGColorSpecialBlendWnd(u16 &color, u8 x);
|
template<bool BACKDROP> FORCEINLINE bool setFinalBGColorSpecialBlendWnd(u16 &color, const u32 x);
|
||||||
template<bool BACKDROP> FORCEINLINE bool setFinalBGColorSpecialIncreaseWnd(u16 &color, u8 x);
|
template<bool BACKDROP> FORCEINLINE bool setFinalBGColorSpecialIncreaseWnd(u16 &color, const u32 x);
|
||||||
template<bool BACKDROP> FORCEINLINE bool setFinalBGColorSpecialDecreaseWnd(u16 &color, u8 x);
|
template<bool BACKDROP> FORCEINLINE bool setFinalBGColorSpecialDecreaseWnd(u16 &color, const u32 x);
|
||||||
|
|
||||||
FORCEINLINE void setFinal3DColorSpecialNone(int dstX, int srcX);
|
FORCEINLINE void setFinal3DColorSpecialNone(int dstX, int srcX);
|
||||||
FORCEINLINE void setFinal3DColorSpecialBlend(int dstX, int srcX);
|
FORCEINLINE void setFinal3DColorSpecialBlend(int dstX, int srcX);
|
||||||
|
@ -801,7 +801,7 @@ struct GPU
|
||||||
FORCEINLINE void setFinal3DColorSpecialDecreaseWnd(int dstX, int srcX);
|
FORCEINLINE void setFinal3DColorSpecialDecreaseWnd(int dstX, int srcX);
|
||||||
|
|
||||||
|
|
||||||
template<bool MOSAIC, bool BACKDROP> void __setFinalColorBck(u16 color, const u8 x, const bool opaque);
|
template<bool MOSAIC, bool BACKDROP> void __setFinalColorBck(u16 color, const u32 x, const bool opaque);
|
||||||
void setAffineStart(int layer, int xy, u32 val);
|
void setAffineStart(int layer, int xy, u32 val);
|
||||||
void setAffineStartWord(int layer, int xy, u16 val, int word);
|
void setAffineStartWord(int layer, int xy, u16 val, int word);
|
||||||
u32 getAffineStart(int layer, int xy);
|
u32 getAffineStart(int layer, int xy);
|
||||||
|
|
|
@ -1800,8 +1800,21 @@ void execHardware_hblank()
|
||||||
//this logic was formerly at hblank time. it was moved to the beginning of the scanline on a whim
|
//this logic was formerly at hblank time. it was moved to the beginning of the scanline on a whim
|
||||||
if(nds.VCount<192)
|
if(nds.VCount<192)
|
||||||
{
|
{
|
||||||
//trigger hblank dmas.
|
//so, we have chosen to do the line drawing at hblank time.
|
||||||
//but should this happen for non-displayed scanlines??? not sure
|
//this is the traditional time for it in desmume.
|
||||||
|
//while it may seem more ruthlessly accurate to do it at hstart,
|
||||||
|
//in practice we need to be more forgiving, in case things have overrun the scanline start.
|
||||||
|
//this should be safe since games cannot do anything timing dependent until this next
|
||||||
|
//scanline begins, anyway (as this scanline was in the middle of drawing)
|
||||||
|
if(!SkipCur2DFrame)
|
||||||
|
{
|
||||||
|
GPU_ligne(&MainScreen, nds.VCount);
|
||||||
|
GPU_ligne(&SubScreen, nds.VCount);
|
||||||
|
}
|
||||||
|
|
||||||
|
//trigger hblank dmas
|
||||||
|
//but notice, we do that just after we finished drawing the line
|
||||||
|
//(values copied by this hdma should not be used until the next scanline)
|
||||||
execHardware_doAllDma(EDMAMode_HBlank);
|
execHardware_doAllDma(EDMAMode_HBlank);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1889,23 +1902,14 @@ void execHardware_hstart()
|
||||||
//handle vcount status
|
//handle vcount status
|
||||||
execHardware_hstart_vcount();
|
execHardware_hstart_vcount();
|
||||||
|
|
||||||
//this logic was formerly at hblank time. it was moved to the beginning of the scanline on a whim
|
|
||||||
if(nds.VCount<192)
|
|
||||||
{
|
|
||||||
//trigger hstart dmas
|
//trigger hstart dmas
|
||||||
//in an effort to more accurately mimic what might happen in cases where these are used
|
|
||||||
//to adjust the scanline which is just about to render, the dma occurs before the scanline draw
|
|
||||||
execHardware_doAllDma(EDMAMode_HStart);
|
execHardware_doAllDma(EDMAMode_HStart);
|
||||||
|
|
||||||
|
if(nds.VCount<192)
|
||||||
|
{
|
||||||
//this is hacky.
|
//this is hacky.
|
||||||
//there is a corresponding hack in doDMA
|
//there is a corresponding hack in doDMA
|
||||||
execHardware_doAllDma(EDMAMode_MemDisplay);
|
execHardware_doAllDma(EDMAMode_MemDisplay);
|
||||||
|
|
||||||
if(!SkipCur2DFrame)
|
|
||||||
{
|
|
||||||
GPU_ligne(&MainScreen, nds.VCount);
|
|
||||||
GPU_ligne(&SubScreen, nds.VCount);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//end of 3d vblank
|
//end of 3d vblank
|
||||||
|
|
|
@ -156,6 +156,7 @@ DWORD hKeyInputTimer;
|
||||||
|
|
||||||
extern LRESULT CALLBACK RamSearchProc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam);
|
extern LRESULT CALLBACK RamSearchProc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam);
|
||||||
void InitRamSearch();
|
void InitRamSearch();
|
||||||
|
void FilterUpdate(HWND hwnd, bool user=true);
|
||||||
|
|
||||||
|
|
||||||
CRITICAL_SECTION win_sync;
|
CRITICAL_SECTION win_sync;
|
||||||
|
@ -1620,8 +1621,7 @@ int _main()
|
||||||
CommonSettings.wifiBridgeAdapterNum = GetPrivateProfileInt("Wifi", "BridgeAdapter", 0, IniName);
|
CommonSettings.wifiBridgeAdapterNum = GetPrivateProfileInt("Wifi", "BridgeAdapter", 0, IniName);
|
||||||
|
|
||||||
video.currentfilter = GetPrivateProfileInt("Video", "Filter", video.NONE, IniName);
|
video.currentfilter = GetPrivateProfileInt("Video", "Filter", video.NONE, IniName);
|
||||||
void FilterUpdate(HWND hwnd);
|
FilterUpdate(MainWindow->getHWnd(),false);
|
||||||
FilterUpdate(MainWindow->getHWnd());
|
|
||||||
|
|
||||||
/* Read the firmware settings from the init file */
|
/* Read the firmware settings from the init file */
|
||||||
win_fw_config.fav_colour = GetPrivateProfileInt("Firmware","favColor", 10, IniName);
|
win_fw_config.fav_colour = GetPrivateProfileInt("Firmware","favColor", 10, IniName);
|
||||||
|
@ -2365,12 +2365,13 @@ void RunConfig(CONFIGSCREEN which)
|
||||||
NDS_UnPause();
|
NDS_UnPause();
|
||||||
}
|
}
|
||||||
|
|
||||||
void FilterUpdate (HWND hwnd){
|
void FilterUpdate (HWND hwnd, bool user){
|
||||||
UpdateScreenRects();
|
UpdateScreenRects();
|
||||||
UpdateWndRects(hwnd);
|
UpdateWndRects(hwnd);
|
||||||
SetScreenGap(video.screengap);
|
SetScreenGap(video.screengap);
|
||||||
SetRotate(hwnd, video.rotation);
|
SetRotate(hwnd, video.rotation);
|
||||||
ScaleScreen(windowSize);
|
if(user && windowSize==0) {}
|
||||||
|
else ScaleScreen(windowSize);
|
||||||
WritePrivateProfileInt("Video", "Filter", video.currentfilter, IniName);
|
WritePrivateProfileInt("Video", "Filter", video.currentfilter, IniName);
|
||||||
WritePrivateProfileInt("Video", "Width", video.width, IniName);
|
WritePrivateProfileInt("Video", "Width", video.width, IniName);
|
||||||
WritePrivateProfileInt("Video", "Height", video.height, IniName);
|
WritePrivateProfileInt("Video", "Height", video.height, IniName);
|
||||||
|
|
|
@ -38,6 +38,7 @@ struct mapview_struct
|
||||||
u16 map;
|
u16 map;
|
||||||
u16 lcd;
|
u16 lcd;
|
||||||
u16 bitmap[1024*1024];
|
u16 bitmap[1024*1024];
|
||||||
|
bool clear;
|
||||||
|
|
||||||
void render()
|
void render()
|
||||||
{
|
{
|
||||||
|
@ -161,11 +162,24 @@ LRESULT MapView_OnPaint(mapview_struct * win, HWND hwnd, WPARAM wParam, LPARAM l
|
||||||
sprintf(text, "%d x %d", parms->BGxPC, parms->BGxPD);
|
sprintf(text, "%d x %d", parms->BGxPC, parms->BGxPD);
|
||||||
SetWindowText(GetDlgItem(hwnd, IDC_SCROLL), text);
|
SetWindowText(GetDlgItem(hwnd, IDC_SCROLL), text);
|
||||||
|
|
||||||
for(int i = 0; i < (1024*1024); i++)
|
for(int i = 0; i < ARRAY_SIZE(win->bitmap); i++)
|
||||||
win->bitmap[i] = 0x7C1F;
|
win->bitmap[i] = 0x7C1F;
|
||||||
|
|
||||||
win->render();
|
win->render();
|
||||||
|
|
||||||
|
if(win->clear)
|
||||||
|
{
|
||||||
|
RECT r;
|
||||||
|
r.left = 200;
|
||||||
|
r.top = 4;
|
||||||
|
r.right = 200 + 1024;
|
||||||
|
r.bottom = 200 + 1024;
|
||||||
|
HBRUSH brush = CreateSolidBrush(GetSysColor(COLOR_3DFACE));
|
||||||
|
FillRect(hdc, &r, brush);
|
||||||
|
DeleteObject(brush);
|
||||||
|
win->clear = false;
|
||||||
|
}
|
||||||
|
|
||||||
SetDIBitsToDevice(hdc, 200, 4, lg, ht, 0, 0, 0, ht, win->bitmap, (BITMAPINFO*)&bmi, DIB_RGB_COLORS);
|
SetDIBitsToDevice(hdc, 200, 4, lg, ht, 0, 0, 0, ht, win->bitmap, (BITMAPINFO*)&bmi, DIB_RGB_COLORS);
|
||||||
|
|
||||||
EndPaint(hwnd, &ps);
|
EndPaint(hwnd, &ps);
|
||||||
|
@ -185,6 +199,7 @@ BOOL CALLBACK ViewMapsProc (HWND hwnd, UINT message, WPARAM wParam, LPARAM lPara
|
||||||
{
|
{
|
||||||
MapView = new mapview_struct;
|
MapView = new mapview_struct;
|
||||||
memset(MapView, 0, sizeof(MapView));
|
memset(MapView, 0, sizeof(MapView));
|
||||||
|
MapView->clear = true;
|
||||||
MapView->autoup_secs = 1;
|
MapView->autoup_secs = 1;
|
||||||
SendMessage(GetDlgItem(hwnd, IDC_AUTO_UPDATE_SPIN),
|
SendMessage(GetDlgItem(hwnd, IDC_AUTO_UPDATE_SPIN),
|
||||||
UDM_SETRANGE, 0, MAKELONG(99, 1));
|
UDM_SETRANGE, 0, MAKELONG(99, 1));
|
||||||
|
@ -288,6 +303,7 @@ BOOL CALLBACK ViewMapsProc (HWND hwnd, UINT message, WPARAM wParam, LPARAM lPara
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
MapView->clear = true;
|
||||||
InvalidateRect(hwnd, NULL, FALSE);
|
InvalidateRect(hwnd, NULL, FALSE);
|
||||||
return 1;
|
return 1;
|
||||||
}//switch et case
|
}//switch et case
|
||||||
|
|
Loading…
Reference in New Issue