summaryrefslogtreecommitdiff
path: root/examples/ThirdPartyLibs/Wavefront/tiny_obj_loader.h
blob: 1fb15b34a51e105365992468a60ea2c743cdf3b2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
//
// Copyright 2012-2013, Syoyo Fujita.
//
// Licensed under 2-clause BSD liecense.
//
#ifndef _TINY_OBJ_LOADER_H
#define _TINY_OBJ_LOADER_H

#include <string>
#include <vector>
#include <map>

struct CommonFileIOInterface;

namespace tinyobj
{
struct vertex_index_t
{
	int v_idx, vt_idx, vn_idx;
	vertex_index_t() : v_idx(-1), vt_idx(-1), vn_idx(-1) {}
	explicit vertex_index_t(int idx) : v_idx(idx), vt_idx(idx), vn_idx(idx) {}
	vertex_index_t(int vidx, int vtidx, int vnidx)
		: v_idx(vidx), vt_idx(vtidx), vn_idx(vnidx) {}
};

typedef std::vector<vertex_index_t> face_t;

typedef struct
{
	std::string name;

	float ambient[3];
	float diffuse[3];
	float specular[3];
	float transmittance[3];
	float emission[3];
	float shininess;
	float transparency;  // 1 == opaque; 0 == fully transparent

	std::string ambient_texname;   // map_Ka
	std::string diffuse_texname;   // map_Kd
	std::string specular_texname;  // map_Ks
	std::string normal_texname;
	std::map<std::string, std::string> unknown_parameter;
} material_t;

// Index struct to support different indices for vtx/normal/texcoord.
// -1 means not used.
typedef struct
{
	int vertex_index;
	int normal_index;
	int texcoord_index;
} index_t;

typedef struct
{
	std::vector<index_t> indices;
} mesh_t;

typedef struct
{
	std::string name;
	material_t material;
	mesh_t mesh;
} shape_t;

// Vertex attributes
struct attrib_t
{
	std::vector<float> vertices;   // 'v'(xyz)
	std::vector<float> normals;    // 'vn'
	std::vector<float> texcoords;  // 'vt'(uv)
	attrib_t() {}
};
/// Loads .obj from a file.
/// 'shapes' will be filled with parsed shape data
/// The function returns error string.
/// Returns empty string when loading .obj success.
/// 'mtl_basepath' is optional, and used for base path for .mtl file.
#ifdef USE_STREAM
std::string LoadObj(
	attrib_t& attrib,
	std::vector<shape_t>& shapes,  // [output]
	const char* filename,
	const char* mtl_basepath = NULL);
#else
std::string
LoadObj(
	attrib_t& attrib,
	std::vector<shape_t>& shapes,
	const char* filename,
	const char* mtl_basepath,
	CommonFileIOInterface* fileIO);
#endif

};  // namespace tinyobj

#endif  // _TINY_OBJ_LOADER_H