Allow games to render at their framebuffer widths

This effectively disables horizontal scaling and when paired with GCVideo it should give you a pixel perfect image.
This commit is contained in:
wiidev 2023-01-01 17:00:31 +00:00
parent c3a65d572c
commit bb21617dba
33 changed files with 267 additions and 17 deletions

View file

@ -1062,6 +1062,9 @@ msgstr ""
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "" msgstr ""
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "" msgstr ""
@ -2386,6 +2389,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "" msgstr ""
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "" msgstr ""

View file

@ -1062,6 +1062,9 @@ msgstr "Billedeprojektion X-Offset"
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "Billedeprojektion Y-Offset" msgstr "Billedeprojektion Y-Offset"
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "Billeder" msgstr "Billeder"
@ -2386,6 +2389,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "Video Skala" msgstr "Video Skala"
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "Virtuel Pointer Hastighed" msgstr "Virtuel Pointer Hastighed"

View file

@ -1062,6 +1062,9 @@ msgstr "Rand projectie X-compensatie"
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "Rand projectie Y-compensatie" msgstr "Rand projectie Y-compensatie"
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "Randen" msgstr "Randen"
@ -2386,6 +2389,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "" msgstr ""
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "Virtuele Muis Snelheid" msgstr "Virtuele Muis Snelheid"

View file

@ -1062,6 +1062,9 @@ msgstr ""
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "" msgstr ""
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "" msgstr ""
@ -2386,6 +2389,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "" msgstr ""
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "" msgstr ""

View file

@ -1062,6 +1062,9 @@ msgstr ""
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "" msgstr ""
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "" msgstr ""
@ -2386,6 +2389,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "" msgstr ""
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "" msgstr ""

View file

@ -1062,6 +1062,9 @@ msgstr "Projection image pos. X"
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "Projection image pos. Y" msgstr "Projection image pos. Y"
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "images" msgstr "images"
@ -2386,6 +2389,9 @@ msgstr "Position de l'image"
msgid "Video scale" msgid "Video scale"
msgstr "Échelle de l'image" msgstr "Échelle de l'image"
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "Vitesse du pointeur virtuel" msgstr "Vitesse du pointeur virtuel"

View file

@ -1062,6 +1062,9 @@ msgstr "Frame Projektions-X-Offset"
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "Frame Projektions-Y-Offset" msgstr "Frame Projektions-Y-Offset"
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "Frames" msgstr "Frames"
@ -2386,6 +2389,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "" msgstr ""
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "Pointergeschwindigkeit" msgstr "Pointergeschwindigkeit"

View file

@ -1062,6 +1062,9 @@ msgstr "Οριζόντιο πλάτος προβολής καρέ"
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "Κάθετο ύψος προβολής καρέ" msgstr "Κάθετο ύψος προβολής καρέ"
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "Καρέ" msgstr "Καρέ"
@ -2386,6 +2389,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "" msgstr ""
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "Ταχύτητα εικονικού δείκτη" msgstr "Ταχύτητα εικονικού δείκτη"

View file

@ -1062,6 +1062,9 @@ msgstr ""
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "" msgstr ""
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "" msgstr ""
@ -2389,6 +2392,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "" msgstr ""
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "" msgstr ""

View file

@ -1062,6 +1062,9 @@ msgstr "Proiezione offset-x frame"
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "Proiezione offset-y frame" msgstr "Proiezione offset-y frame"
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "Frames" msgstr "Frames"
@ -2389,6 +2392,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "Scaling video" msgstr "Scaling video"
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "Velocità puntatore virtuale" msgstr "Velocità puntatore virtuale"

View file

@ -1062,6 +1062,9 @@ msgstr "フレーム角のXオフセット"
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "フレーム角のyオフセット" msgstr "フレーム角のyオフセット"
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "フレーム" msgstr "フレーム"
@ -2389,6 +2392,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "" msgstr ""
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "ポインタの速度" msgstr "ポインタの速度"

View file

@ -1062,6 +1062,9 @@ msgstr "프레임 영상 X-옵셋"
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "프레임 영상 Y-옵셋" msgstr "프레임 영상 Y-옵셋"
msgid "Framebuffer"
msgstr "프레임 버퍼"
msgid "Frames" msgid "Frames"
msgstr "프레임" msgstr "프레임"
@ -2389,6 +2392,9 @@ msgstr "비디오 옵셋"
msgid "Video scale" msgid "Video scale"
msgstr "비디오 스케일" msgstr "비디오 스케일"
msgid "Video Width"
msgstr "비디오 폭"
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "가상 포인터 속도" msgstr "가상 포인터 속도"

View file

@ -1062,6 +1062,9 @@ msgstr ""
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "" msgstr ""
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "" msgstr ""
@ -2386,6 +2389,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "" msgstr ""
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "" msgstr ""

View file

@ -1062,6 +1062,9 @@ msgstr ""
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "" msgstr ""
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "" msgstr ""
@ -2386,6 +2389,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "" msgstr ""
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "" msgstr ""

View file

@ -1062,6 +1062,9 @@ msgstr "Deslocamento X da Moldura"
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "Deslocamento Y da Moldura" msgstr "Deslocamento Y da Moldura"
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "" msgstr ""
@ -2386,6 +2389,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "Escala Video" msgstr "Escala Video"
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "Velocidade do Ponteiro" msgstr "Velocidade do Ponteiro"

View file

@ -1062,6 +1062,9 @@ msgstr ""
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "" msgstr ""
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "" msgstr ""
@ -2386,6 +2389,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "" msgstr ""
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "" msgstr ""

View file

@ -1062,6 +1062,9 @@ msgstr ""
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "" msgstr ""
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "" msgstr ""
@ -2386,6 +2389,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "" msgstr ""
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "" msgstr ""

View file

@ -1062,6 +1062,9 @@ msgstr "帧投影 X 轴偏移"
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "帧投影 Y 轴偏移" msgstr "帧投影 Y 轴偏移"
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "帧数" msgstr "帧数"
@ -2386,6 +2389,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "" msgstr ""
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "虚拟指针速度" msgstr "虚拟指针速度"

View file

@ -1062,6 +1062,9 @@ msgstr "Proyección del marco X-Offset"
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "Proyección del marco Y-Offset" msgstr "Proyección del marco Y-Offset"
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "Marcos" msgstr "Marcos"
@ -2386,6 +2389,9 @@ msgstr "Offset de vídeo"
msgid "Video scale" msgid "Video scale"
msgstr "Escala de vídeo" msgstr "Escala de vídeo"
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "Vel. Puntero Virtual" msgstr "Vel. Puntero Virtual"

View file

@ -1062,6 +1062,9 @@ msgstr ""
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "" msgstr ""
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "" msgstr ""
@ -2386,6 +2389,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "" msgstr ""
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "" msgstr ""

View file

@ -1062,6 +1062,9 @@ msgstr "畫框投射X軸位移"
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "畫框投射Y軸位移" msgstr "畫框投射Y軸位移"
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "畫框數" msgstr "畫框數"
@ -2386,6 +2389,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "" msgstr ""
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "虛擬指針的速度" msgstr "虛擬指針的速度"

View file

@ -1062,6 +1062,9 @@ msgstr ""
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "" msgstr ""
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "" msgstr ""
@ -2386,6 +2389,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "" msgstr ""
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "" msgstr ""

View file

@ -1062,6 +1062,9 @@ msgstr ""
msgid "Frame Projection Y-Offset" msgid "Frame Projection Y-Offset"
msgstr "" msgstr ""
msgid "Framebuffer"
msgstr ""
msgid "Frames" msgid "Frames"
msgstr "" msgstr ""
@ -2386,6 +2389,9 @@ msgstr ""
msgid "Video scale" msgid "Video scale"
msgstr "" msgstr ""
msgid "Video Width"
msgstr ""
msgid "Virtual Pointer Speed" msgid "Virtual Pointer Speed"
msgstr "" msgstr ""

View file

@ -59,7 +59,7 @@ void ClearDOLList()
} }
void gamepatches(u8 videoSelected, u8 videoPatchDol, u8 aspectForce, u8 languageChoice, u8 patchcountrystring, void gamepatches(u8 videoSelected, u8 videoPatchDol, u8 aspectForce, u8 languageChoice, u8 patchcountrystring,
u8 vipatch, u8 deflicker, u8 sneekVideoPatch, u8 hooktype, u64 returnTo, u8 privateServer, const char *serverAddr) u8 vipatch, u8 deflicker, u8 sneekVideoPatch, u8 hooktype, u8 videoWidth, u64 returnTo, u8 privateServer, const char *serverAddr)
{ {
int i; int i;
u8 vfilter_off[7] = {0, 0, 21, 22, 21, 0, 0}; u8 vfilter_off[7] = {0, 0, 21, 22, 21, 0, 0};
@ -99,6 +99,9 @@ void gamepatches(u8 videoSelected, u8 videoPatchDol, u8 aspectForce, u8 language
anti_002_fix(dst, len); anti_002_fix(dst, len);
if (videoWidth == WIDTH_FRAMEBUFFER)
patch_width(dst, len);
if (deflicker == DEFLICKER_ON_LOW) if (deflicker == DEFLICKER_ON_LOW)
{ {
patch_vfilters(dst, len, vfilter_low); patch_vfilters(dst, len, vfilter_low);
@ -169,6 +172,54 @@ void anti_002_fix(u8 *addr, u32 len)
} }
} }
void patch_width(u8 *addr, u32 len)
{
u8 SearchPattern[32] = {
0x40, 0x82, 0x00, 0x08, 0x48, 0x00, 0x00, 0x1C,
0x28, 0x09, 0x00, 0x03, 0x40, 0x82, 0x00, 0x08,
0x48, 0x00, 0x00, 0x10, 0x2C, 0x03, 0x00, 0x00,
0x40, 0x82, 0x00, 0x08, 0x54, 0xA5, 0x0C, 0x3C};
u8 *addr_start = addr;
u8 *addr_end = addr + len - sizeof(SearchPattern);
while (addr_start <= addr_end)
{
if (memcmp(addr_start, SearchPattern, sizeof(SearchPattern)) == 0)
{
if (addr_start[-0x70] == 0xA0 && addr_start[-0x6E] == 0x00 && addr_start[-0x6D] == 0x0A)
{
if (addr_start[-0x44] == 0xA0 && addr_start[-0x42] == 0x00 && addr_start[-0x41] == 0x0E)
{
u8 reg_a = (addr_start[-0x6F] >> 5);
u8 reg_b = (addr_start[-0x43] >> 5);
// Patch to the framebuffer resolution
addr_start[-0x41] = 0x04;
// Center the image
void *offset = addr_start - 0x70;
u32 old_heap_ptr = *(u32 *)0x80003110;
*(u32 *)0x80003110 = old_heap_ptr - 0x20;
u32 heap_space = old_heap_ptr - 0x20;
u32 org_address = (addr_start[-0x70] << 24) | (addr_start[-0x6F] << 16);
*(u32 *)(heap_space + 0x00) = org_address | 4;
*(u32 *)(heap_space + 0x04) = 0x200002D0 | (reg_b << 21) | (reg_a << 16);
*(u32 *)(heap_space + 0x08) = 0x38000002 | (reg_a << 21);
*(u32 *)(heap_space + 0x0C) = 0x7C000396 | (reg_a << 21) | (reg_b << 16) | (reg_a << 11);
*(u32 *)offset = 0x48000000 + ((heap_space - (u32)offset) & 0x3ffffff);
*(u32 *)(heap_space + 0x10) = 0x48000000 + ((((u32)offset + 0x04) - (heap_space + 0x10)) & 0x3ffffff);
gprintf("Patched resolution. Branched from 0x%x to 0x%x\n", offset, heap_space);
return;
}
}
}
addr_start += 4;
}
}
/** Patch GXSetCopyFilter to disable the deflicker filter **/ /** Patch GXSetCopyFilter to disable the deflicker filter **/
void deflicker_patch(u8 *addr, u32 len) void deflicker_patch(u8 *addr, u32 len)
{ {

View file

@ -10,11 +10,12 @@ extern "C" {
void RegisterDOL(u8 *dst, int len); void RegisterDOL(u8 *dst, int len);
void ClearDOLList(); void ClearDOLList();
void gamepatches(u8 videoSelected, u8 videoPatchDol, u8 aspectForce, u8 languageChoice, u8 patchcountrystring, void gamepatches(u8 videoSelected, u8 videoPatchDol, u8 aspectForce, u8 languageChoice, u8 patchcountrystring,
u8 vipatch, u8 deflicker, u8 sneekVideoPatch, u8 hooktype, u64 returnTo, u8 privateServer, const char *serverAddr); u8 vipatch, u8 deflicker, u8 sneekVideoPatch, u8 hooktype, u8 videoWidth, u64 returnTo, u8 privateServer, const char *serverAddr);
void anti_002_fix(u8 *addr, u32 len); void anti_002_fix(u8 *addr, u32 len);
void deflicker_patch(u8 *addr, u32 len); void deflicker_patch(u8 *addr, u32 len);
void patch_vfilters(u8 *addr, u32 len, u8 *vfilter); void patch_vfilters(u8 *addr, u32 len, u8 *vfilter);
void patch_vfilters_rogue(u8 *addr, u32 len, u8 *vfilter); void patch_vfilters_rogue(u8 *addr, u32 len, u8 *vfilter);
void patch_width(u8 *addr, u32 len);
void PrivateServerPatcher(void *addr, u32 len, u8 privateServer, const char *serverAddr); void PrivateServerPatcher(void *addr, u32 len, u8 privateServer, const char *serverAddr);
void PatchFix480p(); void PatchFix480p();
s8 do_new_wiimmfi(); s8 do_new_wiimmfi();

View file

@ -188,6 +188,7 @@ bool CGameSettings::Save()
fprintf(f, "videoPatchDol:%d; ", GameList[i].videoPatchDol); fprintf(f, "videoPatchDol:%d; ", GameList[i].videoPatchDol);
fprintf(f, "patchFix480p:%d; ", GameList[i].patchFix480p); fprintf(f, "patchFix480p:%d; ", GameList[i].patchFix480p);
fprintf(f, "deflicker:%d; ", GameList[i].deflicker); fprintf(f, "deflicker:%d; ", GameList[i].deflicker);
fprintf(f, "videowidth:%d; ", GameList[i].videoWidth);
fprintf(f, "aspectratio:%d; ", GameList[i].aspectratio); fprintf(f, "aspectratio:%d; ", GameList[i].aspectratio);
fprintf(f, "language:%d; ", GameList[i].language); fprintf(f, "language:%d; ", GameList[i].language);
fprintf(f, "ocarina:%d; ", GameList[i].ocarina); fprintf(f, "ocarina:%d; ", GameList[i].ocarina);
@ -276,6 +277,11 @@ bool CGameSettings::SetSetting(GameCFG & game, const char *name, const char *val
game.deflicker = atoi(value); game.deflicker = atoi(value);
return true; return true;
} }
else if(strcmp(name, "videowidth") == 0)
{
game.videoWidth = atoi(value);
return true;
}
else if(strcmp(name, "aspectratio") == 0) else if(strcmp(name, "aspectratio") == 0)
{ {
game.aspectratio = atoi(value); game.aspectratio = atoi(value);
@ -677,6 +683,7 @@ void CGameSettings::SetDefault(GameCFG &game)
game.videoPatchDol = INHERIT; game.videoPatchDol = INHERIT;
game.patchFix480p = INHERIT; game.patchFix480p = INHERIT;
game.deflicker = INHERIT; game.deflicker = INHERIT;
game.videoWidth = INHERIT;
game.aspectratio = INHERIT; game.aspectratio = INHERIT;
game.language = INHERIT; game.language = INHERIT;
game.ocarina = INHERIT; game.ocarina = INHERIT;

View file

@ -25,6 +25,7 @@ typedef struct _GameCFG
u32 alternatedolstart; u32 alternatedolstart;
short patchcountrystrings; short patchcountrystrings;
std::string alternatedolname; std::string alternatedolname;
short videoWidth;
short returnTo; short returnTo;
short sneekVideoPatch; short sneekVideoPatch;
short NandEmuMode; short NandEmuMode;
@ -92,6 +93,7 @@ typedef struct _GameCFG
this->alternatedolstart = game.alternatedolstart; this->alternatedolstart = game.alternatedolstart;
this->patchcountrystrings = game.patchcountrystrings; this->patchcountrystrings = game.patchcountrystrings;
this->alternatedolname = game.alternatedolname; this->alternatedolname = game.alternatedolname;
this->videoWidth = game.videoWidth;
this->returnTo = game.returnTo; this->returnTo = game.returnTo;
this->sneekVideoPatch = game.sneekVideoPatch; this->sneekVideoPatch = game.sneekVideoPatch;
this->NandEmuMode = game.NandEmuMode; this->NandEmuMode = game.NandEmuMode;

View file

@ -108,6 +108,7 @@ void CSettings::SetDefault()
videoPatchDol = OFF; videoPatchDol = OFF;
patchFix480p = ON; patchFix480p = ON;
deflicker = DEFLICKER_AUTO; deflicker = DEFLICKER_AUTO;
videoWidth = WIDTH_AUTO;
language = CONSOLE_DEFAULT; language = CONSOLE_DEFAULT;
ocarina = OFF; ocarina = OFF;
hddinfo = CLOCK_HR12; hddinfo = CLOCK_HR12;
@ -327,6 +328,7 @@ bool CSettings::Save()
fprintf(file, "videoPatchDol = %d\n", videoPatchDol); fprintf(file, "videoPatchDol = %d\n", videoPatchDol);
fprintf(file, "patchFix480p = %d\n", patchFix480p); fprintf(file, "patchFix480p = %d\n", patchFix480p);
fprintf(file, "deflicker = %d\n", deflicker); fprintf(file, "deflicker = %d\n", deflicker);
fprintf(file, "videowidth = %d\n", videoWidth);
fprintf(file, "language = %d\n", language); fprintf(file, "language = %d\n", language);
fprintf(file, "ocarina = %d\n", ocarina); fprintf(file, "ocarina = %d\n", ocarina);
fprintf(file, "hddinfo = %d\n", hddinfo); fprintf(file, "hddinfo = %d\n", hddinfo);
@ -584,6 +586,11 @@ bool CSettings::SetSetting(char *name, char *value)
deflicker = atoi(value); deflicker = atoi(value);
return true; return true;
} }
else if (strcmp(name, "videowidth") == 0)
{
videoWidth = atoi(value);
return true;
}
else if (strcmp(name, "language") == 0) else if (strcmp(name, "language") == 0)
{ {
language = atoi(value); language = atoi(value);

View file

@ -120,6 +120,7 @@ class CSettings
short gamesoundvolume; short gamesoundvolume;
short tooltips; short tooltips;
short parentalcontrol; short parentalcontrol;
short videoWidth;
u8 BootIOS; u8 BootIOS;
u8 LoaderIOS; u8 LoaderIOS;
u8 cios; u8 cios;

View file

@ -123,6 +123,13 @@ enum
DEFLICKER_MAX DEFLICKER_MAX
}; };
enum
{
WIDTH_AUTO,
WIDTH_FRAMEBUFFER,
WIDTH_MAX
};
enum enum
{ {
CLOCK_HR12 = 1, // use OFF for clock off CLOCK_HR12 = 1, // use OFF for clock off

View file

@ -72,6 +72,12 @@ static const char * DeflickerText[] =
trNOOP( "ON (High)" ) trNOOP( "ON (High)" )
}; };
static const char * WidthText[] =
{
trNOOP( "Auto" ),
trNOOP( "Framebuffer" )
};
static const char * AspectText[] = static const char * AspectText[] =
{ {
trNOOP( "Force 4:3" ), trNOOP( "Force 4:3" ),
@ -206,6 +212,7 @@ void GameLoadSM::SetOptionNames()
Options->SetName(Idx++, "%s", tr( "Sneek Video Patch" )); Options->SetName(Idx++, "%s", tr( "Sneek Video Patch" ));
Options->SetName(Idx++, "%s", tr( "VIDTV Patch" )); Options->SetName(Idx++, "%s", tr( "VIDTV Patch" ));
Options->SetName(Idx++, "%s", tr( "Deflicker Filter" )); Options->SetName(Idx++, "%s", tr( "Deflicker Filter" ));
Options->SetName(Idx++, "%s", tr( "Video Width" ));
Options->SetName(Idx++, "%s", tr( "Aspect Ratio" )); Options->SetName(Idx++, "%s", tr( "Aspect Ratio" ));
Options->SetName(Idx++, "%s", tr( "Patch Country Strings" )); Options->SetName(Idx++, "%s", tr( "Patch Country Strings" ));
Options->SetName(Idx++, "%s", tr( "Game Language" )); Options->SetName(Idx++, "%s", tr( "Game Language" ));
@ -288,6 +295,12 @@ void GameLoadSM::SetOptionValues()
else else
Options->SetValue(Idx++, "%s", tr(DeflickerText[GameConfig.deflicker])); Options->SetValue(Idx++, "%s", tr(DeflickerText[GameConfig.deflicker]));
//! Settings: Video Width
if(GameConfig.videoWidth == INHERIT)
Options->SetValue(Idx++, tr("Use global"));
else
Options->SetValue(Idx++, "%s", tr(WidthText[GameConfig.videoWidth]));
//! Settings: Aspect Ratio //! Settings: Aspect Ratio
if(GameConfig.aspectratio == INHERIT) if(GameConfig.aspectratio == INHERIT)
Options->SetValue(Idx++, tr("Use global")); Options->SetValue(Idx++, tr("Use global"));
@ -483,6 +496,12 @@ int GameLoadSM::GetMenuInternal()
if (++GameConfig.deflicker >= DEFLICKER_MAX) GameConfig.deflicker = INHERIT; if (++GameConfig.deflicker >= DEFLICKER_MAX) GameConfig.deflicker = INHERIT;
} }
//! Settings: Video Width
else if (ret == ++Idx)
{
if (++GameConfig.videoWidth >= WIDTH_MAX) GameConfig.videoWidth = INHERIT;
}
//! Settings: Aspect Ratio //! Settings: Aspect Ratio
else if (ret == ++Idx) else if (ret == ++Idx)
{ {

View file

@ -61,7 +61,7 @@ static const char * VideoModeText[] =
trNOOP( "Force NTSC" ), trNOOP( "Force NTSC" ),
trNOOP( "Region Patch" ), trNOOP( "Region Patch" ),
trNOOP( "Force PAL480p" ), trNOOP( "Force PAL480p" ),
trNOOP( "Force NTSC480p" ), trNOOP( "Force NTSC480p" )
}; };
static const char * VideoPatchDolText[] = static const char * VideoPatchDolText[] =
@ -69,7 +69,7 @@ static const char * VideoPatchDolText[] =
trNOOP( "OFF" ), trNOOP( "OFF" ),
trNOOP( "Region Patch" ), trNOOP( "Region Patch" ),
trNOOP( "ON" ), trNOOP( "ON" ),
trNOOP( "All" ), trNOOP( "All" )
}; };
static const char * DeflickerText[] = static const char * DeflickerText[] =
@ -82,6 +82,12 @@ static const char * DeflickerText[] =
trNOOP( "ON (High)" ) trNOOP( "ON (High)" )
}; };
static const char * WidthText[] =
{
trNOOP( "Auto" ),
trNOOP( "Framebuffer" )
};
static const char * LanguageText[] = static const char * LanguageText[] =
{ {
trNOOP( "Japanese" ), trNOOP( "Japanese" ),
@ -114,20 +120,20 @@ static const char * HooktypeText[] =
trNOOP( "GXDraw" ), trNOOP( "GXDraw" ),
trNOOP( "GXFlush" ), trNOOP( "GXFlush" ),
trNOOP( "OSSleepThread" ), trNOOP( "OSSleepThread" ),
trNOOP( "AXNextFrame" ), trNOOP( "AXNextFrame" )
}; };
static const char * ChannelLaunchText[] = static const char * ChannelLaunchText[] =
{ {
trNOOP( "Main DOL" ), trNOOP( "Main DOL" ),
trNOOP( "Boot Content" ), trNOOP( "Boot Content" )
}; };
static const char * GCMode[] = static const char * GCMode[] =
{ {
trNOOP( "MIOS (Default & Customs)" ), trNOOP( "MIOS (Default & Customs)" ),
trNOOP( "Devolution" ), trNOOP( "Devolution" ),
trNOOP( "Nintendont" ), trNOOP( "Nintendont" )
}; };
static const char * GCSourceText[][3] = static const char * GCSourceText[][3] =
@ -136,7 +142,7 @@ static const char * GCSourceText[][3] =
{ trNOOP( "SD Path" ), "", "" }, { trNOOP( "SD Path" ), "", "" },
{ trNOOP( "Auto" ), "", "" }, { trNOOP( "Auto" ), "", "" },
{ trNOOP( "Main Path" ), "/", trNOOP( "SD Path" ) }, { trNOOP( "Main Path" ), "/", trNOOP( "SD Path" ) },
{ trNOOP( "SD Path" ), "/", trNOOP( "Main Path" ) }, { trNOOP( "SD Path" ), "/", trNOOP( "Main Path" ) }
}; };
static const char * DMLVideoText[] = static const char * DMLVideoText[] =
@ -150,21 +156,21 @@ static const char * DMLVideoText[] =
"", // unused "", // unused
trNOOP( "Force PAL480p" ), trNOOP( "Force PAL480p" ),
trNOOP( "Force NTSC480p" ), trNOOP( "Force NTSC480p" ),
trNOOP( "None" ), trNOOP( "None" )
}; };
static const char * DMLNMMMode[] = static const char * DMLNMMMode[] =
{ {
trNOOP( "OFF" ), trNOOP( "OFF" ),
trNOOP( "ON" ), trNOOP( "ON" ),
trNOOP( "Debug" ), trNOOP( "Debug" )
}; };
static const char * DMLDebug[] = static const char * DMLDebug[] =
{ {
trNOOP( "OFF" ), trNOOP( "OFF" ),
trNOOP( "ON" ), trNOOP( "ON" ),
trNOOP( "Debug Wait" ), trNOOP( "Debug Wait" )
}; };
static const char * DEVOMCText[] = static const char * DEVOMCText[] =
@ -172,21 +178,21 @@ static const char * DEVOMCText[] =
trNOOP( "OFF" ), trNOOP( "OFF" ),
trNOOP( "ON" ), trNOOP( "ON" ),
trNOOP( "Individual" ), trNOOP( "Individual" ),
trNOOP( "Regional" ), trNOOP( "Regional" )
}; };
static const char * NINMCText[] = static const char * NINMCText[] =
{ {
trNOOP( "OFF" ), trNOOP( "OFF" ),
trNOOP( "Individual" ), trNOOP( "Individual" ),
trNOOP( "ON (Multi)" ), trNOOP( "ON (Multi)" )
}; };
static const char * NINCfgText[] = static const char * NINCfgText[] =
{ {
trNOOP( "Delete" ), trNOOP( "Delete" ),
trNOOP( "Create" ), trNOOP( "Create" ),
trNOOP( "No change" ), trNOOP( "No change" )
}; };
static const char * PrivServText[] = static const char * PrivServText[] =
@ -195,7 +201,7 @@ static const char * PrivServText[] =
trNOOP( "NoSSL only" ), trNOOP( "NoSSL only" ),
trNOOP( "Wiimmfi" ), trNOOP( "Wiimmfi" ),
trNOOP( "AltWFC" ), trNOOP( "AltWFC" ),
trNOOP( "Custom" ), trNOOP( "Custom" )
}; };
static const char blocked[22] = static const char blocked[22] =
@ -244,6 +250,7 @@ void LoaderSettings::SetOptionNames()
Options->SetName(Idx++, "%s", tr( "Sneek Video Patch" )); Options->SetName(Idx++, "%s", tr( "Sneek Video Patch" ));
Options->SetName(Idx++, "%s", tr( "VIDTV Patch" )); Options->SetName(Idx++, "%s", tr( "VIDTV Patch" ));
Options->SetName(Idx++, "%s", tr( "Deflicker Filter" )); Options->SetName(Idx++, "%s", tr( "Deflicker Filter" ));
Options->SetName(Idx++, "%s", tr( "Video Width" ));
Options->SetName(Idx++, "%s", tr( "Aspect Ratio" )); Options->SetName(Idx++, "%s", tr( "Aspect Ratio" ));
Options->SetName(Idx++, "%s", tr( "Game Language" )); Options->SetName(Idx++, "%s", tr( "Game Language" ));
Options->SetName(Idx++, "%s", tr( "Patch Country Strings" )); Options->SetName(Idx++, "%s", tr( "Patch Country Strings" ));
@ -340,6 +347,9 @@ void LoaderSettings::SetOptionValues()
//! Settings: Deflicker Filter //! Settings: Deflicker Filter
Options->SetValue(Idx++, "%s", tr( DeflickerText[Settings.deflicker] )); Options->SetValue(Idx++, "%s", tr( DeflickerText[Settings.deflicker] ));
//! Settings: Video Width
Options->SetValue(Idx++, "%s", tr( WidthText[Settings.videoWidth] ));
//! Settings: Aspect Ratio //! Settings: Aspect Ratio
Options->SetValue(Idx++, "%s", tr( AspectText[Settings.GameAspectRatio] )); Options->SetValue(Idx++, "%s", tr( AspectText[Settings.GameAspectRatio] ));
@ -601,6 +611,12 @@ int LoaderSettings::GetMenuInternal()
if (++Settings.deflicker >= DEFLICKER_MAX) Settings.deflicker = 0; if (++Settings.deflicker >= DEFLICKER_MAX) Settings.deflicker = 0;
} }
//! Settings: Video Width
else if (ret == ++Idx)
{
if (++Settings.videoWidth >= WIDTH_MAX) Settings.videoWidth = 0;
}
//! Settings: Aspect Ratio //! Settings: Aspect Ratio
else if (ret == ++Idx ) else if (ret == ++Idx )
{ {

View file

@ -312,6 +312,7 @@ int GameBooter::BootGame(struct discHdr *gameHdr)
u8 reloadblock = game_cfg->iosreloadblock == INHERIT ? Settings.BlockIOSReload : game_cfg->iosreloadblock; u8 reloadblock = game_cfg->iosreloadblock == INHERIT ? Settings.BlockIOSReload : game_cfg->iosreloadblock;
u8 Hooktype = game_cfg->Hooktype == INHERIT ? Settings.Hooktype : game_cfg->Hooktype; u8 Hooktype = game_cfg->Hooktype == INHERIT ? Settings.Hooktype : game_cfg->Hooktype;
u8 WiirdDebugger = game_cfg->WiirdDebugger == INHERIT ? Settings.WiirdDebugger : game_cfg->WiirdDebugger; u8 WiirdDebugger = game_cfg->WiirdDebugger == INHERIT ? Settings.WiirdDebugger : game_cfg->WiirdDebugger;
u16 videoWidth = game_cfg->videoWidth == INHERIT ? Settings.videoWidth : game_cfg->videoWidth;
u64 returnToChoice = strlen(Settings.returnTo) > 0 ? (game_cfg->returnTo ? NandTitles.FindU32(Settings.returnTo) : 0) : 0; u64 returnToChoice = strlen(Settings.returnTo) > 0 ? (game_cfg->returnTo ? NandTitles.FindU32(Settings.returnTo) : 0) : 0;
u8 NandEmuMode = OFF; u8 NandEmuMode = OFF;
const char *NandEmuPath = game_cfg->NandEmuPath.size() == 0 ? Settings.NandEmuPath : game_cfg->NandEmuPath.c_str(); const char *NandEmuPath = game_cfg->NandEmuPath.size() == 0 ? Settings.NandEmuPath : game_cfg->NandEmuPath.c_str();
@ -485,13 +486,13 @@ int GameBooter::BootGame(struct discHdr *gameHdr)
{ {
//! Either the server is not Wiimmfi, or, if it is Wiimmfi, the game isn't MKWii - patch the old way //! Either the server is not Wiimmfi, or, if it is Wiimmfi, the game isn't MKWii - patch the old way
gamepatches(videoChoice, videoPatchDolChoice, aspectChoice, languageChoice, countrystrings, viChoice, gamepatches(videoChoice, videoPatchDolChoice, aspectChoice, languageChoice, countrystrings, viChoice,
deflicker, sneekChoice, Hooktype, returnToChoice, PrivServChoice, customAddress); deflicker, sneekChoice, Hooktype, videoWidth, returnToChoice, PrivServChoice, customAddress);
} }
else else
{ {
//! Wiimmfi patch for Mario Kart Wii - patch with PRIVSERV_OFF and handle all the patching within do_new_wiimmfi() //! Wiimmfi patch for Mario Kart Wii - patch with PRIVSERV_OFF and handle all the patching within do_new_wiimmfi()
gamepatches(videoChoice, videoPatchDolChoice, aspectChoice, languageChoice, countrystrings, viChoice, gamepatches(videoChoice, videoPatchDolChoice, aspectChoice, languageChoice, countrystrings, viChoice,
deflicker, sneekChoice, Hooktype, returnToChoice, PRIVSERV_OFF, customAddress); deflicker, sneekChoice, Hooktype, videoWidth, returnToChoice, PRIVSERV_OFF, customAddress);
} }
//! Load Code handler if needed //! Load Code handler if needed