9
Watch
74
Star
14
Fork
12
Issue

Hollow Knight Multiplayer

Extremelyd1
Extremelyd1
pushedAt 1 week ago

Extremelyd1/HKMP

HKMP

What is Hollow Knight Multiplayer?

As the name might suggest, Hollow Knight Multiplayer (HKMP) is a multiplayer mod for the popular 2D action-adventure game Hollow Knight. The main purpose of this mod is to allow people to host games and let others join them in their adventures. A few of the core components of this mod are heavily inspired from an existing implementation found here. However, as it seemed to be discontinued, I decided to rework it entirely and add extra features where possible.

Install

Modding installer

The latest version of the mod can be found on the Scarab, the modding installer for Hollow Knight 1.5. This installer will automatically download the modding API and install the mod via an interface.

Manual install

The mod works through the Hollow Knight Modding API (a getting started guide can be found here). After installing the API, this mod can be installed by dropping the compiled DLL into your mods folder, which can be found in your Steam installation: (Beware that these are the default locations. Your install may be on a different drive, in that case change your path accordingly.)

  • Windows: C:\Program Files (x86)\Steam\steamapps\common\Hollow Knight\hollow_knight_Data\Managed\Mods\
  • Mac: ~/Library/Application Support/Steam/steamapps/common/Hollow Knight/hollow_knight.app/, then click "open package contents" and content -> resources -> data -> managed -> mods
  • Linux: ~/.local/share/Steam/steamapps/common/Hollow Knight/hollow_knight_Data/Managed/Mods/

The latest version of the compiled DLL can be found on the releases page.

Usage

The main interface of the mod can be found in the pause menu in-game. There is an option to host a game on the entered port and an option to join a game at the entered address and entered port. Playing multiplayer with people on your LAN is straightforward, but playing over the internet requires some extra work. Namely, the port of the hosted game should be forwarded in your router to point to the device you are hosting on. Alternatively, you could use software to facilitate extending your LAN, such as Hamachi.

The interface can also be hidden by pressing a key-bind (right ALT by default). This key-bind can be changed in the config for the mod, which can be found at the following locations depending on OS:

  • Windows: %appdata%\..\LocalLow\Team Cherry\Hollow Knight\HKMP.GlobalSettings.json
  • Mac: ~/Library/Application Support/unity.Team Cherry.Hollow Knight/HKMP.GlobalSettings.json
  • Linux: ~/.config/unity3d/Team Cherry/Hollow Knight/HKMP.GlobalSettings.json

The key-binds are stored in integer form, to find which key corresponds to which integer, please consult this list.

Standalone server

It is possible to run a standalone server on Windows, Linux and Mac. The latest executable of the server can be found on the releases page. For Linux and Mac, the server can only be run with Mono installed. After installing Mono, the same executable can be run using mono HKMPServer.exe [args]. The server will read/create a settings file called gamesettings.json, which can be changed to alter the default startup settings of the server. Alternatively, settings can be changed by running commands on the command line. The following are the available commands:

  • set <setting name> [value]: Read or write a setting with the given name and given value. To get a list of available settings, please see the subsections below.
  • exit: Will gracefully exit the server and disconnect its users.
  • list: Will list the currently connected users to the terminal.

Settings

The interface of the mod also contains a client and server settings menu

Client settings

The client settings contain the following entries:

  • Team Selection: Allows the player to change their current team. This setting can only be changed when it is enabled server-side.
  • Player skin ID: Allows the player to input the ID of the skin they would like to change into. After pressing the "Apply skin" button, this will locally change the skin and transmit it to the server. This only has effect if skins are enabled on the server.
  • Display ping: Whether a ping display is enabled in the top-left side of the in-game screen. This will display the current RTT (round trip time) of the client-server connection.

Server settings

Note that this menu is entirely server-sided, only the player hosting the server will be able to alter the settings. Moreover, the settings will only update server and client-side once the "Save settings" button is pressed.
An explanation of the settings can be found below (in brackets their internal names for use in standalone server):

  • Enable PvP (IsPvpEnabled): whether player vs. player damage is enabled.
  • Enable body damage (IsBodyDamageEnabled): whether contact damage is enabled, namely when player models touch, both of them will be damaged. This only has effect if PvP is also enabled.
  • Always show map locations (AlwaysShowMapIcons): whether player's map locations are always shared on the in-game map.
  • Only broadcast map with Wayward Compass (OnlyBroadcastMapIconWithWaywardCompass): whether a player's map location is only shared when they have the Wayward Compass charm equipped. Note that if map locations are always shared, this setting has no effect.
  • Display names (DisplayNames): Whether overhead names should be displayed.
  • Enable teams (TeamsEnabled): Whether player teams are enabled. Players on the same team cannot damage each other. Teams can be selected from the client settings menu.
  • Allow skins (AllowSkins): Whether player skins are allowed. If disabled, players will not be able to use a skin locally, nor will it be transmitted to other players.

The rest of the settings contain entries for damage values of most PvP enabled spells and abilities. Inputting a value of 0 will completely disable the damage. Following is a list of the internal names for use in the standalone server: NailDamage, GrubberflyElegyDamage, VengefulSpiritDamage, ShadeSoulDamage, DesolateDiveDamage, DescendingDarkDamage, HowlingWraithDamage, AbyssShriekDamage, GreatSlashDamage, DashSlashDamage, CycloneSlashDamage, SporeShroomDamage, SporeDungShroomDamage, ThornOfAgonyDamage.

Skins

Skins can be installed by dropping a folder into the skins directory (<steam>/Hollow Knight/hollow_knight_Data/Managed/Mods/HKMP/Skins). If this directory structure is not present yet, it should be generated once you have launched the game at least once with HKMP installed. This folder can be named anything, but the files should be texture sheets that Hollow Knight also normally uses. After running the game with skins installed, each of these skin directories should have a corresponding id.txt file generated. This ID file contains a single integer representing the ID of that skin. This ID can then be used in-game to select the skin from the client settings menu. Normally, these IDs start at 1 and incrementally increase the more skins you use, but it is possible to manually edit the ID files to use other IDs.

Incompatible mods

This section contains a list of mods that are incompatible with HKMP to various degrees.

  • Exaltation: Part of the HKMP UI might become inaccessible due to the Exaltation mod overlapping it with invisible elements.

Contributing

There are a few ways you can contribute to this project, which are all outlined below. Please also read and adhere to the contributing guide.

Github issues

If you have any suggestions or bug reports, please leave them at the issues page. Make sure to label the issues correctly and provide a proper explanation. Suggestions or feature requests can be labeled with "Enhancement", bug reports with "Bug", etc.

Entity system

The entity system (or colloquially known as "enemy sync") is a system that allows entities (enemies and bosses in the game) to be synchronised across clients. This system requires an implementation per distinct (complex) entity in its current implementation. Each implementation requires a significant amount of work to finish and Hollow Knight features ~150 entities, of which at least 47 are complex (namely bosses). Therefore, contribution is welcome and encouraged in order to help finish this system. The following paragraphs outline how the entity system works and what constitutes a new entity implementation.

The way the system currently works is by sending the following data over the network: position, scale, animation (possibly with additional info), and state. The position and scale are handled automatically by the system, but the animation and state need to be implemented. The way to do this is by extending either the Entity or the HealthManagedEntity abstract classes in the Hkmp.Game.Client.Entity namespace. The HealthManagedEntity class extends the Entity with functionality to handle entities that make use of a HealthManager component internally to determine when to do. In most cases, the HealthManagedEntity will be the class to extend, but in some cases (for example for False Knight, see FalseKnight.cs) the dying sequences will be handled differently and thus not use the HealthManager component. Most if not all entities in Hollow Knight are controlled by finite state machines (FSM) implemented in C# in the library PlayMaker. States in these FSMs have actions that are executed when the state is entered. Exact details are omitted here, but can probably be found in the modding channels in the official HK discord or the newer HK modding discord. To inspect the FSMs of entities, the tool FSMViewAvalonia can be used.

Both of the extendable classes contain abstract methods that need to be implemented, namely InternalInitializeAsSceneHost, InternalInitializeAsSceneClient, InternalSwitchToSceneHost, UpdateAnimation, and UpdateState.

  • InternalInitializeAsSceneHost: This method will be called when the entity is initialized given that the local player is a scene host. This means that the entity needs to send animation and state updates and let the underlying FSM run its course.
  • InternalInitializeAsSceneClient: This method will be called when the entity is initialized given that the local player is a scene client. This means that the entity needs to be disallowed to progress its FSM on its own, but rather await animation and state updates and act accordingly. This method is called with an optional state index, which tells the client to initialize the entity at the given state.
  • InternalSwitchToSceneHost: This method will be called when the entity needs to be switch since the local player has suddenly become the scene host. This means that the entity needs to switch from not running its own FSM to proceeding to run its FSM in a proper manner.
  • UpdateAnimation: This method will be called when there is an entity animation received from the network. The entity needs to execute the proper actions to mimic the local animation.
  • UpdateState: This method will be called when there is an entity state received from the network. The entity needs to make sure it is already in that particular state, or update it so that it corresponds to that state.

The Entity class contains a lot of utility methods to make it easier to manage entities, such as removing (and storing) all transitions of FSMs, restoring all transitions of FSMs, and sending animation and state updates. Moreover, the Hkmp.Fsm namespace contains the ActionExtensions class that hosts a lot of methods to execute FSM actions a single time. These methods are useful for replicating FSM behaviour by simply getting the action from the FSM and executing it. The class also has convenience methods to execute a range of actions from an FSM given the state name and action indices. Note: this class contains methods for a bunch of FSM actions, but it definitely not exhaustive, so if you come across an action type that hasn't been implemented yet, feel free to do so.

Currently, there exist implementations for a few entities, have a look at those before starting your own implementation to make sure you are not doing more work than necessary. Apart from implementing the abstract methods, you should make sure that the entity sends animation and state updates at the proper times in the FSM (in the existing implementations, this method is usually called CreateAnimationEvents). Regarding testing, you should have two instances of the game running at the same time and extensively test entering/leaving the scene of the entity at all possible states that the FSM can have.

If you have any more questions or remarks, do not hesitate to post them in the discord server's #entity-system-development. If you want to start working on the implementation of an entity, either make a draft pull request or an issue, so we can keep track of who is doing what and do not accidentally overlap. When you finish the implementation and have tested it thoroughly, you can make a pull request.

Current progress on the entity system can be seen on the project page. If you decide to start implementing an entity you can either make a draft pull request or open an issue and you'll be added to the project. This way we can keep a clear overview of who is working on what at the moment and prevent duplicate work.

Build instructions

HKMP can also be built from scratch. This requires a few dependencies from the Hollow Knight game and the modding API. Namely, the following dependencies should be added as referenced assemblies from the modding API:

  • Assembly-CSharp.dll (modified by the modding API)
  • MMHOOK_Assembly-CSharp.dll

And the following assemblies should be added as references from the Hollow Knight game/Unity:

  • PlayMaker.dll
  • UnityEngine.AudioModule.dll
  • UnityEngine.CoreModule.dll
  • UnityEngine.dll
  • UnityEngine.ImageConversionModule.dll
  • UnityEngine.InputLegacyModule
  • UnityEngine.ParticleSystemModule.dll
  • UnityEngine.Physics2DModule.dll
  • UnityEngine.TextRenderingModule.dll
  • UnityEngine.UI.dll
  • UnityEngine.UIModule.dll

All the files above can be found in the following directory based on your operating system:

  • Windows: C:\Program Files (x86)\Steam\steamapps\common\Hollow Knight\hollow_knight_Data\Managed.
  • Mac: ~/Library/Application Support/Steam/steamapps/common/Hollow Knight/hollow_knight.app/, then click "open package contents" and content -> resources -> data -> managed
  • Linux: ~/.local/share/Steam/steamapps/common/Hollow Knight/hollow_knight_Data/Managed

After this the source code can be compiled into DLL, and you should be good to go!

Discord server

You can also join the Discord server for the mod. There you can also leave your suggestions and bug reports or generally talk about it. Moreover, the latest announcements will be posted there.

Donations

If you like this project and would like to donate, you can do so via Paypal. Please only donate if you really want to, there's no obligation in doing so.

ucloud ads