Project::OSiRiON - Git repositories
Project::OSiRiON
News . About . Screenshots . Downloads . Forum . Wiki . Tracker . Git
summaryrefslogtreecommitdiff
blob: f13c46622a35ad2cee03058fa1a12cc383874138 (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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
/*
   model/model.h
   This file is part of the Osirion project and is distributed under
   the terms of the GNU General Public License version 2
*/

#ifndef __INCLUDED_MODEL_MODEL_H__
#define __INCLUDED_MODEL_MODEL_H__

#include <string>
#include <list>
#include <map>

#include "math/mathlib.h"
#include "model/engine.h"
#include "model/light.h"

/// classes representing 3D geometry
namespace model
{

/// scaling factor when loading .map geometry
const float SCALE = 1.0f / 1024.0f;

/// a 3D model contains a list of faces
class Model
{
public:
	/// load a model from disk
	Model(std::string const & name);
	~Model();
	
	/// the name of the model
	inline std::string const & name() const
	{
		return model_name;
	}

	/// maximum values of the bounding box
	inline math::Vector3f const & maxbbox() const { return model_maxbbox; }
	
	/// minimum values of the bounding box
	inline math::Vector3f const & minbbox() const { return model_minbbox; }

	/// first vertex in the global VertexArray
	inline size_t first_vertex() const { return model_first_vertex; }

	/// number of structural vertices in this model
	inline size_t vertex_structural() const { return model_vertex_count; }

	/// number of detail vertices
	inline size_t vertex_detail() const { return model_vertex_countdetail; }

	/// first vertex in the global VertexArray
	inline size_t first_evertex() const { return model_first_evertex; }

	/// number of structural evertices in this model
	inline size_t evertex_structural() const { return model_evertex_count; }

	/// number of detail evertices in this model
	inline size_t evertex_detail() const { return model_evertex_countdetail; }

	/// total number of triangles in this model
	 size_t tris() const;

	/// number of detail triangles in this model
	size_t details() const;

	/// radius
	inline float radius() const { return model_radius; }

	/// list of Engines
	std::list<Engine *>	model_engine;

	/// add an engine to the model
	void add_engine(Engine *engine);

	/// list of Lights
	std::list<Light   *>	model_light;

	/// add a light to the model
	void add_light(Light *light);
	
	std::string		model_name;
	float			model_radius;

	math::Vector3f		model_maxbbox;
	math::Vector3f		model_minbbox;

	size_t			model_first_vertex;
	size_t			model_vertex_count;
	size_t			model_vertex_countdetail;

	size_t			model_first_evertex;
	size_t			model_evertex_count;
	size_t			model_evertex_countdetail;

	/* ---- static functions for the Model registry -------------------- */

	/// the Model registry
	static std::map<std::string, Model*> registry;

	/// get name model, returns 0 if not found
	static Model *find(std::string const & name);
	
	/// get named model from the registry and load it if necessary
	static Model *load(std::string const & name);
	
	/// clear the model registry
	static void clear();
	
	/// list the content of the model registry
	static void list();
};

}

#endif // __INCLUDED_MODEL_MODEL_H__