Skip to content
ObjectTK is an abstraction layer on top of OpenTK to provide OpenGL features in an object-oriented and type-safe manner with modern C#-style.
Branch: master
Clone or download
Latest commit d8944a5 Apr 3, 2019
Type Name Latest commit message Commit time
Failed to load latest commit information.
ObjectTK.Compiler Fix ShaderCompiler trying to instantiate abstract programs Jan 4, 2015
ObjectTK.Tools Refactor project structure Jan 4, 2015
packages Refactor project structure Jan 4, 2015
.gitattributes migrated to git Sep 29, 2014
LICENSE Create LICENSE Apr 3, 2019
ObjectTK.sln Refactor project structure Jan 4, 2015
ObjectTK.sln.DotSettings Refactor project structure Jan 4, 2015 Rename the whole project to ObjectTK Dec 19, 2014

What is ObjectTK?

ObjectTK is a thin abstraction layer on top of OpenTK to provide OpenGL features in an object-oriented and mostly type-safe manner with modern C#-style. It is fully aimed at modern OpenGL and compatible to the OpenGL4 core profile.

Currently there are types for the following OpenGL features:

  • Programs and Shaders
  • Textures
  • Vertex array objects
  • Buffer objects
  • Sampler objects
  • Query objects
  • Framebuffers
  • Renderbuffers

The main advantages of using these types are:

  • Cleaner interface than using the OpenGL API directly.
  • Type-safety when suitable.
  • Removes the necessary but error-prone boilerplate code from your project.
  • Immediate detection of leaked resources.
  • Information log via log4net.
  • The Debug-Build also includes additional sanity-checks which help tracking down common errors.

ObjectTK does not force you to use its functionality and skip the OpenGL API at all. It is perfectly fine to use the OpenGL API directly and the ObjectTK types side-by-side, because ObjectTK does not explicitly keep track of any OpenGL state which might get corrupted when you call the OpenGL API without it knowing. This is an essential feature which makes ObjectTK very usable even if it is not a "complete" wrapper around every corner of OpenGL.

What about performance?

Just like any wrapper it introduces another layer between the things you want to get done and the hardware, so it may theoretically slow things down a bit, but there are two things to consider:

  • When using modern OpenGL, which is the main target of ObjectTK, the number of API-calls is much lower than it used to be. That means that the overhead of each API-call is not that important anymore.
  • The wrapper really is very thin, more often than not there is just a single method call between you and the OpenGL API for functionality which might get used very often. For initialization-related stuff the layer may be a little thicker because it does things right, with all possible error-checking and so forth.


For examples please have a look at the Examples project and the wiki pages: Basic example

You can’t perform that action at this time.