Skip to content

A cross-platform framework for window creation, input handling, and rendering using OpenGL 4.5+ or Direct3D11

Notifications You must be signed in to change notification settings

FrodoAlaska/Nikol

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

76 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Nikol

A cross-platform framework for window creation, input handling, audio playback, and rendering using OpenGL 4.5+ or Direct3D11.

Features

  • 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.

Dependencies

  • GLFW3
  • GLAD
  • D3D11

Build Instructions

Run the following commands to build Nikol using CMake

mkdir build 
cd build 
cmake .. 

# For Linux
make 

# For Windows 
cmake --build .

Hello, Nikol

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();
}

More Examples

For more practical examples using the Nikol engine, go to NikolExamples