netfox
by elementbound

A set of addons for responsive online games with the Godot engine.
Features
- ⏲️ Consistent timing across multiple machines
- 🖥️ Supports client-server architecture
- 🧈 Smooth motion with easy-to-use interpolation
- 💨 Lag compensation with Client-side Prediction and Server-side Reconciliation
- 🛜 Bullet-proof connectivity with noray integration
Overview
The package consists of multiple addons, each with different features:
- netfox
- The core package, implements timing, rollback and other multiplayer
features - Start here
- The core package, implements timing, rollback and other multiplayer
- netfox.noray
- Implements noray integration to establish connection between players
- Useful for online games
- netfox.extras
- Provides high-level, game-specific, convenience features built on top of
netfox, like base classes for input management or weapons - Check for reusable components for your game
- Provides high-level, game-specific, convenience features built on top of
- netfox.internals
- Shared utilities for the other addons
- Included as dependency, no need to install separately
C# Support
For experimental C# support, see the Netfox Sharp repo, and the corresponding
Netfox Sharp guide.
Install
Releases
Find the latest netfox under
Releases
Each release contains the addons, and a build of Forest Brawl for Windows and
Linux. Each addon has its dependencies packed with it - e.g.
"netfox.extras.vx.y.z.zip" also contains both netfox and
netfox.internals.
Note: For releases before v1.1.1, a separate ".with-deps.zip" version
contains the addon and its dependencies, while the regular zips contain only
the addon itself.
Asset Library
Search for the addon name in Godot's AssetLib or download from the site:
Source
Download the source and copy the addons of your choice to your Godot project.
Enable the addons
After adding netfox to your project, make sure to enable the addons in your
project settings. Otherwise, Godot will present you with errors about
undeclared identifiers.
Upgrading
If you're upgrading from an older version of netfox, refer to the upgrade
guide.
Usage
See the docs.
Supported versions
Godot 4.x is supported by netfox. If you find any issue using any supported
version, please open an issue.
Forest Brawl and the other examples are written against Godot 4.1. They may or
may not work when opened with any other version.
Prototyping
To try your game online with noray, a free to use instance is hosted at
tomfol.io:8890
, the same instance used by Forest Brawl.
You can use this noray instance to quickly test your games online, but is not
recommended for shipping games. The instance has configured limits, and no
uptime guarantees are made.
Examples
Comparison sample
To provide a short intro on how to get started with netfox, and how it fares
compared to built-in multiplayer tools, a simple demo was implemented as a
single-player game, which was ported to multiplayer using both a naive approach
and netfox.
Feature examples
- State machines
- Multiplayer FPS
- Rollback Debugger
- Property Configuration
- Input prediction
- NPCs with rollback
Example game
To provide examples of netfox usage in an actual game, Forest Brawl was
created and included specifically for this purpose.
It's a party game where an arbitrary amount of players compete by trying to
knock eachother off of the map.
Built with netfox
Games built with netfox, coming to a Steam near you! See the more on the site's
Made with netfox
page!
Building something cool with netfox? Whether it's released or in progress, feel
free to open a PR, adding your game to the list!
License
netfox is under the MIT license.
Note that the repository contains assets made by other people as well. For
these cases, the relevant licenses can be found in the assets' directories.
Issues
In case of any issues, comments, or questions, please feel free to open an issue!
Contribution
Contributions are welcome! Please feel free to fork the repository and open a
PR. Ideally, your PR implements a single thing, optionally refers to an
existing issue, and follows the GDScript style guide.
Please note that depending on the feature/fix you implement, the PR may need to
undergo changes, or in some cases, get rejected if it doesn't fit netfox's
intended feature set or vision.
If you feel like it, grant the netfox author(s) write permission to your fork,
so we can update the PR if needed.
If you're not sure if the PR would fit netfox or not, open an issue first,
mentioning that you'd be willing to contribute a PR.
Author(s) at the time of writing:
Funding
If you've found netfox useful, feel free to fund us on ko-fi:
Donations are always appreciated and taken as gratitude for the work that has
already been done.
If you'd like to fund a specific feature or development, please contact us in email.
Download
Support
If you need help or have questions about this plugin, please contact the author.
Contact Author