.. | ||
60fps.patch | ||
crash.patch | ||
crash_font.bin | ||
debug_box.patch | ||
fps.patch | ||
ique_support.patch | ||
mem_error_screen.patch | ||
README.md | ||
record_demo.patch | ||
RecordDemo.js |
Super Mario 64 Enhancements
This directory contains unofficial patches to the source code that provide various features and enhancements.
To apply a patch, run tools/apply_patch.sh [patch]
where [patch]
is the name of the
.patch file you wish to apply. This will perform all of the patch's changes
to the source code.
Likewise, to undo the changes from a patch you applied, run
tools/revert_patch.sh
with the name of the .patch file you wish to undo.
To create your own enhancement patch, switch to the master
Git
branch, make your changes to the code (but do not commit), then run tools/create_patch.sh
. Your changes will be stored in the .patch file you specify.
The following enhancements are included in this directory:
60 FPS - 60fps.patch
This patch is only supported when not targeting N64. It also currently requires a 64-bit platform. If compiled for a 32-bit platform, the game will run out of memory and crash.
This allows the game to be rendered at 60 FPS instead of 30 FPS by interpolation.
The Mario head intro is the only exception which is still rendered at 30 FPS.
Crash Screen - crash.patch
This enhancement provides a crash screen that is displayed when the code throws a hardware exception. This may be useful for diagnosing crashes in game code.
Debug Box - debug_box.patch
This allows you to draw 3D boxes for debugging purposes.
Call the debug_box
function whenever you want to draw one. debug_box
by default takes two arguments: a center and bounds vec3f. This will draw a box starting from the point (center - bounds) to (center + bounds).
Use debug_box_rot
to draw a box rotated in the xz-plane. If you want to draw a box by specifying min and max points, use debug_box_pos
instead.
FPS Counter - fps.patch
This patch provides an in-game FPS counter to measure the frame rate.
iQue Player Support - ique_support.patch
This enhancement allows the same ROM to work on both the Nintendo 64 and the iQue Player.
Memory Expansion Pak Error Screen - mem_error_screen.patch
Use this patch if your game requires over 4 MB of memory and requires the Expansion Pak. If the Expansion Pak is not present, an error message will be shown on startup.
Demo Input Recorder - record_demo.patch
This patch allows you to record gameplay demos for the attract screen. It requires the latest nightly versions of Project64, and uses the Project64 JavaScript API to dump the demo input data from RAM and write it to a file.
Place the enhancements/RecordDemo.js
file in the /Scripts/
folder in the Project64 directory.
In the Scripts window, double click on "RecordDemo" on the list on the left side.
When this is done, it should turn green which lets you know that it has started.
When your demo has been recorded, it will be dumped to the newly created /SM64_DEMOS/
folder within the Project64 directory.