Project::OSiRiON - Git repositories
Project::OSiRiON
News . About . Screenshots . Downloads . Forum . Wiki . Tracker . Git
summaryrefslogtreecommitdiff
path: root/src/model
diff options
context:
space:
mode:
Diffstat (limited to 'src/model')
-rw-r--r--src/model/fragment.h14
-rw-r--r--src/model/map.cc54
-rw-r--r--src/model/map.h10
-rw-r--r--src/model/model.h3
4 files changed, 63 insertions, 18 deletions
diff --git a/src/model/fragment.h b/src/model/fragment.h
index fcdeca3..204a3c9 100644
--- a/src/model/fragment.h
+++ b/src/model/fragment.h
@@ -86,11 +86,16 @@ public:
inline const Type type() const { return group_type; }
+ inline const size_t size() const { return group_fragments.size(); }
+
+ inline const float angle() const { return group_angle; }
+
+ inline const float speed() const { return group_speed; }
+
inline iterator begin() { return group_fragments.begin(); }
inline iterator end() { return group_fragments.end(); }
- inline size_t size() const { return group_fragments.size(); }
inline void push_back(Fragment *fragment) { group_fragments.push_back(fragment); }
@@ -98,7 +103,12 @@ public:
inline void set_type(const Type type) { group_type = type; }
+ inline void set_angle(const float angle) { group_angle = angle; }
+
+ inline void set_speed(const float speed) { group_speed = speed; }
+
void clear();
+
private:
/// type definition for a list of model fragments
typedef std::list<Fragment *> Fragments;
@@ -108,6 +118,8 @@ private:
math::Vector3f group_forward;
Type group_type;
+ float group_angle;
+ float group_speed;
};
}
diff --git a/src/model/map.cc b/src/model/map.cc
index 71b0dda..c073a4d 100644
--- a/src/model/map.cc
+++ b/src/model/map.cc
@@ -242,14 +242,6 @@ bool Map::getline()
return true;
}
-void Map::clear_bbox()
-{
- for (int i=0; i < 3; i++) {
- class_minbbox[i] = MAX_BOUNDS;
- class_maxbbox[i] = -MAX_BOUNDS;
- }
-}
-
void Map::make_brushface(Plane *face)
{
using math::Vector3f;
@@ -678,6 +670,17 @@ void Map::close()
mapfile_ifs.close();
}
+void Map::clear_bbox()
+{
+ for (int i=0; i < 3; i++) {
+ class_minbbox[i] = MAX_BOUNDS;
+ class_maxbbox[i] = -MAX_BOUNDS;
+ }
+
+ class_angle = 0;
+ class_speed = 0;
+}
+
void Map::load_worldspawn(Model *model)
{
if (!map_materials.size())
@@ -694,7 +697,7 @@ void Map::load_worldspawn(Model *model)
load_fragmentgroup(model, FragmentGroup::None);
}
-void Map::load_fragmentgroup(Model *model, const FragmentGroup::Type type)
+void Map::load_fragmentgroup(Model *model, const FragmentGroup::Type class_type)
{
if (!VertexArray::instance() || VertexArray::instance()->overflow())
return;
@@ -702,9 +705,18 @@ void Map::load_fragmentgroup(Model *model, const FragmentGroup::Type type)
if (!map_materials.size())
return;
+ if (class_type == FragmentGroup::Rotate) {
+ if (class_speed == 0) {
+ // default rotation speed 45 degrees per second
+ class_speed = 45.0f;
+ }
+ }
+
FragmentGroup *group = new FragmentGroup();
- group->set_type(type);
+ group->set_type(class_type);
group->set_location((class_minbbox + class_maxbbox) / 2.0f - map_center);
+ group->set_angle(class_angle);
+ group->set_speed(class_speed);
for (Materials::iterator mit = map_materials.begin(); mit != map_materials.end(); mit++) {
// split the Primitives with this material into fragments
@@ -819,7 +831,7 @@ Model * Map::load(std::string const &name)
mapfile.load_worldspawn(model);
mapfile.clear_materials();
- } else if (mapfile.classname().compare("worldspawn") == 0) {
+ } else if (mapfile.in_class("worldspawn")) {
// worldspawn attributes
if (mapfile.got_key_int("enginesound", u)) {
@@ -832,14 +844,12 @@ Model * Map::load(std::string const &name)
} else if (mapfile.got_key_color("enginecolor", model->model_enginecolor)) {
continue;
-/*
- } else if (mapfile.got_key("name")) {
- continue;
-*/
+
} else if (mapfile.got_key()) {
con_warn "Unknown key " << mapfile.classname() << ":" << mapfile.key() << std::endl;
}
+
} else if (mapfile.got_classname("func_door")) {
mapfile.clear_bbox();
@@ -847,6 +857,8 @@ Model * Map::load(std::string const &name)
mapfile.load_fragmentgroup(model, FragmentGroup::Door);
mapfile.clear_materials();
+ } else if (mapfile.in_class("func_door")) {
+
} else if (mapfile.got_classname("func_group")) {
mapfile.clear_bbox();
@@ -861,6 +873,18 @@ Model * Map::load(std::string const &name)
mapfile.load_fragmentgroup(model, FragmentGroup::Rotate);
mapfile.clear_materials();
+ } else if (mapfile.in_class("func_rotate")) {
+
+ if (mapfile.got_key_float("angle", mapfile.class_angle)) {
+ continue;
+
+ } else if (mapfile.got_key_float("speed", mapfile.class_speed)) {
+ continue;
+
+ } else if (mapfile.got_key()) {
+ con_warn "Unknown key " << mapfile.classname() << ":" << mapfile.key() << std::endl;
+ }
+
} else if (mapfile.got_classend()) {
mapfile.clear_materials();
diff --git a/src/model/map.h b/src/model/map.h
index 9b75f7a..f9b036f 100644
--- a/src/model/map.h
+++ b/src/model/map.h
@@ -64,6 +64,11 @@ private:
/// true if the last read line contained a new classname
bool got_classname() const;
+ /// true if we are inside the requested class
+ bool in_class(const char *name) {
+ return (classname_current.compare(name) == 0);
+ }
+
/// true if the last read line contained a class closing bracket
inline bool got_classend() const
{
@@ -130,7 +135,7 @@ private:
void load_worldspawn(Model *model);
/// load parsed primitives into a FragmentGroup
- void load_fragmentgroup(Model *model, const FragmentGroup::Type type);
+ void load_fragmentgroup(Model *model, const FragmentGroup::Type class_type);
/// clear the current list of per-material geometry
void clear_materials();
@@ -160,9 +165,10 @@ private:
math::Vector3f class_maxbbox;
math::Vector3f class_minbbox;
+ float class_angle;
+ float class_speed;
math::Vector3f map_center;
-
Materials map_materials;
};
diff --git a/src/model/model.h b/src/model/model.h
index bdaa74a..6e9c5d8 100644
--- a/src/model/model.h
+++ b/src/model/model.h
@@ -23,6 +23,9 @@ namespace model
const float SCALE = 1.0f / 1024.0f;
const float LIGHTSCALE = 1.0f / 100.0f;
+const float ANGLEUP = -1.0f;
+const float ANGLEDOWN = -2.0f;
+
/// a 3D model contains a list of faces
class Model
{