blob: 3c0ccf1552309cd1e9d4b9b07edb476e068b3a57 (
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
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
|
/*
model/material.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_MATERIAL_H__
#define __INCLUDED_MODEL_MATERIAL_H__
#include <string>
#include <map>
#include "math/color.h"
#include "math/vector2f.h"
namespace model
{
/// fragment surface material parameters
class Material
{
public:
/// function pointer type for local functions
typedef void(* LoaderFuncPtr)(Material *);
/// surface flags
enum SurfaceFlags { None = 0, Primary = 1, Secondary = 2, Tertiary = 3, Bright = 4, Engine = 8, Environment = 16, Texture = 32, Ignore = 64, Clip = 128};
/// type definition for the material registry
typedef std::map<std::string, Material *> Registry;
Material(const std::string &name);
~Material();
/* ---- inspectors ----------------------------------------- */
inline const std::string &name() const {
return material_name;
}
inline const math::Color &color() const {
return material_color;
}
inline const unsigned int flags() const {
return material_flags;
}
inline const std::string &texture() const {
return material_texture;
}
inline const size_t texture_id() const {
return material_texture_id;
}
/**
* @brief returns the material texture size
*/
inline const math::Vector2f & size() const {
return material_size;
}
/* ---- mutators ------------------------------------------- */
void set_color(const math::Color &color);
/**
* @brief set the material texture name
*/
void set_texture(const std::string &texture);
/**
* @brief set the material texture id
*/
void set_texture_id(const size_t texture_id);
/**
* @brief set the material texture size
*/
void set_size(const float width, const float height);
/**
* @brief set the material texture size
*/
void set_size(const math::Vector2f &size);
inline void set_flags(SurfaceFlags flags) {
material_flags |= flags;
}
inline void unset_flags(SurfaceFlags flags) {
material_flags &= ~flags;
}
/* ---- static ----------------------------------------------------- */
/**
* @brief initialize material registry
* reads materials from the shader files listed in shaderlist.txt
*/
static void init();
/**
* @brief shutdown material registry
*/
static void shutdown();
/**
* @brief clear material registry
*/
static void clear();
/**
* @brief print registered materials to the system console
*/
static void list();
/**
* @brief add a material to the registry
*/
static void add(Material *material);
/**
* @brief find a material in the registry
*/
static Material *find(const std::string &name);
static void set_loader_func(LoaderFuncPtr func);
private:
std::string material_name;
math::Color material_color;
unsigned int material_flags;
std::string material_texture;
size_t material_texture_id;
/// size of the material
math::Vector2f material_size;
/// the materials registry
static Registry material_registry;
static void load_shader(const std::string &shadername);
static LoaderFuncPtr material_loaderfunc;
};
}
#endif // __INCLUDED_MODEL_MATERIAL_H__
|