项目作者: syoyo

项目描述 :
Header only C++ Tiny glTF loader.
高级语言: C
项目地址: git://github.com/syoyo/tinygltfloader.git
创建时间: 2015-12-20T11:26:43Z
项目社区:https://github.com/syoyo/tinygltfloader

开源协议:

下载


Tiny glTF loader, header only C++ glTF 1.x parsing library.

TinyGLTFLoader is a header only C++ glTF 1.x https://github.com/KhronosGroup/glTF parsing library.

TinyGLTFLoader is deprecated. Please go https://github.com/syoyo/tinygltf for glTF 2.0 parser/serializer

Build Status

Build status

Features

  • Portable C++. C++-03 with STL dependency only.
  • Moderate parsing time and memory consumption.
  • glTF specification v1.0.0
  • Buffers
    • Parse BASE64 encoded embedded buffer fata(DataURI).
    • Load .bin file.
  • Image(Using stb_image)
    • Parse BASE64 encoded embedded image fata(DataURI).
    • Load external image file.
    • PNG(8bit only)
    • JPEG(8bit only)
    • BMP
    • GIF

Examples

  • glview : Simple glTF geometry viewer.
  • writer : Simple glTF writer(serialize tinygltf::Scene class)
  • alembic_to_gltf : Simple Alembic to glTF converter.
  • cyhair_to_gltf : Simple CyHair(hair curves) to glTF converter.

TODOs

  • Write C++ code generator from json schema for robust parsing.
  • Support multiple scenes in .gltf
  • Parse skin
  • Compression/decompression(Open3DGC, etc)
  • Support extensions and extras property
  • HDR image?

License

TinyGLTFLoader is licensed under MIT license.

TinyGLTFLoader uses the following third party libraries.

  • picojson.h : Copyright 2009-2010 Cybozu Labs, Inc. Copyright 2011-2014 Kazuho Oku
  • 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, picojson.h and tiny_gltf_loader.h to your project.

  1. // Define these only in *one* .cc file.
  2. #define TINYGLTF_LOADER_IMPLEMENTATION
  3. #define STB_IMAGE_IMPLEMENTATION
  4. #include "tiny_gltf_loader.h"
  5. using namespace tinygltf;
  6. Scene scene;
  7. TinyGLTFLoader loader;
  8. std::string err;
  9. bool ret = loader.LoadASCIIFromFile(scene, err, argv[1]);
  10. //bool ret = loader.LoadBinaryFromFile(scene, err, argv[1]); // for binary glTF(.glb)
  11. if (!err.empty()) {
  12. printf("Err: %s\n", err.c_str());
  13. }
  14. if (!ret) {
  15. printf("Failed to parse glTF\n");
  16. return -1;
  17. }

Running tests.

Setup

Python 2.6 or 2.7 required.
Git clone https://github.com/KhronosGroup/glTF-Sample-Models to your local dir.

Run test

After building loader_example, edit test_runner.py, then,

  1. $ python test_runner.py