TinyGLTF is a header only C++11 glTF 2.0 https://github.com/KhronosGroup/glTF library.
Work in process(devel branch). Very near to release, but need more tests and examples.
TinyGLTF uses Niels Lohmann's json library(https://github.com/nlohmann/json), so now it requires C++11 compiler.
If you are looking for old, C++03 version, please use devel-picojson branch.
- Written in portable C++. C++-11 with STL dependency only.
- macOS + clang(LLVM)
- iOS + clang
- Linux + gcc/clang
- Windows + MinGW
-  Windows + Visual Studio 2015 Update 3 or later.
- Visual Studio 2013 is not supported since they have limited C++11 support and failed to compile json.hpp.
 
- Visual Studio 2013 is not supported since they have limited C++11 support and failed to compile 
- Android + CrystaX(NDK drop-in replacement) GCC
- Web using Emscripten(LLVM)
 
- Moderate parsing time and memory consumption.
- glTF specification v2.0.0
- ASCII glTF
- Binary glTF(GLB)
- PBR material description
 
- Buffers
- Parse BASE64 encoded embedded buffer fata(DataURI).
-  Load .binfile.
 
- Image(Using stb_image)
- Parse BASE64 encoded embedded image fata(DataURI).
- Load external image file.
- PNG(8bit only)
- JPEG(8bit only)
- BMP
- GIF
 
- px_render Single header C++ Libraries for Thread Scheduling, Rendering, and so on... https://github.com/pplux/px
- Physical based rendering with Vulkan using glTF 2.0 models https://github.com/SaschaWillems/Vulkan-glTF-PBR
- GLTF loader plugin for OGRE 2.1. Support for PBR materials via HLMS/PBS https://github.com/Ybalrid/Ogre_glTF
- TinyGltfImporter plugin for Magnum, a lightweight and modular C++11/C++14 graphics middleware for games and data visualization.
- Your projects here! (Please send PR)
- Write C++ code generator from jSON schema for robust parsing.
- Serialization
- Compression/decompression(Open3DGC, etc)
-  Support extensionsandextrasproperty
-  HDR image?
- OpenEXR extension through TinyEXR.
 
-  Write tests for animationandskin
TinyGLTF is licensed under MIT license.
TinyGLTF uses the following third party libraries.
- json.hpp : Copyright (c) 2013-2017 Niels Lohmann. MIT license.
- base64 : Copyright (C) 2004-2008 René Nyffenegger
- stb_image.h : v2.08 - public domain image loader - Github link
- stb_image_write.h : v1.09 - public domain image writer - Github link
Copy stb_image.h, stb_image_write.h, json.hpp and tiny_gltf.h to your project.
// Define these only in *one* .cc file.
#define TINYGLTF_IMPLEMENTATION
#define STB_IMAGE_IMPLEMENTATION
#define STB_IMAGE_WRITE_IMPLEMENTATION
// #define TINYGLTF_NOEXCEPTION // optional. disable exception handling.
#include "tiny_gltf.h"
using namespace tinygltf;
Model model; 
TinyGLTF loader;
std::string err;
  
bool ret = loader.LoadASCIIFromFile(&model, &err, argv[1]);
//bool ret = loader.LoadBinaryFromFile(&model, &err, argv[1]); // for binary glTF(.glb) 
if (!err.empty()) {
  printf("Err: %s\n", err.c_str());
}
if (!ret) {
  printf("Failed to parse glTF\n");
  return -1;
}- TINYGLTF_NOEXCEPTION: Disable C++ exception in JSON parsing. You can use- -fno-exceptionsor by defining the symbol- JSON_NOEXCEPTIONand- TINYGLTF_NOEXCEPTIONto fully remove C++ exception codes when compiling TinyGLTF.
- TINYGLTF_NO_STB_IMAGE: Do not load images with stb_image. Instead use- TinyGLTF::SetImageLoader(LoadimageDataFunction LoadImageData, void *user_data)to set a callback for loading images.
- TINYGLTF_NO_STB_IMAGE_WRITE: Do not write images with stb_image_write. Instead use- TinyGLTF::SetImageWriter(WriteimageDataFunction WriteImageData, void *user_data)to set a callback for writing images.
-  Buffers.
- To file
- Embedded
- Draco compressed?
 
-  Images
- To file
- Embedded
 
- Binary(.glb)
Python 2.6 or 2.7 required. Git clone https://github.com/KhronosGroup/glTF-Sample-Models to your local dir.
After building loader_example, edit test_runner.py, then,
$ python test_runner.py$ cd tests
$ make
$ ./tester
$ ./tester_noexcept- json.hpp : Licensed under the MIT License http://opensource.org/licenses/MIT. Copyright (c) 2013-2017 Niels Lohmann http://nlohmann.me.
- stb_image : Public domain.
- catch : Copyright (c) 2012 Two Blue Cubes Ltd. All rights reserved. Distributed under the Boost Software License, Version 1.0.