Skip to content

Latest commit

 

History

History
45 lines (27 loc) · 2.14 KB

README.md

File metadata and controls

45 lines (27 loc) · 2.14 KB

mach-glfw OpenGL example

This is an example for how to use mach-glfw together with zigglgen to create a window and draw to it using modern OpenGL 4.1 (the last version supported on macOS).

This example works with the zigup 0.12.0-dev.3180+83e578a18/2024.3.0-mach version of the Zig compiler. See Nominated Zig versions for instructions on how to install the correct version of the compiler.

Screenshot

Getting started

Clone the repository

git clone https://github.com/hexops/mach-glfw-opengl-example

cd mach-glfw-opengl-example

Run the example

zig build run

Next steps

Understanding this example

This example draws a simple colored hexagon to the screen that rotates slowly. It shows you how to

  • create an OpenGL-enabled GLFW window,
  • initialize the OpenGL bindings,
  • compile a simple shader program,
  • define vertex data using extern struct and upload it to the GPU along with instructions for how it's laid out in memory, and finally
  • draw to the screen in a main update loop.

Understanding why zigglgen is required

Unlike many other libraries which you link your program with at compile or load time, OpenGL is implemented as a set of functions that your program must query the windowing system for at runtime. OpenGL doesn't help you with this and you are expected to handle loading all the functions you need yourself.

A non-trivial OpenGL program might use several dozen different functions, so the way most developers get around having to write all this code is by using a binding generator that automatically generates the necessary function loading code. zigglgen is one such binding generator that is written in Zig and integrated with the Zig build system.

Getting help

You can ask the Mach community on Discord for help if this example doesn't work. You might also want to consider joining the Zig Programming Language Discord's #gamedev channel.