Somewhat Universal Widescreen Fix is intended to enable widescreen aspect ratios (e.g. 21:9, 32:9, 48:9) in games where it is unsupported.
- Ensure you have the latest 64bit VC Redist or 32bit VC Redist installed.
- Download the latest release
- For 32bit (x86) games download SUWSF-x86.zip, for 64bit (x86_64) games download SUWSF-x64.zip.
- Extract it so that
SUWSF.asi
,SUWSF.ini
, anddsound.dll
are in the same folder as the game executable that you are trying to fix. - If
dsound.dll
would collide with a file included in the game try a different name on this list which is marked as supporting the architecture (x86 or x64) of the game you are trying to fix.
Note that it must be alongside the actual game executable, it will not work if it is only placed alongside a game's launcher.
To uninstall, delete the SUWSF.asi
, SUWSF.ini
, and dsound.dll
files that you extracted to the game executable location.
In SUWSF.ini
you can configure the following settings:
A group of settings specific to the user.
The user's screen resolution that should be used in patch calculations.
Valid options: A screen resolution (e.g. "3440x1440"), "auto" (automatically detect from primary screen, may be affected by DPI scaling)
Default: "auto"
A group of settings related to a patch. Patches can optionally have names (e.g. [Patch:AspectRatio]
or [Patch:FOV]
). Names do not matter as long as they contain the word Patch
.
As many patch groups as needed can be used.
Whether a patch should be enabled. Use this for optional patches that users can choose to enable or disable.
Valid options: "true", "false"
Default: "true"
This should be set to a pattern that matches the bytes you would like to patch.
Commonly this will be 16/9 in bytes, which can either be 39 8E E3 3F
or 3B 8E E3 3F
depending on the game.
Wildcards are supported for bytes that can vary between game versions (e.g. 39 8E ?? 3F
).
The offset from the pattern match that should be written. Use this if you need to include bytes before the thing you are trying to patch.
e.g. to get to 39
in 90 90 39 8E E3 3F
set to 2
Default: 0
The value to write to the matched bytes.
If ValueType
is float
then this can contain numbers or included variables. This can also contain an expression!
If ValueType
is byte
then this should contain an array of bytes! e.g. 90 90 90 90
Included variables:
aspectratio
- This will be replaced with the user's screen's aspect ratio.
width
- This will be replaced with the user's screen's width.
height
- This will be replaced with the user's screen's height.
Example:
Value="width/height"
What type the Value setting contains.
Valid options: "float", "double", "int", "byte"
Default: float
Which match should be targeted. Useful for cases where a pattern can have multiple matches but only one should be changed.
Valid options: number of match (starting from 1), "last", "all"
Note that last
might match different bytes than the last match in a hex editor. This is because SUWSF works from memory while a hex editor works on the file on disk.
Default: "all"
Which file should be targeted by patch. Useful for cases where the patch needs to be applied to a file other than the main game executable. (e.g. "UnityPlayer.dll")
Valid options: "auto" (detects main game executable name), any string.
Default: "auto"
If you get an error such as "Unable to load SUWSF.asi. Error:126", ensure you have the latest 64bit VC Redist or 32bit VC Redist installed depending on which version of SUWSF you are trying to use.
If this does not work for you, try renaming dsound.dll
to dinput8.dll
or any other name on this list and see if the problem remains.
version.dll
is a good alternative to try.
- @ThirteenAG for Hooking.Patterns, IniReader and UltimateASILoader
- @sergey-shandar for getboost
- @codeplea for tinyexpr