A cross-platform framework for window creation, input handling, audio playback, and rendering using OpenGL 4.5+ or Direct3D11.
- A fully documented single header file for every functionality in the library.
- Cross-platform window creation.
- Gamepad, keyboard, and mouse input support.
- Fully-configurable cross-platform rendering API using OpenGL (Linux) and DirectX11 (Windows).
- A cross-platform audio abstraction layer.
- GLFW3
- GLAD
- D3D11
Run the following commands to build Nikol using CMake
mkdir build
cd build
cmake ..
# For Linux
make
# For Windows
cmake --build .
Here's a simple example of the library. The example below will open a basic window and initialze a graphics context.
#include <nikol_core.hpp>
int main() {
// Initialze the library
if(!nikol::init()) {
return -1;
}
// Openinig the window
nikol::i32 win_flags = nikol::WINDOW_FLAGS_FOCUS_ON_CREATE | nikol::WINDOW_FLAGS_GFX_HARDWARE;
nikol::Window* window = nikol::window_open("Hello, Nikol", 1366, 768, win_flags);
if(!window) {
return -1;
}
// Creating a graphics context
nikol::GfxContextDesc gfx_desc = {
.window = window,
.states = nikol::GFX_STATE_DEPTH | nikol::GFX_STATE_STENCIL,
};
nikol::GfxContext* gfx = nikol::gfx_context_init(gfx_desc);
if(!gfx) {
return -1;
}
// Main loop
while(nikol::window_is_open(window)) {
// Will stop the application when F1 is pressed
if(nikol::input_key_pressed(nikol::KEY_F1)) {
break;
}
// Clear the screen to black
nikol::gfx_context_clear(gfx, 0.0f, 0.0f, 0.0f, 1.0f, nikol::GFX_CONTEXT_FLAGS_ENABLE_VSYNC);
// Swap the internal window buffer
nikol::gfx_context_present(gfx);
// Poll the window events
nikol::window_poll_events(window);
}
// De-initialze
nikol::gfx_context_shutdown(gfx);
nikol::window_close(window);
nikol::shutdown();
}
For more practical examples using the Nikol engine, go to NikolExamples