-
Notifications
You must be signed in to change notification settings - Fork 32
Architecture
Most of Punchy is organized into Bevy plugins, each in it's own module, named after the plugin. Some modules do not contain plugins, bug instead contain useful types or helpers, such as utils.rs
and metadata.rs
.
While not all systems have been removed from main.rs
yet, most of the system scheduling and systems live in their own modules, and main.rs
is mostly responsible for the initial configuration setup and for adding plugins.
The goal is to have all of the game's content loaded dynamically based on a central index, the .game.yaml
asset. This means that we should never include a specific asset by name in code.
The asset dir and the specific .game.yaml
asset to be loaded is specified at runtime, with the defaults being assets/
and default.game.yaml
.
The .game.yaml
asset will itself reference other assets, such as level assets, which will in turn reference fighter assets. All of these interrelated assets make up the game content.
The three major modules involved in asset loading are:
-
assets.rs
- Contains the bevy asset loaders for all of our custom asset types.
-
metadata.rs
- Contains the struct definitions that make up most assets, and therefore determines the YAML structure most of the non-binary asset types.
- Contains important structs, representing the YAML asset data such as
GameMeta
,LevelMeta
, andFighterMeta
. - Many of these structs contain fields like
image
and a corresponding field with a_handle
suffix. These_handle
fields are populated by the asset loader inassets.rs
after deserialization.
-
loading.rs
- Contains the startup game and level loading code and hot reloading systems.
Some of the plugins include:
This plugin contains core primitives used to move things in the game, such as LinearVelocity
, AngularVelocity
, and Force
. These behave similar to how they would in a physics simulation, but they don't represent a real physics simulation, just a simple constraint system.
Anything that needs to limit the movement of one or more entities may be implemented as a constraint system that gets run in a chain before the velocity_system
. This is how player movement is constrained.
The damage plugin contains core components and events related to damage such as Health
, Damageable
, and DamageEvent
.
Manages the fighter state machine. See Fighter State Machine for a detailed explanation.
The lifetime plugin allows us to despawn entities after a timer by adding the LifetimeComponent
.
Handles camera following and y sorting.
Installs audio player and sound playing systems.
Responsible for game menus and in-game HUD and widgets.
Contains the sprite animation player and components.
Handles triggering and un-triggering attack collision boxes based on the AttackFrames
component.
Contains the localization loader that is used for getting game translations, and an extension trait for helping read the translated values.
This contains platform specific integration code, such as the Storage
interface which we use for saving game settings, and the system to set the web canvas size.
Initiates the load of game assets and levels. Also contains the systems that hot-reload specific asset types such as fighers.
Contains the enemy AI logic. This is currently very simple. More details are in Enemy AI.