Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Widescreen HUD Hack Patch for Echoes #108

Open
wants to merge 36 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
4d778fb
WidescreenHUD Patch
Nystrata Apr 25, 2024
f7c4210
Renamed FRME files to match names in PWE
Nystrata Apr 25, 2024
47dcc7f
Summary (Required)
Nystrata May 16, 2024
74e913e
Update dol_patches.py
Nystrata May 16, 2024
5b77a25
Update dol_patches.py
Nystrata May 16, 2024
1b5a9eb
Summary (required)
Nystrata May 18, 2024
7e8cf3e
Summary (required)
Nystrata May 18, 2024
3ba54eb
Merge branch 'main' into WidescreenHUDPatch
Nystrata Jul 27, 2024
336a29d
Seperate out apply_widescreen_hack_patch into it's own function
Nystrata Jul 27, 2024
2e60b8e
Remove prints from widescreen_hud\__init__
Nystrata Jul 27, 2024
dc07441
Clean up
Nystrata Jul 27, 2024
9a37e80
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jul 27, 2024
892cf34
Make configurable via EchoesDolPatchesData
Nystrata Jul 27, 2024
c195eeb
Merge branch 'WidescreenHUDPatch' of https://github.com/Nystrata/open…
Nystrata Jul 27, 2024
cf03ff1
Add docstrings, pass version.description instead of the entire versio…
Nystrata Jul 28, 2024
55320f8
Restore vanila instructions when widescreen hack is disabled
Nystrata Jul 31, 2024
1ae075a
Merge branch 'randovania:main' into WidescreenHUDPatch
Nystrata Jul 31, 2024
432fc18
Merge branch 'main' into WidescreenHUDPatch
Nystrata Oct 12, 2024
a5544d5
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Oct 12, 2024
9b3ad55
Merge branch 'randovania:main' into WidescreenHUDPatch
Nystrata Oct 26, 2024
f531082
Merge branch 'randovania:main' into WidescreenHUDPatch
Nystrata Oct 26, 2024
1a1af32
Update __init__.py - Fixed comment typo
Nystrata Oct 29, 2024
807463b
Move addresses to dol_versions.py
Nystrata Oct 30, 2024
ac0461b
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Oct 30, 2024
9a15c3d
Fixed variable typos
Nystrata Oct 30, 2024
27a8e76
Add comment explaining manual version detection
Nystrata Oct 31, 2024
a7be495
Comment typo fix
Nystrata Oct 31, 2024
6dfe945
Check if asset exists, instead of needing to deal with game versions
Nystrata Nov 1, 2024
eaa0d5d
Merge branch 'randovania:main' into WidescreenHUDPatch
Nystrata Nov 13, 2024
fb4896b
Merge branch 'randovania:main' into WidescreenHUDPatch
Nystrata Dec 5, 2024
20dc608
Update __init__.py
Nystrata Dec 5, 2024
0ec11ad
Rename variables to be more accurate, added comments
Nystrata Dec 6, 2024
377549c
Replace culling section with a simple float value change, updated com…
Nystrata Dec 7, 2024
579ae9f
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Dec 7, 2024
7e91bd9
Remove usage of storing to r2
Nystrata Dec 8, 2024
bda18b6
Rework culling code, rename variables for clarity
Nystrata Dec 9, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Rework culling code, rename variables for clarity
  • Loading branch information
Nystrata committed Dec 9, 2024
commit bda18b6b8fbc3ede346a2e92e29e2b87f4ab04eb
50 changes: 30 additions & 20 deletions src/open_prime_rando/dol_patching/echoes/dol_patches.py
Original file line number Diff line number Diff line change
Expand Up @@ -76,10 +76,12 @@ class StartingBeamVisorAddresses:

@dataclasses.dataclass(frozen=True)
class WidescreenRenderAddresses:
frustum_culling_value: int
frustum_function_instruction: int
frustum_function_insertion: int
custom_frustum_value_offset: int
# culling_value_address: int
culling_original_instruction_address: int
culling_custom_frustum_value_offset: int
frustum_original_instruction_address: int
frustum_insertion_instructions_address: int
frustum_custom_frustum_value_offset: int


_PREFERENCES_ORDER = (
Expand Down Expand Up @@ -516,35 +518,43 @@ def apply_widescreen_hack(widescreen_render_symbols: WidescreenRenderAddresses,
Apply widescreen render hack to render the game in 16:9
"""
# Ported from gamemasterplc's 16:9 Aspect Ratio Fix NTSC-U Gecko Code
frustum_culling_value = widescreen_render_symbols.frustum_culling_value
frustum_function_instruction = widescreen_render_symbols.frustum_function_instruction
frustum_function_insertion = widescreen_render_symbols.frustum_function_insertion
custom_frustum_value_offset = widescreen_render_symbols.custom_frustum_value_offset
culling_original_instruction_address = widescreen_render_symbols.culling_original_instruction_address
culling_custom_frustum_value_offset = widescreen_render_symbols.culling_custom_frustum_value_offset
frustum_original_instruction_address = widescreen_render_symbols.frustum_original_instruction_address
frustum_insertion_instructions_address = widescreen_render_symbols.frustum_insertion_instructions_address
frustum_custom_frustum_value_offset = widescreen_render_symbols.frustum_custom_frustum_value_offset

if enabled:
# Expand frustum culling from the original 0.5f to prevent things popping in/out at the sides of screen
dol_file.write(frustum_culling_value, struct.pack(">f", 0.75))
# Expand frustum culling to prevent things popping in/out at the sides of screen
dol_file.write_instructions(
culling_original_instruction_address,
[
lfs(f26, culling_custom_frustum_value_offset, r2) # Load 2.0f from custom offset
],
)

# Expand frustum view cone to render more horizontally by patching C_MTXFrustum
dol_file.write_instructions(
frustum_function_instruction,
frustum_original_instruction_address,
[
b(frustum_function_insertion, relative=False) # Replace with jump to frustum_function_insertion
b(
frustum_insertion_instructions_address, relative=False
) # Replace with branch to frustum_function_insertion
],
)
dol_file.write_instructions(
frustum_function_insertion,
frustum_insertion_instructions_address,
[
lfs(f19, custom_frustum_value_offset, r2), # Load 1.3333334f from custom offset
fmuls(f9, f19, 0, f9),
fdivs(f11, f10, f9, 0),
b(frustum_function_instruction + 0x4), # Return from branch
lfs(f19, frustum_custom_frustum_value_offset, r2), # Load 1.3333334f from custom offset
fmuls(f9, f19, f9),
fdivs(f11, f10, f9),
b(frustum_original_instruction_address + 0x4), # Return from branch
],
)

else:
# TODO Remove when RDV is updated to no longer cache patched DOL files
# Restore vanilla behavior when widescreen hack is disabled
dol_file.write(frustum_culling_value, struct.pack(">f", 0.5)) # Restore original frustum culling size
dol_file.write(frustum_function_instruction + 0x14, [0xED, 0x6A, 0x48, 0x24]) # Restore original instruction
dol_file.write(frustum_function_insertion, (b"\0" * 0x10)) # Remove inserted code
dol_file.write(culling_original_instruction_address, [0xFF, 0x40, 0x10, 0x90]) # Restore original instruction
dol_file.write(frustum_original_instruction_address, [0xED, 0x6A, 0x48, 0x24]) # Restore original instruction
dol_file.write(frustum_insertion_instructions_address, (b"\0" * 0x10)) # Remove inserted code
18 changes: 10 additions & 8 deletions src/open_prime_rando/dol_patching/echoes/dol_versions.py
Original file line number Diff line number Diff line change
Expand Up @@ -87,10 +87,11 @@
),
double_damage_vfx=0x80017F28,
widescreen_render=WidescreenRenderAddresses(
frustum_culling_value=0x8041E944,
frustum_function_instruction=0x8036D684,
frustum_function_insertion=0x80003748,
custom_frustum_value_offset=-0x4400,
culling_original_instruction_address=0x8030256C,
culling_custom_frustum_value_offset=-0x3490, # assume r2 = 0x804223c0
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

r2 is already tracked via the sda2_base variable, meaning you could have these two offsets be just addresses and do the math in runtime.

Also remove the suffix _address from all attributes because everything is an address.

frustum_original_instruction_address=0x8036D684,
frustum_insertion_instructions_address=0x80418E88,
frustum_custom_frustum_value_offset=-0x4400, # assume r2 = 0x804223c0
),
),
EchoesDolVersion(
Expand Down Expand Up @@ -163,10 +164,11 @@
),
double_damage_vfx=0x80017FC4,
widescreen_render=WidescreenRenderAddresses(
frustum_culling_value=0x8041FC1C,
frustum_function_instruction=0x8036DAA0,
frustum_function_insertion=0x803B1D60,
custom_frustum_value_offset=-0x4420,
culling_original_instruction_address=0x803029E0,
culling_custom_frustum_value_offset=-0x34B8, # assume r2 = 0x804236c0
frustum_original_instruction_address=0x8036DAA0,
frustum_insertion_instructions_address=0x803B1D60,
frustum_custom_frustum_value_offset=-0x4420, # assume r2 = 0x804236c0
),
),
]