141 lines
4.0 KiB
Markdown
141 lines
4.0 KiB
Markdown
# Header only C++ tiny glTF library(loader/saver).
|
|
|
|
`TinyGLTF` is a header only C++11 glTF 2.0 https://github.com/KhronosGroup/glTF library.
|
|
|
|
## Status
|
|
|
|
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.
|
|
|
|
## Builds
|
|
|
|
[![Build Status](https://travis-ci.org/syoyo/tinygltf.svg?branch=devel)](https://travis-ci.org/syoyo/tinygltf)
|
|
|
|
[![Build status](https://ci.appveyor.com/api/projects/status/warngenu9wjjhlm8?svg=true)](https://ci.appveyor.com/project/syoyo/tinygltf)
|
|
|
|
## Features
|
|
|
|
* Written in portable C++. C++-11 with STL dependency only.
|
|
* [x] macOS + clang(LLVM)
|
|
* [x] iOS + clang
|
|
* [x] Linux + gcc/clang
|
|
* [x] Windows + MinGW
|
|
* [x] Windows + Visual Studio 2015 or later.
|
|
* Visual Studio 2013 is not supported since they have limited C++11 support and failed to compile `json.hpp`.
|
|
* [x] Android + CrystaX(NDK drop-in replacement) GCC
|
|
* [x] Web using Emscripten(LLVM)
|
|
* Moderate parsing time and memory consumption.
|
|
* glTF specification v2.0.0
|
|
* [x] ASCII glTF
|
|
* [x] Binary glTF(GLB)
|
|
* [x] PBR material description
|
|
* Buffers
|
|
* [x] Parse BASE64 encoded embedded buffer fata(DataURI).
|
|
* [x] Load `.bin` file.
|
|
* Image(Using stb_image)
|
|
* [x] Parse BASE64 encoded embedded image fata(DataURI).
|
|
* [x] Load external image file.
|
|
* [x] PNG(8bit only)
|
|
* [x] JPEG(8bit only)
|
|
* [x] BMP
|
|
* [x] GIF
|
|
|
|
## Examples
|
|
|
|
* [glview](examples/glview) : Simple glTF geometry viewer.
|
|
* [validator](examples/validator) : Simple glTF validator with JSON schema.
|
|
|
|
## TODOs
|
|
|
|
* [ ] Write C++ code generator from json schema for robust parsing.
|
|
* [x] Serialization
|
|
* [ ] Compression/decompression(Open3DGC, etc)
|
|
* [ ] Support `extensions` and `extras` property
|
|
* [ ] HDR image?
|
|
* [ ] Write tests for `animation` and `skin`
|
|
|
|
## Licenses
|
|
|
|
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 - http://nothings.org/stb_image.h
|
|
|
|
|
|
## Build and example
|
|
|
|
Copy `stb_image.h`, `json.hpp` and `tiny_gltf.h` to your project.
|
|
|
|
### Loading glTF 2.0 model
|
|
|
|
```c++
|
|
// Define these only in *one* .cc file.
|
|
#define TINYGLTF_IMPLEMENTATION
|
|
#define STB_IMAGE_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;
|
|
}
|
|
```
|
|
|
|
## Compile options
|
|
|
|
* `TINYGLTF_NOEXCEPTION` : Disable C++ exception in JSON parsing. You can use `-fno-exceptions` or by defining the symbol `JSON_NOEXCEPTION` and `TINYGLTF_NOEXCEPTION` to 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.
|
|
|
|
### Saving gltTF 2.0 model
|
|
|
|
T.B.W.
|
|
|
|
## Running tests.
|
|
|
|
### glTF parsing test
|
|
|
|
#### Setup
|
|
|
|
Python 2.6 or 2.7 required.
|
|
Git clone https://github.com/KhronosGroup/glTF-Sample-Models to your local dir.
|
|
|
|
#### Run parsing test
|
|
|
|
After building `loader_example`, edit `test_runner.py`, then,
|
|
|
|
```bash
|
|
$ python test_runner.py
|
|
```
|
|
|
|
### Unit tests
|
|
|
|
```bash
|
|
$ cd tests
|
|
$ make
|
|
$ ./tester
|
|
$ ./tester_noexcept
|
|
```
|
|
|
|
## Third party licenses
|
|
|
|
* 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.
|