Skip to content
forked from Quaver/Wobble

๐ŸŽฎ A powerful MonoGame extension framework for developing cross-platform games.

License

Notifications You must be signed in to change notification settings

PulsarcGame/Wobble

ย 
ย 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

Wobble Build Status CodeFactor Trello Discord

Wobble is a powerful and bare-bones extension of the MonoGame Framework designed to make the initial boilerplate process of developing games so much simpler.

This framework allows you to follow a familiar and easy-to-learn paradigm while still giving you full control of MonoGame itself.

The original purpose of Wobble was to provide an underlying and organized framework for Quaver, a competitive-oriented and open-source rhythm game currently in development, however it can be used for just about any game.

If you can master this framework, you'll have no problem jumping in on the Quaver development which is encouraged.

Features

While this framework is still in its early stages and fairly bare-bones, you get a ton of boilerplate that can be used to help you get right into development.

The features include but are not limited to:

  • An awesome audio library
  • Game State/Screen Management
  • Fully customizable drawable and sprite management system
  • Basic, reusable, and customizable GUI (buttons, sprites, text)
  • Sprite transformations with tons of easing animations
  • Automatic GUI -> Window Scaling
  • Clean shader usage
  • Resource and asset loading
  • Discord Rich Presence
  • Input handling
  • Bindable values
  • And tons more!

Goals

We have several goals with the creation and development of this framework.

  • The primary goal is to make it easier for people to jump in on the Quaver development.
  • To move some of our base code that was originally copyleft licensed to something more permissive.
  • To make the boilerplate process of developing new games a lot faster.
  • Have a clean and easy way of building out scenes while still giving the developer full control.

Requirements

Understanding the Design Paradigm

The key of understanding how to use Wobble is understanding how it works at its core.

tl;dr - We want developers to skip the boilerplate process and just get right to developing their game screens. Everything is managed for you.

Here is a diagram that shows how it works under the hood, and where your code will be placed on top of:

Legend

Every plain rectangle is implemented by you. Every non-plain rectangle is implemented under the hood by Wobble.

  • WobbleGame - The abstract base class that new games should derive from. It contains a ton of intiailization and under-the-hood updating to keep development simple. It is a derivative of Game from the MonoGame Framework.
  • Your Game - This is your derivative of WobbleGame. You can perform any initialization updating, or drawing of the game at a global state.
  • GameBase - This is simply a static class to reference your Game and a few extra configuration properties such as DefaultSpriteBatchOptions
  • ScreenManager - Handles the initailization, updating, and drawing of game screens. It's a Stack where the the last screen added is the one on top, and is the first screen to be removed. Any class of type Screen can be used here.
  • Screen - Screen is an abstract class that contains a new game state/screen. It is its own entity to be able to update/draw a single screen.
  • ScreenView - This is the GUI for the screen. It is best to separate business logic from the actual view - just like the MVC paradigm. This is a requirement and dependency of Screen.
  • Container - This is a container for all Drawables. Each screen automatically has one, and this should be the parent of all base Drawable's in the screen (unless going for custom functionality). A Drawable's position and size depends on the container. When a container is destroyed, updated, or drawn, so are its children.
  • Sprite - Any GUI element wanting to be placed on the screen. Its parent can be the container itself, or another Sprite/Drawable.

Getting Started

Wobble is designed to work directly with the MonoGame.Framework.DesktopGL Nuget Package. It has not been tested with the others, although it should work properly.

If creating a new game, it's best to start with that, as Wobble provides all the dlls needed to get up and running.

Currently there is no NuGet package for Wobble, however this may change in the future.

Steps

These are the following steps that we find to be particularly handy when using Wobble with new projects.

1. Create a new C# .NET Core project.

3. Clone Wobble and add it as a submodule to your project.

4. Run git submodule update --init --recursive to install all of Wobble's dependencies.

5. Reference both Wobble and MonoGame.Framework.DesktopGL.Core in your project.

4. Create a class that derives from WobbleGame. In this case, we'll call it MyGame. It should look similar to this:

public class MyGame : WobbleGame
{
    /// <inheritdoc />
    /// <summary>
    /// </summary>
    protected override bool IsReadyToUpdate { get; set; }

    /// <inheritdoc />
    /// <summary>
    ///     Allows the game to perform any initialization it needs to before starting to run.
    ///     This is where it can query for any required services and load any non-graphic
    ///     related content.  Calling base.Initialize will enumerate through any components
    ///     and initialize them as well.
    /// </summary>
    protected override void Initialize()
    {
        base.Initialize();
        
        // TODO: Your initialization code goes here.
    }

    /// <inheritdoc />
    /// <summary>
    ///     LoadContent will be called once per game and is the place to load
    ///     all of your content.
    /// </summary>
    protected override void LoadContent()
    {
        base.LoadContent();

        // TODO: Your asset loading code goes here.

        // Tell the game that it should start updating now
        IsReadyToUpdate = true;

        // TODO: Change to the first screen via ScreenManager
        // ScreenManager.ChangeScreen(new MainMenuScreen()); - Example
    }

    /// <inheritdoc />
    /// <summary>
    ///     UnloadContent will be called once per game and is the place to unload
    ///     game-specific content.
    /// </summary>
    protected override void UnloadContent()
    {
        base.UnloadContent();

        // TODO: Your disposing logic goes here.
    }

    /// <inheritdoc />
    /// <summary>
    ///     Allows the game to run logic such as updating the world,
    ///     checking for collisions, gathering input, and playing audio.
    /// </summary>
    protected override void Update(GameTime gameTime)
    {
        if (!IsReadyToUpdate)
            return;

        base.Update(gameTime);

        // TODO: Your global update logic goes here. Anything updated here will be updated on every screen.
    }

    /// <inheritdoc />
    /// <summary>
    ///     This is called when the game should draw itself.
    /// </summary>
    protected override void Draw(GameTime gameTime)
    {
        if (!IsReadyToUpdate)
            return;

        base.Draw(gameTime);

        // TODO: Your global draw logic goes here. Anything drawn here will be drawn on top of every screen.
    }
}

5. The main method (usually in Program.cs) of your application should look very straight forward.

internal static class Program
{
    [STAThread]
    internal static void Main(string[] args)
    {
        using (var game = new MyGame())
        {
            game.Run();
        }
    }
}

6. Start building screens!

7. Profit?

Creating Screens

As stated in our goals, the core focus of Wobble is to skip all of the initial boilerplate and set up code you'd usually do with MonoGame/XNA and go straight to developing your screens.

There are five major components to take notice of when developing screens:

  • ScreenManager - An under the hood static class that controls the addition, changing, removal, updating, and drawing of screens.

  • Screen - A portion of your game used to update and render a single state or scene of your game. You might want to have a main menu screen, and options screen, and a gameplay screen for example.

  • ScreenView - Each screen has one of these. It's where all of your GUI code should be placed. The initializing, updating, and drawing of sprites should live here. Think about it like the view in the MVC architecture. No business logic, just display.

  • Container - Every ScreenView has a container. In short, it serves a parent to the majority of the sprites on the screen.

    Each child depends on their parent for their positioning and size. As an example, if you were to align a container at the mid left of the screen, and a child sprite at the top right, the position of the sprite would be at the top right of the container, at the mid left of the screen.

  • Sprite/SpriteText - It's pretty self explanatory, but these are the sprites that are actually drawn to the screen. A sprite must have a parent of another Drawable (Container, another Sprite/SpriteText)

As long as you understand that hierarchy, you should have no problem creating screens.

Demos

There a a bunch of demos and tests that you can use to learn how Wobble works.

You should first check out the example GreenBox game. A simple game that draws a green box to the screen and moves it around with our awesome transformation system.

There are also tons of visual tests you can run and take a look at to see how each part of Wobble can be used.

Contributing

We love and encourage people to contribute to Quaver - whether it be through code, designs, or ideas. Our mission is to provide a space where the rhythm game community's voice is able to be heard, which we feel has been neglected in the past. We aim to create the ultimate mania rhythm game, and this isn't possible without community input.

The best place to begin contributing to Quaver is through our Discord server, where all of our developers, community, and testers are located.

Any contributions can be made through opening a pull request. When contributing however, please keep in mind that there should only be one branch/pull request per feature. This means if your branch is titled my-new-feature, you shouldn't have any unrelated commits, and the same system is applied to pull requests.

If you are wanting to develop a feature with the goal of having it being in the Steam release, open up an issue first, so we can discuss if it is in the scope of what we are trying to accomplish. If it is accepted, it'll be added to our official Trello board.

When contributing, please remember to follow our code style, so the codebase is consistent across the board. If you have any issues with our approaches to structuring/styling our code, feel free to bring this up.

Special Thanks

The creation of this framework couldn't have been possible without the following people/organizations.

People

  • Staravia - For building out the base of the Drawable & Sprite system.
  • Swan - For putting the majority of this framework together.
  • Vortex- - For developing the included shaders.
  • Lachee - For their C# Discord Rich Presence Library

Orgs

License

Wobble is released and licensed under The MIT License (MIT).

Please Note: BASS, the audio library dependency of this framework, is free to use for non-commercial purposes. If you plan on using this framework for a commercial game, be sure to purchase a license.

About

๐ŸŽฎ A powerful MonoGame extension framework for developing cross-platform games.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C# 99.3%
  • HLSL 0.7%