diff options
author | Stijn Buys <ingar@osirion.org> | 2008-03-02 21:21:13 +0000 |
---|---|---|
committer | Stijn Buys <ingar@osirion.org> | 2008-03-02 21:21:13 +0000 |
commit | 6e08b92bd4f3e32fdf550f0a3e950e3101a1b06f (patch) | |
tree | 602e344c9506949f1a3f2d71875778baa23a7e36 /src/client | |
parent | a2acf0f1b4aa830929507c70483f0b1885bf4426 (diff) |
Rotated world
Diffstat (limited to 'src/client')
-rw-r--r-- | src/client/camera.cc | 23 | ||||
-rw-r--r-- | src/client/draw.cc | 38 | ||||
-rw-r--r-- | src/client/view.cc | 3 |
3 files changed, 33 insertions, 31 deletions
diff --git a/src/client/camera.cc b/src/client/camera.cc index d9aa16e..e8a6625 100644 --- a/src/client/camera.cc +++ b/src/client/camera.cc @@ -52,7 +52,7 @@ float x_offset; float z_offset; // default pitch in mode::Track -const float pitch_track = -15.0f; +const float pitch_track = 15.0f; // default rotate offset increase/decrease float rotate_offset_inc; // default translate offset increase/decrease @@ -161,22 +161,27 @@ void draw(float elapsed) pitch_current = degrees360f( pitch_current - d *elapsed); } + // map world coordinates to opengl coordinates + gl::rotate(90.0f, 0, 1.0, 0); + gl::rotate(-90.0f, 1.0f , 0, 0); + + // map camera coordinates to opengl coordinates switch (mode) { case Free: - gl::translate(1.0f+distance, -distance/2, 0.0f); - gl::rotate(-pitch_current, 0, 0, 1.0f); - gl::rotate(-yaw_current, 0, 1.0f, 0); + gl::translate(1.0f+distance, 0.0f, -distance/2); + gl::rotate(-pitch_current, 0, 1.0f, 0 ); + gl::rotate(-yaw_current, 0, 0, 1.0f); gl::translate(-1*target); break; case Track: - gl::translate(1.0f+distance, -distance , 0.0f); - gl::rotate(-pitch_current, 0, 0, 1.0f); - gl::rotate(-yaw_current, 0, 1.0f, 0); + gl::translate(1.0f+distance, 0.0f, -distance); + gl::rotate(-pitch_current, 0, 1.0f, 0); + gl::rotate(-yaw_current, 0, 0, 1.0f); gl::translate(-1*target); break; case Overview: - gl::rotate(75.0f, 0.0f, 0.0f, 1.0f); - gl::translate(0.0f, -distance, 0.0f); + gl::rotate(-75.0f, 0.0f, 1.0f, 0.0f); + gl::translate(0.0f, 0.0f, -distance); //gl::translate(x_offset, 0.0f, z_offset); gl::translate(-1*target); break; diff --git a/src/client/draw.cc b/src/client/draw.cc index 76c55b3..cdf80c2 100644 --- a/src/client/draw.cc +++ b/src/client/draw.cc @@ -45,11 +45,11 @@ void draw_entity_diamond(core::Entity *entity) gl::color(entity->color()); gl::vertex(-r,0.0f,0.0f); - gl::vertex(0.0f,0.0f,r/2); - gl::vertex(0.0f,0.0f,-r/2); + gl::vertex(0.0f,r/2,0.0f); + gl::vertex(0.0f,-r/2,0.0f); - gl::vertex(0.0f,r,0.0f); - gl::vertex(0.0f,-r, 0.0f); + gl::vertex(0.0f,0.0f,r); + gl::vertex(0.0f,0.0f,-r); gl::end(); } @@ -108,7 +108,7 @@ void draw_ship(core::EntityControlable *entity) gl::push(); gl::translate(entity->location()); gl::scale(0.2f, 0.2f, 0.2f); - gl::rotate(entity->direction(), 0.0f, 1.0f, 0.0f ); + gl::rotate(entity->direction(), 0.0f, 0.0f, 1.0f ); Vector3f tl(0.25, 0.125, 0.125); Vector3f br(-0.25, -0.125, -0.125); @@ -151,25 +151,23 @@ void draw_ship(core::EntityControlable *entity) } // shield rotation - gl::rotate(angle, 0.0f, 1.0f, 0.0f ); + gl::rotate(angle, 0.0f, 0.0f, 1.0f ); // draw the shield gl::color(Color(0.0f, 1.0f ,0.0f , 0.5f)); - gl::begin(gl::LineStrip); + gl::begin(gl::LineLoop); gl::vertex(v0); gl::vertex(v1); gl::vertex(v2); gl::vertex(v3); - gl::vertex(v0); gl::end(); - gl::begin(gl::LineStrip); + gl::begin(gl::LineLoop); gl::vertex(v4); gl::vertex(v5); gl::vertex(v6); gl::vertex(v7); - gl::vertex(v4); gl::end(); gl::pop(); @@ -183,28 +181,28 @@ void draw_spacegrid() int gridsize = 32; float s = 1.0f / gridsize; - float y = -4.0f; + float z = -4.0f; float dx = camera::target.x - floorf(camera::target.x); - float dz = camera::target.z - floorf(camera::target.z); + float dy = camera::target.y - floorf(camera::target.y); color(0,0, 1.0f); begin(Lines); for (int i=-gridsize; i <= gridsize; i++) { color(0,0, 0, 0); - vertex(i-dx, y, -gridsize-dz); + vertex(i-dx, -gridsize-dy, z); color(0,0, (gridsize-abs(i))*s, (gridsize-abs(i))*s); - vertex(i-dx, y, -dz); - vertex(i-dx, y, -dz); + vertex(i-dx, -dy, z ); + vertex(i-dx, -dy ,z ); color(0,0, 0, 0); - vertex(i-dx, y, gridsize-dz); + vertex(i-dx, gridsize-dy, z); - vertex(-gridsize-dx, y, i-dz); + vertex(-gridsize-dx, i-dy, z ); color(0,0, (gridsize-abs(i))*s, (gridsize-abs(i))*s); - vertex(-dx, y, i-dz); - vertex(-dx, y, i-dz); + vertex(-dx, i-dy, z); + vertex(-dx, i-dy, z); color(0,0, 0, 0); - vertex(gridsize-dx, y, i-dz); + vertex(gridsize-dx, i-dy, z); } end(); } diff --git a/src/client/view.cc b/src/client/view.cc index 96a0631..8ddd33c 100644 --- a/src/client/view.cc +++ b/src/client/view.cc @@ -174,8 +174,7 @@ void frame(float seconds) gl::matrixmode(GL_MODELVIEW); // map world to screen coordinates gl::loadidentity(); - gl::rotate(90.0f, 0, 1.0, 0); - + camera::draw(seconds); // draw the current camera transformation gl::enable(GL_DEPTH_TEST); // enable depth buffer writing |