diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/client/Makefile.am | 5 | ||||
-rw-r--r-- | src/client/camera.cc | 29 | ||||
-rw-r--r-- | src/client/camera.h | 40 | ||||
-rw-r--r-- | src/client/input.cc | 17 | ||||
-rw-r--r-- | src/client/input.h | 11 | ||||
-rw-r--r-- | src/client/main.cc | 59 | ||||
-rw-r--r-- | src/client/video.cc | 26 | ||||
-rw-r--r-- | src/client/video.h | 20 | ||||
-rw-r--r-- | src/client/view.cc | 8 | ||||
-rw-r--r-- | src/client/view.h | 12 | ||||
-rw-r--r-- | src/common/functions.h | 1 | ||||
-rw-r--r-- | src/game/game.h | 1 |
12 files changed, 94 insertions, 135 deletions
diff --git a/src/client/Makefile.am b/src/client/Makefile.am index 40bafa1..37bafcf 100644 --- a/src/client/Makefile.am +++ b/src/client/Makefile.am @@ -3,8 +3,9 @@ METASOURCES = AUTO bin_PROGRAMS = osirion osirion_LDADD = $(top_builddir)/src/game/libgame.la \ $(top_builddir)/src/gl/libosiriongl.la -lSDL -osirion_SOURCES = camera.cc camera.h input.cc input.h main.cc video.cc video.h \ - view.cc view.h shipdrawer.cc shipdrawer.h stardrawer.cc stardrawer.h +osirion_SOURCES = camera.cc camera.h client.cc client.h input.cc input.h \ + main.cc shipdrawer.cc shipdrawer.h stardrawer.cc stardrawer.h video.cc video.h \ + view.cc view.h diff --git a/src/client/camera.cc b/src/client/camera.cc index 87e00fc..6a6da0c 100644 --- a/src/client/camera.cc +++ b/src/client/camera.cc @@ -14,19 +14,26 @@ using namespace common; namespace client { - -Camera::Mode Camera::mode = Camera::Track; -const float Camera::track_pitch = -15.0f; // default tracking pitch -const float Camera::offset_inc = 5.0f; // default offset increment +Camera::Camera() +{ + pitch_track = -15.0f; + offset_inc = 5.0f; + + yaw = 0; + yaw_target = 0; -float Camera::yaw = 0; // current yaw, angle in XZ plane, positive is looking left -float Camera::yaw_target = 0; // target yaw + pitch = pitch_track * 2; + pitch_target = pitch_track; -float Camera::pitch = -45.0f; // current pitch, angle in XY, positive is looking up -float Camera::pitch_target = Camera::track_pitch; // target pitch + distance = 0.4f; -float Camera::distance = 0.4f; // distance from the eye to the target + mode = Track; +} + +Camera::~Camera() +{ +} void Camera::draw(float elapsed) { @@ -95,7 +102,7 @@ void Camera::nextmode() { mode = Track; yaw_target = game::ship.yaw; yaw = yaw_target; - pitch_target = track_pitch; + pitch_target = pitch_track; pitch = pitch_target; break; case Track: @@ -103,7 +110,7 @@ void Camera::nextmode() { mode = Free; yaw_target = game::ship.yaw; yaw = yaw_target; - pitch_target = track_pitch; + pitch_target = pitch_track; pitch = pitch_target; break; default: diff --git a/src/client/camera.h b/src/client/camera.h index 2e20c1b..7e189b3 100644 --- a/src/client/camera.h +++ b/src/client/camera.h @@ -18,47 +18,49 @@ for the camera eye location. The camera always looks at (0,0,0) class Camera { public: + Camera(); + ~Camera(); + /// enum indicating the camera mode enum Mode {Free, Track}; /// draw the OpenGL camera transformation - static void draw(float elapsed); + void draw(float elapsed); /// rotate the camera left - static void rotate_left(); + void rotate_left(); /// rotate the camera right - static void rotate_right(); + void rotate_right(); /// rotate the camera up - static void rotate_up(); + void rotate_up(); /// rotate the camera down - static void rotate_down(); + void rotate_down(); /// switch to next camera mode - static void nextmode(); + void nextmode(); /// camera target /** The location the camera is looking at */ - static gl::Vector3f target; + gl::Vector3f target; /// target yaw, angle in XZ plane, positive is looking left - static float yaw_target; + float yaw_target; /// target pitch, angle in XZ plane, positive is looking left - static float pitch_target; + float pitch_target; /// distance from the camera to the target - static float distance; + float distance; + /// current camera mode + Mode mode; protected: - /// default tracking pitch - static const float track_pitch; - /// default offset increment - static const float offset_inc; - /// current yaw, angle in XZ plane, positive is looking left - static float yaw; + float yaw ; /// current pitch, angle in XY, positive is looking up - static float pitch; - - static Mode mode; + float pitch; + /// default tracking pitch + float pitch_track; + /// default offset increment + float offset_inc; }; } // namespace client diff --git a/src/client/input.cc b/src/client/input.cc index b231270..fc70b37 100644 --- a/src/client/input.cc +++ b/src/client/input.cc @@ -5,12 +5,9 @@ */ //project headers -#include "input.h" -#include "view.h" -#include "camera.h" - -#include "common/functions.h" +#include "client.h" #include "game/game.h" +#include "common/functions.h" namespace client { @@ -30,19 +27,19 @@ void Input::handle_keydown(SDL_keysym* keysym) game::shutdown(); break; case SDLK_SPACE: - Camera::nextmode(); + camera.nextmode(); break; case SDLK_LEFT: - Camera::rotate_left(); + camera.rotate_left(); break; case SDLK_RIGHT: - Camera::rotate_right(); + camera.rotate_right(); break; case SDLK_UP: - Camera::rotate_up(); + camera.rotate_up(); break; case SDLK_DOWN: - Camera::rotate_down(); + camera.rotate_down(); break; case SDLK_KP_PLUS: game::ship.thrust_increase(); diff --git a/src/client/input.h b/src/client/input.h index 6027d58..fa5486d 100644 --- a/src/client/input.h +++ b/src/client/input.h @@ -14,19 +14,16 @@ class Input { public: /// initialize the input subsystem - static void init(); + void init(); /// shutdown the input subsystem - static void shutdown(); - - /// exit the application - static void quit(int exit_code); + void shutdown(); /// process input events - static void process(); + void process(); protected: /// handle keydown events - static void handle_keydown(SDL_keysym* keysym); + void handle_keydown(SDL_keysym* keysym); }; } // namespace Client diff --git a/src/client/main.cc b/src/client/main.cc index 76f7277..e8486ca 100644 --- a/src/client/main.cc +++ b/src/client/main.cc @@ -3,63 +3,10 @@ the terms and conditions of the GNU General Public License version 2 */ -// SDL headers -#include <SDL/SDL.h> - -// C++ headers -#include <iostream> - -// project headers -#include "osirion.h" -#include "game/game.h" - -#include "input.h" -#include "video.h" - -void quit(int status) -{ - SDL_Quit(); - exit(status); -} +#include "client.h" int main( int argc, char *argv[] ) { - std::cout << "Project::OSiRiON " << OSIRION_VERSION << std::endl; - - // Initialize the video subsystem - client::Video::init(); - if (!client::Video::initialized) { - quit(1); - } - - // initialize input - client::Input::init(); - - // initialize game - game::init(); - - Uint32 startup = SDL_GetTicks(); - while(game::initialized) { - Uint32 chrono = SDL_GetTicks(); - - // overflow protection ~49 days - if (chrono < startup) { - startup = chrono; - } - - // update the game chronometers - float elapsed = (float) ( chrono - startup) / 1000.0f; - game::update(elapsed); - - // update the video chronometers and draw - client::Video::draw(elapsed); - startup = chrono; - - // process input - client::Input::process(); - } - - client::Video::shutdown(); - - quit(0); + client::init(); + client::run(); } diff --git a/src/client/video.cc b/src/client/video.cc index a676d10..1dc596e 100644 --- a/src/client/video.cc +++ b/src/client/video.cc @@ -4,8 +4,7 @@ the terms and conditions of the GNU General Public License version 2 */ -#include "video.h" -#include "view.h" +#include "client.h" #include "gl/osiriongl.h" #include <SDL/SDL.h> @@ -13,10 +12,17 @@ namespace client { -int Video::width = 0; -int Video::height = 0; -bool Video::initialized = false; -float Video::ratio = 1; +Video::Video() +{ + width = 0; + height = 0; + initialized = false; + ratio = 1; +} + +Video::~Video() +{ +} void Video::reset() { @@ -43,7 +49,7 @@ void Video::reset() // Setup our viewport. gl::viewport(0, 0, width, height ); - View::reset(); + view.reset(); } void Video::init() @@ -87,7 +93,7 @@ void Video::init() gl::init(); initialized = true; - View::init(); + view.init(); reset(); return; @@ -95,12 +101,12 @@ void Video::init() void Video::draw(float elapsed) { - View::draw(elapsed); + view.draw(elapsed); } void Video::shutdown() { - client::View::shutdown(); + view.shutdown(); gl::shutdown(); initialized = false; diff --git a/src/client/video.h b/src/client/video.h index 145cc24..4c07652 100644 --- a/src/client/video.h +++ b/src/client/video.h @@ -10,24 +10,26 @@ namespace client { class Video { public: + Video(); + ~Video(); + /// initialize the video subsystem - static void init(); + void init(); /// shutdown the video subsystem - static void shutdown(); + void shutdown(); /// Update the screen state and redraw - static void draw(float elapsed); + void draw(float elapsed); /// reset and clear the viewport - static void reset(); + void reset(); /// Width of the SDL window in pixels - static int width; + int width; /// Height of the SDL window in pixels - static int height; + int height; /// True if the video subsystem is initialized - static bool initialized; + bool initialized; /// width/height ratio - static float ratio; - + float ratio; }; } // namespace client diff --git a/src/client/view.cc b/src/client/view.cc index af9037b..c9a7b8a 100644 --- a/src/client/view.cc +++ b/src/client/view.cc @@ -4,9 +4,7 @@ the terms and conditions of the GNU General Public License version 2 */ -#include "view.h" -#include "video.h" -#include "camera.h" +#include "client.h" #include "shipdrawer.h" #include "stardrawer.h" #include "gl/osiriongl.h" @@ -53,7 +51,7 @@ void View::reset() { //glu::perspective( 64.0, video::ratio, 1.0, 1024.0 ); const float frustumsize=0.5f; - gl::frustum( -frustumsize * Video::ratio, frustumsize * Video::ratio, -frustumsize, frustumsize, 1.0f, 1024.0f); + gl::frustum( -frustumsize * video.ratio, frustumsize * video.ratio, -frustumsize, frustumsize, 1.0f, 1024.0f); /* map world coordinates to GL coordinates @@ -144,7 +142,7 @@ void View::draw(float elapsed) gl::loadidentity(); // Camera transformation - Camera::draw(elapsed); + camera.draw(elapsed); // draw the world draw_world(elapsed); diff --git a/src/client/view.h b/src/client/view.h index 377cc9b..0087ae5 100644 --- a/src/client/view.h +++ b/src/client/view.h @@ -13,21 +13,21 @@ class View { public: /// intialize the view - static void init(); + void init(); /// shutdown the view - static void shutdown(); + void shutdown(); /// Update the chronometer and draw the game view - static void draw(float elapsed); + void draw(float elapsed); /// Reset the projection matrix - static void reset(); + void reset(); protected: /// draw the world - static void draw_world(float elapsed); + void draw_world(float elapsed); /// draw the background - static void draw_background(float elapsed); + void draw_background(float elapsed); }; } // namespace client diff --git a/src/common/functions.h b/src/common/functions.h index 62cf627..d13fd17 100644 --- a/src/common/functions.h +++ b/src/common/functions.h @@ -11,6 +11,7 @@ #include <cstdlib> #include <cmath> +/// Support functions for the game engine namespace common { /// return the smallest of two float values diff --git a/src/game/game.h b/src/game/game.h index 9609884..a2c4156 100644 --- a/src/game/game.h +++ b/src/game/game.h @@ -11,6 +11,7 @@ #include "ship.h" #include "star.h" +/// The game engine namespace game { /// initialize the game |