As of 2021, the project is being succeeded by VulkanSceneGraph project, a Vulkan-based library.[3] OpenSceneGraph is in maintenance phase since 2019.
History
The OpenSceneGraph project was initiated by Don Burns in 1998. Robert Osfield joined the project during 1999, working on porting finished components for Microsoft Windows. The project went open source in September 1999 and the official project website was created. Towards the end of the year Osfield took over the project and began extensive refactoring of the existing codebase, putting emphasis on modernisation, embracing modern C++ standards and design patterns.
In April 2001, taking into account growing community of users and interest of public, Robert Osfield created OpenSceneGraph Professional Services, providing commercial support, consulting and training services. This marks full professionalization of the project.
The first official stable version of OpenSceneGraph was version 1.0, released in 2005. An extended version 2.0 followed in 2007, adding support for multi-core and multi-gpu systems, several important NodeKits and usage of unified multiplatform build system CMake. Books and user handbooks were introduced.[4]
The project has been quickly growing and becoming more popular ever since. There are more than 530 contributors signed under current stable version, and the official mailing list contains thousands of names.[5][needs update]
In 2019, the project was moved to a maintenance phase, the main development effort being routed to its successor project VulkanSceneGraph.[6]
Support for OpenGL, from 1.1 through 2.0 including the latest extensions
Tightly coupled support for OpenGL Shading Language, developed in conjunction with 3Dlabs
Support for a wide range of 2D image and 3D database formats, with loaders available for formats such as OpenFlight, TerraPage, OBJ, 3DS, JPEG, PNG and GeoTIFF
Seamless support for framebuffer objects, pbuffers and frame buffer render-to-texture effects
Multi-threaded database paging support, which can be used in conjunction with all 3D database and image loaders
Large scale, whole earth geospatial terrain paged database generation
Introspection support for core libraries allowing external applications to query, get, set and operate on all classes in the scene graph, via a generic interface
Multi-threaded and configurable support for multiple CPU/multiple GPU machines
The OpenSceneGraph project contains a threading library, OpenThreads, which is a lightweight cross-platform threadmodel. It is intended to provide a minimal and complete Object-Oriented (OO) thread interface for C++ programmers. It is loosely modeled on the Java thread API, and the POSIX Threads standards.
The architecture of OpenThreads is designed around "swappable" thread models which are defined at compile-time in a shared object library. It is of importance to note that while a factory pattern design could have been used to achieve the goal of generic interface, it would have required the programmer to allocate each of the 4 fundamental types (Thread, Mutex, Barrier, & Condition) on the heap. Due to the cost associated with heap allocation of the underlying concrete implementations of these constructs on some platforms, such allocation was deemed unacceptable at the time this library was originally written, and thus the factory pattern was not used.
Instead, a somewhat abstruse - but effective - technique was chosen to provide the necessary data/implementation hiding. This technique uses private void pointers to encapsulate object private data. The void pointers actually point at concrete data structures, but give a uniform interface to the dso.
The design goal of OpenThreads is to construct optimized implementations using platform optimized multi-processing constructs such as the sproc methods used on IRIX, and Windows threads.
osgUtil
osgUtil contains renderingbackend functionality and utilities taking care of scene graph traversal, rendering optimisation and transforming the scene into a stream of OpenGL API calls. It also provides means of basic interaction with scene, such as object picking.
osgDB
This library is tasked with loading 3D model files. It supports many 2D/3D data formats manipulators. More than 50 different formats are supported - most common are 3D data formats, such as COLLADA (.dae), LightWave (.lwo), Wavefront (.obj), OpenFlight (.flt), 3D Studio Max (.3ds), DirectX (.x) and many others. OpenSceneGraph also provides its own native ASCII .osg format. There are exporters into .osg format available for Blender, Maya and 3D Studio MAX.
This module also provides I/O device abstraction. The other file-format loader plugins are registered with osgDB.
osgGA
This is a GUI abstraction library required for different platforms.
osgViewer
osgViewer Library provides a quick and easy way of visualizing the graphics scene. It is also a platform-independent abstraction for various window system interfaces.
osgProducer
The OSG is also shipped with a osgProducer which is just a platform-independent viewer supporting multiple graphic contexts and multi-threading.[16][17]
NodeKits
Project distribution also contains a variety of so-called NodeKits. These are solutions of common problems and frequently used more advanced 3D application components and graphics algorithms. Among the most significant are
osgAnimation — Skeletal models usage, animating and morphing.
osgFX — Special effects and image postprocessing.
osgManipulator — Interactive 3D scene manipulation.
OpenSceneGraph doesn't provide any functionality for higher "gaming" logic, it is a rendering-only tool. There are several full-scale engines for computer games (or so-called serious games) creation using OSG as a base of graphics rendering, the most common framework being Delta3D.
OpenSceneGraph has received a javascript/WebGL implementation called OSG.JS that is used by many online 3D scene viewers including Sketchfab and Clara.io.
A wrapping from C++ to javascript through Emscripten OGStudio is also currently developed.
Among other products that use OSG must be mentioned: