projects
/
laserbrain_demo
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
prepare_data script now accepts a filter argument to process only a
[laserbrain_demo]
/
src
/
scene.h
diff --git
a/src/scene.h
b/src/scene.h
index
a8c8e6a
..
1cf8dcc
100644
(file)
--- a/
src/scene.h
+++ b/
src/scene.h
@@
-6,17
+6,24
@@
#include "mesh.h"
#include "snode.h"
#include "texture.h"
#include "mesh.h"
#include "snode.h"
#include "texture.h"
+#include "dataset.h"
+#include "datamap.h"
enum {
SCNLOAD_FLIPYZ = 1,
enum {
SCNLOAD_FLIPYZ = 1,
- SCNLOAD_FLIPTEX = 2
+ SCNLOAD_FLIPTEX = 2,
+
+ SCNLOAD_STAGE_IO = 0x4000,
+ SCNLOAD_STAGE_GL = 0x8000
};
};
-class Scene {
-private:
- bool own_texset;
+class MetaScene;
+class Scene {
public:
public:
+ MetaScene *metascn;
+ DataMap datamap;
+
// meshes objects and nodes are owned by Scene
std::vector<Mesh*> meshes;
std::vector<Object*> objects;
// meshes objects and nodes are owned by Scene
std::vector<Mesh*> meshes;
std::vector<Object*> objects;
@@
-25,8
+32,9
@@
public:
Mesh *walk_mesh;
TextureSet *texset; // only owned by Scene if own_texset is true
Mesh *walk_mesh;
TextureSet *texset; // only owned by Scene if own_texset is true
+ void *loader_data;
- explicit Scene(TextureSet *tset = 0);
+ explicit Scene();
~Scene();
Scene(const Scene &rhs) = delete;
~Scene();
Scene(const Scene &rhs) = delete;
@@
-68,4
+76,15
@@
public:
void draw() const;
};
void draw() const;
};
+class SceneSet : public DataSet<Scene*> {
+private:
+ static Scene *create_scene();
+ static bool load_scene(Scene *scn, const char *fname);
+ static bool done_scene(Scene *scn);
+ static void free_scene(Scene *scn);
+
+public:
+ SceneSet();
+};
+
#endif // SCENE_H_
#endif // SCENE_H_