- One to one translation of raylib.h, rlgl.h, rcamera.h and raygui.h files in zig
- Build tools to compile raylib from source with simple zon dependency.
- Raylib version
5.0
- Raygui version
4.0
- Zig version
0.12.0
Sample project here using what's described below
You'll need raylib and raygui sources with the correct version:
git clone --depth 1 --branch 5.0 https://github.com/raysan5/raylib.git
git clone --depth 1 --branch 4.0 https://github.com/raysan5/raygui.git
Create a build.zig.zon
file and use this project as dependency.
.{
.name = "game",
.version = "0.0.0",
.dependencies = .{
.@"raylib-zig-bindings" = .{
.url = "https://github.com/L-Briand/raylib-zig-bindings/releases/download/0.0.1/release.tar.gz",
.hash = "1220aea55046536f9d140db95ab07ce0ff8e69927aca1e15250dc7ba7fd1017ac078",
}
},
.paths = .{
"",
},
}
Create a build.zig
file looking like this:
const std = @import("std");
// Import the project from zon file.
const rlzb = @import("raylib-zig-bindings");
pub fn build(b: *std.Build) !void {
// Default zig setup
const target = b.standardTargetOptions(.{});
const optimize = b.standardOptimizeOption(.{});
const exe = b.addExecutable(.{
.name = "game",
.root_source_file = b.path("src/main.zig"),
.target = target,
.optimize = optimize,
});
// Adding rlzb binding files for us to use in the main.zig file.
const bindings = b.dependency("raylib-zig-bindings", .{
.target = target,
.optimize = optimize,
});
exe.root_module.addImport("rlzb", bindings.module("raylib-zig-bindings"));
// Compiling raylib with main.zig
// You can select which raylib C file to add in the third parameter
var setup = try rlzb.Setup.init(b, .{ .cwd_relative = "raylib/src" }, .{});
defer setup.deinit();
// This line copy the raygui.h file into raylib/src to build with it.
try setup.addRayguiToRaylibSrc(b, .{ .cwd_relative = "raygui/src/raygui.h" });
// If you have some raylib's C #define requirements that need to be at build time. You can set them here.
setup.setRayguiOptions(b, exe, .{});
setup.setRCameraOptions(b, exe, .{});
setup.setRlglOptions(b, exe, .{});
// Build specific for platform.
switch (target.result.os.tag) {
.windows => try setup.linkWindows(exe),
.macos => try setup.linkMacos(b, exe),
.linux => try setup.linkLinux(b, exe, .{ .platform = .DESKTOP, .backend = .X11 }),
else => @panic("Unsupported os"),
}
// Add everything to the exe.
setup.finalize(b, exe);
// Default zig build run command setup
b.installArtifact(exe);
const run_cmd = b.addRunArtifact(exe);
run_cmd.step.dependOn(b.getInstallStep());
if (b.args) |args| {
run_cmd.addArgs(args);
}
const run_step = b.step("run", "Run the app");
run_step.dependOn(&run_cmd.step);
}
And create a src/main.zig
file. This is the translation
of raygui code sample.
const std = @import("std");
const rlzb = @import("rlzb");
const rl = rlzb.raylib;
const rg = rlzb.raygui;
pub fn main() !void {
rl.InitWindow(400, 200, "raygui - controls test suite");
defer rl.CloseWindow();
rl.SetTargetFPS(60);
var showMessageBox = false;
while (!rl.WindowShouldClose()) {
rl.BeginDrawing();
const style = rg.GuiGetStyle(
rg.GuiControl.DEFAULT.toValue(),
rg.GuiDefaultProperty.BACKGROUND_COLOR.toValue(),
);
rl.ClearBackground(rl.GetColor(@bitCast(style)));
if (rg.GuiButton(rl.Rectangle.init(24, 24, 120, 30), "#191#Show Message") > 0)
showMessageBox = true;
if (showMessageBox) {
const bounds = rl.Rectangle.init(85, 70, 250, 100);
const result = rg.GuiMessageBox(bounds, "#191#Message Box", "Hi! This is a message!", "Nice;Cool");
if (result >= 0) showMessageBox = false;
}
rl.EndDrawing();
}
return;
}
Then run zig build run
. You should see a window popping up.