MM2Hook : Project NuHook
A cleaned up fork of mm2hook, with a larger focus on the Lua modding API and capabilities.
A simple DLL-injection module for hooking into Midtown Madness 2, allowing for further control of the game.
Also included are complimentary bug-fixes for random crashes, as well as a fix for the infamous heap overrun error.
-
Console output window
-
Lua scripting
-
Discord Rich Presence Integration:
- Dynamically updates based on the state of your game (playing a race, cruising around, in the main menu, etc.)
- Shows a thumbnail picture for default vehicles/cities
- Thumbnail text shows the full name (mods included!)
- Grab the latest version here.
- Optional: Download the latest version of Discord Rich Presence here, and grab
discord-rpc.dll
from thewin32-dynamic\bin
folder. - Place all files in your Midtown Madness 2 installation directory and enjoy!
Note for Wine users: In order to use this on Wine, you must open winecfg, go to the Libraries tab, and add an override for dinput. Set the override to either "native" or "native then builtin"
Using a recent version of the Visual Studio IDE (including Visual Studio 2022 14.39) should more or less work as expected. If you'd prefer to use something else, a simple build script is also available.
Note that this still requires installing parts of the Build Tools for Visual Studio to work:
C++/CLI support for v143 build tools
(latest should be fine)MSVC v143 - VS 2022 C++ x64/x86 build tools
(latest should be fine)C++ ATL for latest v143 build tools (x86 & x64)
C++ MFC for latest v143 build tools (x86 & x64)
Windows 10 SDK (10.0.18362.0)
Windows Universal C Runtime
C++ Build Tools core features
C++ core features
If you'd like to contribute to the project, please fork the project and submit a pull request.
All contributions are welcomed, including ones that fix something as simple as a typo.
Please use spaces instead of tabs, and try to keep your code consistent with the rest of the project.
mm2hook supports some custom parameters to enable or disable functions and patches. These are the most commonly used:
Argument | Parameters | Description |
---|---|---|
-nopause | N/A | Allows the game to keep running even when unfocused. |
-width | size_in_pixels |
Sets the window width in pixels. |
-height | size_in_pixels |
Sets the window height in pixels. |
-sw | N/A | Forces the game to run in software mode. |
-borderless | N/A | Sets the window to borderless mode. |
-novsync | N/A | Disables vertical sync. |
-nohwtnl | N/A | Disables hardware T&L. |
-windowed | N/A | Forces the game to windowed mode. |
-fullscreen | N/A | Forces the game to fullscreen mode. |
-bitdepth | bit_depth |
Sets the bit depth in bits. |
-heapsize | size_in_mb |
Sets the heap size (in megabytes). |
mm2hook supports more geometries which can be added in PKG files as new realistic features in game.
Pop-up headlights objects.
Object | Description |
---|---|
PLIGHTON | Appears when car lights are on. |
PLIGHTOFF | Appears when car lights are off. |
Spinning wheel objects appear when wheel rotation rate is high.
Object | Description |
---|---|
SWHL0 | Front left blurry wheel. |
SWHL1 | Front right blurry wheel. |
SWHL2 | Back left blurry wheel. |
SWHL3 | Back right blurry wheel. |
SWHL4 | Back back left blurry wheel. |
SWHL5 | Back back right blurry wheel. |
Note: In order to export these objects in the right order, you must use Blender PKG Add-On here, otherwise it won't work properly.