#egui #ggez #gui #gamedev

ggegui

A simple implementation of egui for ggez

9 releases

0.4.0 Feb 26, 2024
0.3.9 Feb 26, 2024
0.3.8 Nov 19, 2023
0.3.7 Jul 8, 2023
0.3.4 Feb 28, 2023

#371 in Game dev

Download history 34/week @ 2023-12-22 13/week @ 2023-12-29 6/week @ 2024-01-05 3/week @ 2024-01-12 3/week @ 2024-02-16 236/week @ 2024-02-23 44/week @ 2024-03-01 20/week @ 2024-03-08 30/week @ 2024-03-15 39/week @ 2024-03-29 13/week @ 2024-04-05

86 downloads per month

MIT license

29KB
366 lines

crates.io docs.rs

ggegui

An egui implementation for the ggez game framework

Ultra minimal example

use ggegui::{egui, Gui};
use ggez::{
	ContextBuilder, Context, GameResult, glam,
	event::{ self, EventHandler}, 
	graphics::{ self, DrawParam, Color }
};

fn main() {
	let (mut ctx, event_loop) = ContextBuilder::new("game_id", "author").build().unwrap();
	let state = State::new(&mut ctx);
	event::run(ctx, event_loop, state);
}

struct State {
	gui: Gui,
} 

impl State {
	pub fn new(ctx: &mut Context) -> Self {
		Self { 
			gui: Gui::new(ctx),
		}
	} 
} 

impl EventHandler for State {
	fn update(&mut self, ctx: &mut Context) -> GameResult {
		let gui_ctx = self.gui.ctx();

		egui::Window::new("Title").show(&gui_ctx, |ui| {
			ui.label("label");
			if ui.button("button").clicked() {
				println!("button clicked");
			}
		});
		self.gui.update(ctx);
		Ok(())
	}

	fn draw(&mut self, ctx: &mut Context) -> GameResult {
		let mut canvas = graphics::Canvas::from_frame(ctx, Color::BLACK);
		canvas.draw(
			&self.gui, 
			DrawParam::default().dest(glam::Vec2::ZERO),
		);
		canvas.finish(ctx)
	}
}

there are a few examples to show how to use this implementation.

Dependencies

~28–67MB
~1M SLoC