gfx3d: make 'alternate flush mode' emulation option. this option toggles between two methods, neither of which is entirely accurate such that under one of the modes, certain games are unplayable. if a game is fixed by alternate flush mode, please report it in the bug tracker under that category for data collecting purposes. also hooked up this option in windows.
This commit is contained in:
parent
522ef7db4d
commit
133b9866b6
|
@ -357,6 +357,7 @@ extern struct TCommonSettings {
|
|||
, wifiBridgeAdapterNum(0)
|
||||
, spuInterpolationMode(SPUInterpolation_Linear)
|
||||
, spuAdpcmCache(false)
|
||||
, gfx3d_flushMode(0)
|
||||
{
|
||||
strcpy(ARM9BIOS, "biosnds9.bin");
|
||||
strcpy(ARM7BIOS, "biosnds7.bin");
|
||||
|
@ -377,6 +378,9 @@ extern struct TCommonSettings {
|
|||
|
||||
int wifiBridgeAdapterNum;
|
||||
|
||||
//this is a temporary hack until we straighten out the flushing logic and/or gxfifo
|
||||
int gfx3d_flushMode;
|
||||
|
||||
SPUInterpolationMode spuInterpolationMode;
|
||||
bool spuAdpcmCache;
|
||||
} CommonSettings;
|
||||
|
|
|
@ -39,6 +39,7 @@
|
|||
#include "mem.h"
|
||||
#include "types.h"
|
||||
#include "saves.h"
|
||||
#include "NDSSystem.h"
|
||||
#include "readwrite.h"
|
||||
#include "FIFO.h"
|
||||
|
||||
|
@ -1397,7 +1398,9 @@ void gfx3d_glFlush(u32 v)
|
|||
flushPending = TRUE;
|
||||
gfx3d.sortmode = BIT0(v);
|
||||
gfx3d.wbuffer = BIT1(v);
|
||||
|
||||
//see discussion at top of file
|
||||
if(CommonSettings.gfx3d_flushMode == 0)
|
||||
gfx3d_doFlush();
|
||||
}
|
||||
|
||||
|
@ -1516,7 +1519,8 @@ void gfx3d_VBlankSignal()
|
|||
}
|
||||
|
||||
//see discussion at top of file
|
||||
//gfx3d_doFlush();
|
||||
if(CommonSettings.gfx3d_flushMode == 1)
|
||||
gfx3d_doFlush();
|
||||
}
|
||||
|
||||
void gfx3d_VBlankEndSignal(bool skipFrame)
|
||||
|
|
|
@ -1829,6 +1829,7 @@ int WINAPI WinMain (HINSTANCE hThisInstance,
|
|||
|
||||
cur3DCore = GetPrivateProfileInt("3D", "Renderer", GPU3D_OPENGL, IniName);
|
||||
CommonSettings.HighResolutionInterpolateColor = GetPrivateProfileInt("3D", "HighResolutionInterpolateColor", 1, IniName);
|
||||
CommonSettings.gfx3d_flushMode = GetPrivateProfileInt("3D", "AlternateFlush", 0, IniName);
|
||||
NDS_3D_ChangeCore(cur3DCore);
|
||||
|
||||
#ifdef BETA_VERSION
|
||||
|
@ -3589,6 +3590,7 @@ LRESULT CALLBACK GFX3DSettingsDlgProc(HWND hw, UINT msg, WPARAM wp, LPARAM lp)
|
|||
int i;
|
||||
|
||||
CheckDlgButton(hw,IDC_INTERPOLATECOLOR,CommonSettings.HighResolutionInterpolateColor?1:0);
|
||||
CheckDlgButton(hw,IDC_ALTERNATEFLUSH,CommonSettings.gfx3d_flushMode);
|
||||
|
||||
for(i = 0; core3DList[i] != NULL; i++)
|
||||
{
|
||||
|
@ -3608,6 +3610,8 @@ LRESULT CALLBACK GFX3DSettingsDlgProc(HWND hw, UINT msg, WPARAM wp, LPARAM lp)
|
|||
NDS_3D_ChangeCore(ComboBox_GetCurSel(GetDlgItem(hw, IDC_3DCORE)));
|
||||
WritePrivateProfileInt("3D", "Renderer", cur3DCore, IniName);
|
||||
WritePrivateProfileInt("3D", "HighResolutionInterpolateColor", CommonSettings.HighResolutionInterpolateColor?1:0, IniName);
|
||||
CommonSettings.gfx3d_flushMode = (IsDlgButtonChecked(hw,IDC_ALTERNATEFLUSH) == BST_CHECKED)?1:0;
|
||||
WritePrivateProfileInt("3D", "AlternateFlush", CommonSettings.gfx3d_flushMode, IniName);
|
||||
}
|
||||
case IDCANCEL:
|
||||
{
|
||||
|
@ -3620,6 +3624,8 @@ LRESULT CALLBACK GFX3DSettingsDlgProc(HWND hw, UINT msg, WPARAM wp, LPARAM lp)
|
|||
NDS_3D_ChangeCore(GPU3D_OPENGL);
|
||||
ComboBox_SetCurSel(GetDlgItem(hw, IDC_3DCORE), GPU3D_OPENGL);
|
||||
WritePrivateProfileInt("3D", "Renderer", GPU3D_OPENGL, IniName);
|
||||
CommonSettings.gfx3d_flushMode = 0;
|
||||
WritePrivateProfileInt("3D", "AlternateFlush", CommonSettings.gfx3d_flushMode, IniName);
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
|
|
|
@ -225,6 +225,7 @@
|
|||
#define IDC_SOUNDCORECB 1000
|
||||
#define IDC_USEEXTBIOS 1000
|
||||
#define ID_BROWSE 1000
|
||||
#define IDC_ALTERNATEFLUSH 1001
|
||||
#define IDC_BGMAP_BGXCNT 1001
|
||||
#define IDC_CHECKBOX_DEBUGGERMODE 1001
|
||||
#define IDC_EDIT01 1001
|
||||
|
|
|
@ -638,19 +638,22 @@ FONT 8, "MS Sans Serif"
|
|||
|
||||
|
||||
|
||||
|
||||
LANGUAGE LANG_ENGLISH, SUBLANG_ENGLISH_US
|
||||
IDD_3DSETTINGS DIALOGEX 0, 0, 174, 120
|
||||
IDD_3DSETTINGS DIALOGEX 0, 0, 174, 136
|
||||
STYLE DS_MODALFRAME | DS_SETFONT | WS_BORDER | WS_CAPTION | WS_DLGFRAME | WS_POPUP | WS_SYSMENU
|
||||
CAPTION "3D settings"
|
||||
FONT 8, "MS Sans Serif", 0, 0, 0
|
||||
{
|
||||
DEFPUSHBUTTON "OK", IDOK, 62, 92, 50, 14, BS_DEFPUSHBUTTON
|
||||
PUSHBUTTON "Cancel", IDCANCEL, 117, 92, 50, 14, BS_PUSHBUTTON
|
||||
PUSHBUTTON "Default", IDC_DEFAULT, 7, 92, 50, 14, BS_PUSHBUTTON
|
||||
DEFPUSHBUTTON "OK", IDOK, 62, 111, 50, 14, BS_DEFPUSHBUTTON
|
||||
PUSHBUTTON "Cancel", IDCANCEL, 117, 111, 50, 14, BS_PUSHBUTTON
|
||||
PUSHBUTTON "Default", IDC_DEFAULT, 7, 111, 50, 14, BS_PUSHBUTTON
|
||||
GROUPBOX "Renderer:", IDC_STATIC, 7, 7, 160, 39
|
||||
COMBOBOX IDC_3DCORE, 15, 23, 146, 138, WS_TABSTOP | WS_VSCROLL | WS_TABSTOP | CBS_DROPDOWNLIST
|
||||
AUTOCHECKBOX "Unrealistically High-Precision Color Interpolation", IDC_INTERPOLATECOLOR, 9, 55, 165, 10, BS_AUTOCHECKBOX
|
||||
LTEXT "(Presently only effective for SoftRasterizer)", IDC_STATIC, 21, 65, 134, 8, SS_LEFT
|
||||
AUTOCHECKBOX "Alternate Flush Mode", IDC_ALTERNATEFLUSH, 9, 79, 83, 10, BS_AUTOCHECKBOX
|
||||
LTEXT "(Fixes some games with flickering graphics)", IDC_STATIC, 21, 89, 136, 8, SS_LEFT
|
||||
}
|
||||
|
||||
|
||||
|
|
Loading…
Reference in New Issue