Skip to content

Latest commit

 

History

History
36 lines (21 loc) · 2.52 KB

README.md

File metadata and controls

36 lines (21 loc) · 2.52 KB

Hooked Player Controller

Player controller with hooks for custom input actions or other events.

If you're making a mod and you want to respond to an input action you created, you need a hook in the player controller. Or you might have another reason you need a hook in the player controller. Whatever it is, if everyone supplied their own patched player controller, no mods would be compatible with each other because each mod would overwrite the original player controller with their own patched version. This project aims to be a collaboratively-developed player controller extension which contains all hooks for all mods.

Contribution rules

To keep this project backwards compatible with supported mods, this project is append only. In other words, contributors are not allowed to delete or modify any hooks that already exist.

You're probably contributing to this project to add support for your mod. Please refrain from adding logic for your mod here. Just add your dummy, call into it, and do the rest in your own project.

How to add a hook

  1. In your mod project (not this project), add a blueprint library with a function (name it whatever you like).
  2. In this project, add a dummy of that blueprint library (i.e. same path, same asset name, same function name, same function signature; function definition not required).
  3. In BP_PlayerGoatMain, call the blueprint library function you just dummied.

Congratulations, you now have a hook into the player controller!

Note: the same steps apply for blueprint actors, but dummying blueprint actors is a bit more involved. You'll need to use a blueprint actor as your hook if you want to spawn something in the world, for instance.

How to build

Prerequisites:

  • Unreal Engine 5.1
  • Python 3
  1. Run cook.bat
  2. Run deploy.bat
  3. Run the game

Notes

  • A big reason we can do this is that if an asset is referenced but not found, the game won't crash and in fact behaves like nothing happened. So say this mod currently has hooks for mods A and B, and you have this mod and mod A installed but you don't have mod B installed. If the hook (i.e. the dummy blueprint library function) for mod B gets invoked, the game will try to call into mod B's blueprint library, not be able to find mod B's blueprint library asset, and then... nothing happens. Game doesn't crash. Interestingly, the game will crash if you call a function that doesn't exist in a blueprint library that does exist. So if you're wondering why we don't put everyone's hooks in one big blueprint library, that's why.