]> git.tdb.fi Git - r2c2.git/blobdiff - source/libr2c2/terrain.cpp
Save terrain position and rotation
[r2c2.git] / source / libr2c2 / terrain.cpp
index 072a6e5a26b322066e2818873dd6b8b026332b25..7b8f9f5778c3d0fe84f73f5c9cac2bd04d2029b2 100644 (file)
@@ -159,6 +159,8 @@ Terrain::NodeCoordinates Terrain::get_closest_node(const Ray &ray) const
 
 void Terrain::save(list<DataFile::Statement> &st) const
 {
+       st.push_back((DataFile::Statement("position"), position.x, position.y, position.z));
+       st.push_back((DataFile::Statement("rotation"), rotation.radians()));
        st.push_back((DataFile::Statement("size"), width, height));
        for(vector<Tile>::const_iterator i=tiles.begin(); i!=tiles.end(); ++i)
        {
@@ -189,7 +191,12 @@ Terrain::Tile::Tile():
 void Terrain::Tile::set_node_elevation(unsigned i, float e)
 {
        nodes[i].elevation = e;
-       secondary_axis = ((nodes[1].elevation+nodes[2].elevation) < (nodes[0].elevation+nodes[3].elevation));
+       update_axis();
+}
+
+void Terrain::Tile::update_axis()
+{
+       secondary_axis = (abs(nodes[1].elevation-nodes[2].elevation) < abs(nodes[0].elevation-nodes[3].elevation));
 }
 
 void Terrain::Tile::save(list<DataFile::Statement> &st) const
@@ -262,6 +269,7 @@ void Terrain::Loader::tile()
        Tile &t = obj.tiles[next_tile];
        Tile::Loader ldr(obj, t);
        load_sub_with(ldr);
+       t.update_axis();
        unsigned x = next_tile%obj.width;
        unsigned y = next_tile/obj.width;
        ++next_tile;