ggez logo

What is this?

Build Status Build status Docs Status license Crates.io Crates.io

WARNING: The current released version, 0.5.0-rc.X, is NOT DONE. It is basically a PRE-RELEASE. It will get fixed up pretty rapidly, and you are encouraged to use it, as the API will not change much before the final release. However, the docs are not entirely updated, and there WILL be bugs! They should get fixed rapidly, and a real release coming Real Soon. But it seemed better to get people using the thing instead of blocking it on things like updating the web site. You can track release progress here.

ggez is a Rust library to create a Good Game Easily.

More specifically, ggez is a lightweight cross-platform game framework for making 2D games with minimum friction. It aims to implement an API based on (a Rustified version of) the LÖVE game framework. This means it contains basic and portable 2D drawing, sound, resource loading and event handling, but finer details like performance characteristics may be very different (e.g. ggez does not do automatic batching).

ggez is not meant to be everything to everyone, but rather a good base upon which to build. Thus it takes a fairly batteries-included approach without needing a million additions and plugins for everything imaginable, but also does not dictate higher-level functionality such as physics engine or entity component system. Instead the goal is to allow you to use whichever libraries you want to provide these functions, or build your own libraries atop ggez.

Features

Supported platforms

For details, see docs/BuildingForEveryPlatform.md

Who's using ggez?

Check out the projects list!

Usage

ggez requires rustc >= 1.31 and is distributed on crates.io. To include it in your project, just add the dependency line to your Cargo.toml file:

text ggez = "0.5"

ggez consists of three main parts: A Context object which contains all the state required to interface with the computer's hardware, an EventHandler trait that the user implements to register callbacks for events, and various sub-modules such as graphics and audio that provide the functionality to actually get stuff done. The general pattern is to create a struct holding your game's data which implements the EventHandler trait. Create a new Context object with default objects from a ContextBuilder or Conf object, and then call event::run() with the Context and an instance of your EventHandler to run your game's main loop.

See the API docs for full documentation, or the examples directory for a number of commented examples of varying complexity. Most examples show off a single feature of ggez, while astroblasto and snake are a small but complete games.

Getting started

For a quick tutorial on ggez, see the Hello ggez guide in the docs/ directory.

Examples

See the examples/ directory in the source. Most examples show off a single feature of ggez, while astroblasto is a small but complete Asteroids-like game.

To run the examples, just check out the source and execute cargo run --example in the root directory:

text git clone https://github.com/ggez/ggez.git cd ggez cargo run --example 05_astroblasto

If this doesn't work, see the FAQ for solutions to common problems.

Basic Project Template

```rust use ggez::{Context, ContextBuilder, GameResult}; use ggez::event::{self, EventHandler};

fn main() { // Make a Context. let ctx = &mut ContextBuilder::new("my_game", "Cool Game Author") .build() .expect("aieee, could not create ggez context!");

// Create an instance of your event handler.
// Usually, you should provide it with the Context object to
// use when setting your game up.
let mut my_game = MyGame::new(ctx);

// Run!
match event::run(ctx, &mut my_game) {
    Ok(_) => println!("Exited cleanly."),
    Err(e) => println!("Error occured: {}", e)
}

}

struct MyGame { // Your state here... }

impl EventHandler for MyGame { fn update(&mut self, _ctx: &mut Context) -> GameResult<()> { // Update code here... }

fn draw(&mut self, _ctx: &mut Context) -> GameResult<()> {
    // Draw code here...
}

} ```

Implementation details

ggez is built upon winit for windowing and events, rodio for sound, and a 2D drawing engine implemented in gfx using the OpenGL backend (which currently defaults to use OpenGL 3.2). It should be entirely thread-safe outside of the basic event-handling loop, and portable to Windows, Linux and Mac.

ggez is Pure Rust(tm).

Help!

Sources of information: