summaryrefslogtreecommitdiff
authorandyq <andyq>2002-12-09 20:30:46 (UTC)
committer andyq <andyq>2002-12-09 20:30:46 (UTC)
commitb9a448e0687558c1cb79f801161966e15d589132 (patch) (unidiff)
tree4f485b85b8bc03546008dd2003c75bf60f7acd9b
parentaccc4e231dc34744e75d32af77eeb98f46006c27 (diff)
downloadopie-b9a448e0687558c1cb79f801161966e15d589132.zip
opie-b9a448e0687558c1cb79f801161966e15d589132.tar.gz
opie-b9a448e0687558c1cb79f801161966e15d589132.tar.bz2
Added replay function and included own random method for replay functionality
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/games/sfcave/random.cpp179
-rw-r--r--noncore/games/sfcave/random.h19
-rw-r--r--noncore/games/sfcave/sfcave.cpp79
-rw-r--r--noncore/games/sfcave/sfcave.h12
-rw-r--r--noncore/games/sfcave/sfcave.pro4
5 files changed, 274 insertions, 19 deletions
diff --git a/noncore/games/sfcave/random.cpp b/noncore/games/sfcave/random.cpp
new file mode 100644
index 0000000..c4c10bb
--- a/dev/null
+++ b/noncore/games/sfcave/random.cpp
@@ -0,0 +1,179 @@
1/* -------------------------------------------------------------------------
2 * This is an ANSI C library for multi-stream random number generation.
3 * The use of this library is recommended as a replacement for the ANSI C
4 * rand() and srand() functions, particularly in simulation applications
5 * where the statistical 'goodness' of the random number generator is
6 * important. The library supplies 256 streams of random numbers; use
7 * SelectStream(s) to switch between streams indexed s = 0,1,...,255.
8 *
9 * The streams must be initialized. The recommended way to do this is by
10 * using the function PlantSeeds(x) with the value of x used to initialize
11 * the default stream and all other streams initialized automatically with
12 * values dependent on the value of x. The following convention is used
13 * to initialize the default stream:
14 * if x > 0 then x is the state
15 * if x < 0 then the state is obtained from the system clock
16 * if x = 0 then the state is to be supplied interactively.
17 *
18 * The generator used in this library is a so-called 'Lehmer random number
19 * generator' which returns a pseudo-random number uniformly distributed
20 * 0.0 and 1.0. The period is (m - 1) where m = 2,147,483,647 and the
21 * smallest and largest possible values are (1 / m) and 1 - (1 / m)
22 * respectively. For more details see:
23 *
24 * "Random Number Generators: Good Ones Are Hard To Find"
25 * Steve Park and Keith Miller
26 * Communications of the ACM, October 1988
27 *
28 * Name : rngs.c (Random Number Generation - Multiple Streams)
29 * Authors : Steve Park & Dave Geyer
30 * Language : ANSI C
31 * Latest Revision : 09-22-98
32 * -------------------------------------------------------------------------
33 */
34
35#include <stdio.h>
36#include <time.h>
37#include "random.h"
38
39#define MODULUS 2147483647 /* DON'T CHANGE THIS VALUE */
40#define MULTIPLIER 48271 /* DON'T CHANGE THIS VALUE */
41#define CHECK 399268537 /* DON'T CHANGE THIS VALUE */
42#define STREAMS 256 /* # of streams, DON'T CHANGE THIS VALUE */
43#define A256 22925 /* jump multiplier, DON'T CHANGE THIS VALUE */
44#define DEFAULT 123456789 /* initial seed, use 0 < DEFAULT < MODULUS */
45
46static long seed[STREAMS] = {DEFAULT}; /* current state of each stream */
47static int stream = 0; /* stream index, 0 is the default */
48static int initialized = 0; /* test for stream initialization */
49
50
51 double Random(void)
52/* ----------------------------------------------------------------
53 * Random returns a pseudo-random real number uniformly distributed
54 * between 0.0 and 1.0.
55 * ----------------------------------------------------------------
56 */
57{
58 const long Q = MODULUS / MULTIPLIER;
59 const long R = MODULUS % MULTIPLIER;
60 long t;
61
62 t = MULTIPLIER * (seed[stream] % Q) - R * (seed[stream] / Q);
63 if (t > 0)
64 seed[stream] = t;
65 else
66 seed[stream] = t + MODULUS;
67 return ((double) seed[stream] / MODULUS);
68}
69
70
71 void PlantSeeds(long x)
72/* ---------------------------------------------------------------------
73 * Use this function to set the state of all the random number generator
74 * streams by "planting" a sequence of states (seeds), one per stream,
75 * with all states dictated by the state of the default stream.
76 * The sequence of planted states is separated one from the next by
77 * 8,367,782 calls to Random().
78 * ---------------------------------------------------------------------
79 */
80{
81 const long Q = MODULUS / A256;
82 const long R = MODULUS % A256;
83 int j;
84 int s;
85
86 initialized = 1;
87 s = stream; /* remember the current stream */
88 SelectStream(0); /* change to stream 0 */
89 PutSeed(x); /* set seed[0] */
90 stream = s; /* reset the current stream */
91 for (j = 1; j < STREAMS; j++) {
92 x = A256 * (seed[j - 1] % Q) - R * (seed[j - 1] / Q);
93 if (x > 0)
94 seed[j] = x;
95 else
96 seed[j] = x + MODULUS;
97 }
98}
99
100
101 void PutSeed(long x)
102/* ---------------------------------------------------------------
103 * Use this function to set the state of the current random number
104 * generator stream according to the following conventions:
105 * if x > 0 then x is the state (unless too large)
106 * if x < 0 then the state is obtained from the system clock
107 * if x = 0 then the state is to be supplied interactively
108 * ---------------------------------------------------------------
109 */
110{
111 char ok = 0;
112
113 if (x > 0)
114 x = x % MODULUS; /* correct if x is too large */
115 if (x < 0)
116 x = ((unsigned long) time((time_t *) NULL)) % MODULUS;
117 if (x == 0)
118 while (!ok) {
119 printf("\nEnter a positive integer seed (9 digits or less) >> ");
120 scanf("%ld", &x);
121 ok = (0 < x) && (x < MODULUS);
122 if (!ok)
123 printf("\nInput out of range ... try again\n");
124 }
125 seed[stream] = x;
126}
127
128
129 void GetSeed(long *x)
130/* ---------------------------------------------------------------
131 * Use this function to get the state of the current random number
132 * generator stream.
133 * ---------------------------------------------------------------
134 */
135{
136 *x = seed[stream];
137}
138
139
140 void SelectStream(int index)
141/* ------------------------------------------------------------------
142 * Use this function to set the current random number generator
143 * stream -- that stream from which the next random number will come.
144 * ------------------------------------------------------------------
145 */
146{
147 stream = ((unsigned int) index) % STREAMS;
148 if ((initialized == 0) && (stream != 0)) /* protect against */
149 PlantSeeds(DEFAULT); /* un-initialized streams */
150}
151
152
153 void TestRandom(void)
154/* ------------------------------------------------------------------
155 * Use this (optional) function to test for a correct implementation.
156 * ------------------------------------------------------------------
157 */
158{
159 long i;
160 long x;
161 double u;
162 char ok = 0;
163
164 SelectStream(0); /* select the default stream */
165 PutSeed(1); /* and set the state to 1 */
166 for(i = 0; i < 10000; i++)
167 u = Random();
168 GetSeed(&x); /* get the new state value */
169 ok = (x == CHECK); /* and check for correctness */
170
171 SelectStream(1); /* select stream 1 */
172 PlantSeeds(1); /* set the state of all streams */
173 GetSeed(&x); /* get the state of stream 1 */
174 ok = ok && (x == A256); /* x should be the jump multiplier */
175 if (ok)
176 printf("\n The implementation of rngs.c is correct.\n\n");
177 else
178 printf("\n\a ERROR -- the implementation of rngs.c is not correct.\n\n");
179}
diff --git a/noncore/games/sfcave/random.h b/noncore/games/sfcave/random.h
new file mode 100644
index 0000000..4bc7c06
--- a/dev/null
+++ b/noncore/games/sfcave/random.h
@@ -0,0 +1,19 @@
1/* -----------------------------------------------------------------------
2 * Name : rngs.h (header file for the library file rngs.c)
3 * Author : Steve Park & Dave Geyer
4 * Language : ANSI C
5 * Latest Revision : 09-22-98
6 * -----------------------------------------------------------------------
7 */
8
9#if !defined( _RNGS_ )
10#define _RNGS_
11
12double Random(void);
13void PlantSeeds(long x);
14void GetSeed(long *x);
15void PutSeed(long x);
16void SelectStream(int index);
17void TestRandom(void);
18
19#endif
diff --git a/noncore/games/sfcave/sfcave.cpp b/noncore/games/sfcave/sfcave.cpp
index 788606f..b5bc736 100644
--- a/noncore/games/sfcave/sfcave.cpp
+++ b/noncore/games/sfcave/sfcave.cpp
@@ -1,956 +1,1003 @@
1#include <stdio.h> 1#include <stdio.h>
2#include <stdlib.h> 2#include <stdlib.h>
3#include <math.h> 3#include <math.h>
4#include <time.h>
4 5
5#ifdef QWS 6#ifdef QWS
6#include <qpe/qpeapplication.h> 7#include <qpe/qpeapplication.h>
7#include <qpe/config.h> 8#include <qpe/config.h>
8#else 9#else
9#include <qapplication.h> 10#include <qapplication.h>
10#endif 11#endif
11 12
12#include "helpwindow.h" 13#include "helpwindow.h"
13#include "sfcave.h" 14#include "sfcave.h"
14 15
15#define CAPTION "SFCave 1.8 by AndyQ" 16#define CAPTION "SFCave 1.8 by AndyQ"
16 17
17#define UP_THRUST 0.6 18#define UP_THRUST 0.6
18#define NO_THRUST 0.8 19#define NO_THRUST 0.8
19#define MAX_DOWN_THRUST 4.0 20#define MAX_DOWN_THRUST 4.0
20#define MAX_UP_THRUST -3.5 21#define MAX_UP_THRUST -3.5
21 22
22// States 23// States
23#define STATE_BOSS 0 24#define STATE_BOSS 0
24#define STATE_RUNNING 1 25#define STATE_RUNNING 1
25#define STATE_CRASHING 2 26#define STATE_CRASHING 2
26#define STATE_CRASHED 3 27#define STATE_CRASHED 3
27#define STATE_NEWGAME 4 28#define STATE_NEWGAME 4
28#define STATE_MENU 5 29#define STATE_MENU 5
30#define STATE_REPLAY 6
29 31
30// Menus 32// Menus
31#define MENU_MAIN_MENU 0 33#define MENU_MAIN_MENU 0
32#define MENU_OPTIONS_MENU 1 34#define MENU_OPTIONS_MENU 1
33 35
34// Main Menu Options 36// Main Menu Options
35#define MENU_START_GAME 0 37#define MENU_START_GAME 0
36#define MENU_OPTIONS 1 38#define MENU_OPTIONS 1
37#define MENU_HELP 2 39#define MENU_HELP 2
38#define MENU_QUIT 3 40#define MENU_QUIT 3
39 41
40// Option Menu Options 42// Option Menu Options
41#define MENU_GAME_TYPE 0 43#define MENU_GAME_TYPE 0
42#define MENU_GAME_DIFFICULTY 1 44#define MENU_GAME_DIFFICULTY 1
43#define MENU_CLEAR_HIGHSCORES 2 45#define MENU_CLEAR_HIGHSCORES 2
44#define MENU_BACK 3 46#define MENU_BACK 3
45 47
46 48
47#define NR_GAME_DIFFICULTIES 3 49#define NR_GAME_DIFFICULTIES 3
48#define NR_GAME_TYPES 3 50#define NR_GAME_TYPES 3
49 51
50#define DIFICULTY_EASY 0 52#define DIFICULTY_EASY 0
51#define DIFICULTY_NORMAL 1 53#define DIFICULTY_NORMAL 1
52#define DIFICULTY_HARD 2 54#define DIFICULTY_HARD 2
53#define EASY "Easy" 55#define EASY "Easy"
54#define NORMAL "Normal" 56#define NORMAL "Normal"
55#define HARD "Hard" 57#define HARD "Hard"
56 58
57#define SFCAVE_GAME_TYPE 0 59#define SFCAVE_GAME_TYPE 0
58#define GATES_GAME_TYPE 1 60#define GATES_GAME_TYPE 1
59#define FLY_GAME_TYPE 2 61#define FLY_GAME_TYPE 2
60#define SFCAVE_GAME "SFCave" 62#define SFCAVE_GAME "SFCave"
61#define GATES_GAME "Gates" 63#define GATES_GAME "Gates"
62#define FLY_GAME "Fly" 64#define FLY_GAME "Fly"
63#define CURRENT_GAME_TYPE gameTypes[currentGameType] 65#define CURRENT_GAME_TYPE gameTypes[currentGameType]
64#define CURRENT_GAME_DIFFICULTY difficultyOption[currentGameDifficulty]; 66#define CURRENT_GAME_DIFFICULTY difficultyOption[currentGameDifficulty];
65 67
66QString SFCave::dificultyOption[] = { EASY, NORMAL, HARD }; 68QString SFCave::dificultyOption[] = { EASY, NORMAL, HARD };
67QString SFCave::gameTypes[] = { SFCAVE_GAME, GATES_GAME, FLY_GAME }; 69QString SFCave::gameTypes[] = { SFCAVE_GAME, GATES_GAME, FLY_GAME };
68 70
69QString SFCave::menuOptions[2][5] = { { "Start Game", "Options", "Help", "Quit", "" }, 71QString SFCave::menuOptions[2][5] = { { "Start Game", "Options", "Help", "Quit", "" },
70 { "Game Type - %s", "Game Difficulty - %s", "Clear High Scores for this game", "Back", "" } }; 72 { "Game Type - %s", "Game Difficulty - %s", "Clear High Scores for this game", "Back", "" } };
71 73
72#define UP_THRUST 0.6 74#define UP_THRUST 0.6
73#define NO_THRUST 0.8 75#define NO_THRUST 0.8
74#define MAX_DOWN_THRUST 4.0 76#define MAX_DOWN_THRUST 4.0
75#define MAX_UP_THRUST -3.5 77#define MAX_UP_THRUST -3.5
76double SFCave::UpThrustVals[3][3] = {{ 0.6, 0.6, 0.6 }, // SFCave 78double SFCave::UpThrustVals[3][3] = {{ 0.6, 0.6, 0.6 }, // SFCave
77 { 0.6, 0.6, 0.8 }, // Gates 79 { 0.6, 0.6, 0.8 }, // Gates
78 { 0.4, 0.7, 1.0 } }; // Fly 80 { 0.4, 0.7, 1.0 } }; // Fly
79 81
80double SFCave::DownThrustVals[3][3] = {{ 0.8, 0.8, 0.8 }, // SFCave 82double SFCave::DownThrustVals[3][3] = {{ 0.8, 0.8, 0.8 }, // SFCave
81 { 0.8, 0.8, 1.0 }, // Gates 83 { 0.8, 0.8, 1.0 }, // Gates
82 { 0.4, 0.7, 1.0 } }; // Fly 84 { 0.4, 0.7, 1.0 } }; // Fly
83 85
84double SFCave::MaxUpThrustVals[3][3] = {{ -3.5, -3.5, -3.5 }, // SFCave 86double SFCave::MaxUpThrustVals[3][3] = {{ -3.5, -3.5, -3.5 }, // SFCave
85 { -3.5, -4.0, -5.0 }, // Gates 87 { -3.5, -4.0, -5.0 }, // Gates
86 { -3.5, -4.0, -5.0 } }; // Fly 88 { -3.5, -4.0, -5.0 } }; // Fly
87 89
88double SFCave::MaxDownThrustVals[3][3] = {{ 4.0, 4.0, 4.0 }, // SFCave 90double SFCave::MaxDownThrustVals[3][3] = {{ 4.0, 4.0, 4.0 }, // SFCave
89 { 4.0, 5.0, 5.5 }, // Gates 91 { 4.0, 5.0, 5.5 }, // Gates
90 { 3.5, 4.0, 5.0 } }; // Fly 92 { 3.5, 4.0, 5.0 } }; // Fly
91 93
92int SFCave::initialGateGaps[] = { 75, 50, 25 }; 94int SFCave::initialGateGaps[] = { 75, 50, 25 };
93 95
94int SFCave::nrMenuOptions[2] = { 4, 4 }; 96int SFCave::nrMenuOptions[2] = { 4, 4 };
95int SFCave ::currentMenuOption[2] = { 0, 0 }; 97int SFCave ::currentMenuOption[2] = { 0, 0 };
96 98
97bool movel; 99bool movel;
98 100
99 101
100int main( int argc, char *argv[] ) 102int main( int argc, char *argv[] )
101{ 103{
102 movel = true; 104 movel = true;
103#ifdef QWS 105#ifdef QWS
104 QPEApplication a( argc, argv ); 106 QPEApplication a( argc, argv );
105#else 107#else
106 QApplication a( argc, argv ); 108 QApplication a( argc, argv );
107#endif 109#endif
108 110
109 int speed = 3; 111 int speed = 3;
110 for ( int i = 0 ; i < argc ; ++i ) 112 for ( int i = 0 ; i < argc ; ++i )
111 { 113 {
112 if ( strcmp( argv[i], "-s" ) == 0 ) 114 if ( strcmp( argv[i], "-s" ) == 0 )
113 { 115 {
114 if ( i+1 < argc ) 116 if ( i+1 < argc )
115 speed = atoi( argv[i+1] ); 117 speed = atoi( argv[i+1] );
116 } 118 }
117 } 119 }
118 120
119 SFCave app( speed ); 121 SFCave app( speed );
120 a.setMainWidget( &app ); 122 a.setMainWidget( &app );
121 app.show(); 123 app.show();
122 app.start(); 124 app.start();
123 a.exec(); 125 a.exec();
124} 126}
125 127
126SFCave :: SFCave( int spd, QWidget *w, char *name ) 128SFCave :: SFCave( int spd, QWidget *w, char *name )
127 : QMainWindow( w, name ) 129 : QMainWindow( w, name )
128 130
129{ 131{
132 replayIt = 0;
130#ifdef QWS 133#ifdef QWS
131 showMaximized(); 134 showMaximized();
132#else 135#else
133 resize( 240, 284 ); 136 resize( 240, 284 );
134#endif 137#endif
135 138
136 sWidth = width(); 139 sWidth = width();
137 sHeight = height(); 140 sHeight = height();
138 segSize = sWidth/(MAPSIZE-1)+1; 141 segSize = sWidth/(MAPSIZE-1)+1;
139 142
140 currentMenuNr = 0; 143 currentMenuNr = 0;
141 currentGameType = 0; 144 currentGameType = 0;
142 currentGameDifficulty = 0; 145 currentGameDifficulty = 0;
143 146
144 setCaption( CAPTION ); 147 setCaption( CAPTION );
145 showScoreZones = false; 148 showScoreZones = false;
146 149
147#ifdef QWS 150#ifdef QWS
148 Config cfg( "sfcave" ); 151 Config cfg( "sfcave" );
149 cfg.setGroup( "settings" ); 152 cfg.setGroup( "settings" );
150 QString key = "highScore_"; 153 QString key = "highScore_";
151 154
152 for ( int i = 0 ; i < 3 ; ++i ) 155 for ( int i = 0 ; i < 3 ; ++i )
153 { 156 {
154 for ( int j = 0 ; j < 3 ; ++j ) 157 for ( int j = 0 ; j < 3 ; ++j )
155 highestScore[i][j] = cfg.readNumEntry( key + gameTypes[i] + "_" + dificultyOption[j], 0 ); 158 highestScore[i][j] = cfg.readNumEntry( key + gameTypes[i] + "_" + dificultyOption[j], 0 );
156 } 159 }
157 160
158 currentGameType = cfg.readNumEntry( "gameType", 0 ); 161 currentGameType = cfg.readNumEntry( "gameType", 0 );
159 currentGameDifficulty = cfg.readNumEntry( "difficulty", 0 ); 162 currentGameDifficulty = cfg.readNumEntry( "difficulty", 0 );
160#endif 163#endif
161 speed = spd; // Change to 2 for PC 164 speed = spd; // Change to 2 for PC
162 press = false; 165 press = false;
163 166
164 offscreen = new QPixmap( sWidth, sHeight ); 167 offscreen = new QPixmap( sWidth, sHeight );
165 offscreen->fill( Qt::black ); 168 offscreen->fill( Qt::black );
166 169
167 setUp(); 170// setUp();
168 crashLineLength = -1; 171 crashLineLength = -1;
172 state = STATE_MENU;
173 prevState = STATE_MENU;
169 174
170 gameTimer = new QTimer( this, "game timer" ); 175 gameTimer = new QTimer( this, "game timer" );
171 connect( gameTimer, SIGNAL( timeout() ), 176 connect( gameTimer, SIGNAL( timeout() ),
172 this, SLOT( run() ) ); 177 this, SLOT( run() ) );
173} 178}
174 179
175SFCave :: ~SFCave() 180SFCave :: ~SFCave()
176{ 181{
177} 182}
178 183
179void SFCave :: start() 184void SFCave :: start()
180{ 185{
181 gameTimer->start( 10 ); 186 gameTimer->start( 10 );
182 187
183} 188}
184 189
190void SFCave :: setSeed( int seed )
191{
192 if ( seed == -1 )
193 currentSeed = ((unsigned long) time((time_t *) NULL));
194 else
195 currentSeed = seed;
196 PutSeed( currentSeed );
197}
198
185int SFCave :: nextInt( int range ) 199int SFCave :: nextInt( int range )
186{ 200{
187 return rand() % range; 201 int val = (int)(Random( ) * range);
202
203 return val;
204
188} 205}
189 206
190void SFCave :: setUp() 207void SFCave :: setUp()
191{ 208{
192 state = STATE_MENU;
193 prevState = STATE_MENU;
194
195 score = 0; 209 score = 0;
196 offset = 0; 210 offset = 0;
197 nrFrames = 0; 211 nrFrames = 0;
198 dir = 1; 212 dir = 1;
199 thrust = 0; 213 thrust = 0;
200 214
201 if ( CURRENT_GAME_TYPE == SFCAVE_GAME ) 215 if ( CURRENT_GAME_TYPE == SFCAVE_GAME )
202 { 216 {
203 thrustUp = UpThrustVals[SFCAVE_GAME_TYPE][currentGameDifficulty];; 217 thrustUp = UpThrustVals[SFCAVE_GAME_TYPE][currentGameDifficulty];;
204 noThrust = DownThrustVals[SFCAVE_GAME_TYPE][currentGameDifficulty];; 218 noThrust = DownThrustVals[SFCAVE_GAME_TYPE][currentGameDifficulty];;
205 maxUpThrust = MaxUpThrustVals[SFCAVE_GAME_TYPE][currentGameDifficulty];; 219 maxUpThrust = MaxUpThrustVals[SFCAVE_GAME_TYPE][currentGameDifficulty];;
206 maxDownThrust = MaxDownThrustVals[SFCAVE_GAME_TYPE][currentGameDifficulty];; 220 maxDownThrust = MaxDownThrustVals[SFCAVE_GAME_TYPE][currentGameDifficulty];;
207 } 221 }
208 else if ( CURRENT_GAME_TYPE == GATES_GAME ) 222 else if ( CURRENT_GAME_TYPE == GATES_GAME )
209 { 223 {
210 thrustUp = UpThrustVals[GATES_GAME_TYPE][currentGameDifficulty];; 224 thrustUp = UpThrustVals[GATES_GAME_TYPE][currentGameDifficulty];;
211 noThrust = DownThrustVals[GATES_GAME_TYPE][currentGameDifficulty];; 225 noThrust = DownThrustVals[GATES_GAME_TYPE][currentGameDifficulty];;
212 maxUpThrust = MaxUpThrustVals[GATES_GAME_TYPE][currentGameDifficulty];; 226 maxUpThrust = MaxUpThrustVals[GATES_GAME_TYPE][currentGameDifficulty];;
213 maxDownThrust = MaxDownThrustVals[GATES_GAME_TYPE][currentGameDifficulty];; 227 maxDownThrust = MaxDownThrustVals[GATES_GAME_TYPE][currentGameDifficulty];;
214 } 228 }
215 else 229 else
216 { 230 {
217 thrustUp = UpThrustVals[FLY_GAME_TYPE][currentGameDifficulty]; 231 thrustUp = UpThrustVals[FLY_GAME_TYPE][currentGameDifficulty];
218 noThrust = DownThrustVals[FLY_GAME_TYPE][currentGameDifficulty]; 232 noThrust = DownThrustVals[FLY_GAME_TYPE][currentGameDifficulty];
219 maxUpThrust = MaxUpThrustVals[FLY_GAME_TYPE][currentGameDifficulty]; 233 maxUpThrust = MaxUpThrustVals[FLY_GAME_TYPE][currentGameDifficulty];
220 maxDownThrust = MaxDownThrustVals[FLY_GAME_TYPE][currentGameDifficulty]; 234 maxDownThrust = MaxDownThrustVals[FLY_GAME_TYPE][currentGameDifficulty];
221 } 235 }
222 236
223 crashLineLength = 0; 237 crashLineLength = 0;
238 lastGateBottomY = 0;
224 239
225 user.setRect( 50, sWidth/2, 4, 4 ); 240 user.setRect( 50, sWidth/2, 4, 4 );
226 241
227 blockWidth = 20; 242 blockWidth = 20;
228 blockHeight = 70; 243 blockHeight = 70;
229 gapHeight = initialGateGaps[currentGameDifficulty]; 244 gapHeight = initialGateGaps[currentGameDifficulty];
230 gateDistance = 75; 245 gateDistance = 75;
231 nextGate = nextInt( 50 ) + gateDistance; 246 nextGate = nextInt( 50 ) + gateDistance;
232 247
233 for ( int i = 0 ; i < TRAILSIZE ; ++i ) 248 for ( int i = 0 ; i < TRAILSIZE ; ++i )
234 { 249 {
235 trail[i].setX( -1 ); 250 trail[i].setX( -1 );
236 trail[i].setY( 0 ); 251 trail[i].setY( 0 );
237 } 252 }
238 253
239 if ( CURRENT_GAME_TYPE != FLY_GAME ) 254 if ( CURRENT_GAME_TYPE != FLY_GAME )
240 { 255 {
241 maxHeight = 50; 256 maxHeight = 50;
242 257
243 mapTop[0] = (int)(nextInt(50)) + 5; 258 mapTop[0] = (int)(nextInt(50)) + 5;
244 mapBottom[0] = (int)(nextInt(50)) + 5; 259 mapBottom[0] = (int)(nextInt(50)) + 5;
245 for ( int i = 1 ; i < MAPSIZE ; ++i ) 260 for ( int i = 1 ; i < MAPSIZE ; ++i )
246 setPoint( i ); 261 setPoint( i );
247 } 262 }
248 else 263 else
249 { 264 {
250 maxHeight = 100; 265 maxHeight = 100;
251 266
252 for ( int i = 0 ; i < MAPSIZE ; ++i ) 267 for ( int i = 0 ; i < MAPSIZE ; ++i )
253 mapBottom[i] = sHeight - 10; 268 mapBottom[i] = sHeight - 10;
254 } 269 }
255 for ( int i = 0 ; i < BLOCKSIZE ; ++i ) 270 for ( int i = 0 ; i < BLOCKSIZE ; ++i )
256 blocks[i].setY( -1 ); 271 blocks[i].setY( -1 );
272
257} 273}
258 274
259void SFCave :: run() 275void SFCave :: run()
260{ 276{
261 switch ( state ) 277 switch ( state )
262 { 278 {
263 case STATE_MENU: 279 case STATE_MENU:
264 displayMenu(); 280 displayMenu();
265 break; 281 break;
266 case STATE_NEWGAME: 282 case STATE_NEWGAME:
283 setSeed( -1 );
267 setUp(); 284 setUp();
268 draw(); 285 draw();
269 state = STATE_RUNNING; 286 state = STATE_RUNNING;
287 replay = false;
288 replayList.clear();
270 break; 289 break;
290 case STATE_REPLAY:
291 setSeed( currentSeed );
292 setUp();
293 draw();
294 state = STATE_RUNNING;
295 replay = true;
296 if ( replayIt )
297 delete replayIt;
298 replayIt = new QListIterator<int>( replayList );
271 case STATE_BOSS: 299 case STATE_BOSS:
272 drawBoss(); 300 drawBoss();
273 break; 301 break;
274 302
275 case STATE_CRASHING: 303 case STATE_CRASHING:
276 case STATE_CRASHED: 304 case STATE_CRASHED:
277 draw(); 305 draw();
278 break; 306 break;
279 307
280 case STATE_RUNNING: 308 case STATE_RUNNING:
281 { 309 {
282 if ( nrFrames % 2 == 0 ) 310 if ( nrFrames % 2 == 0 )
283 handleKeys(); 311 handleKeys();
284 312
285 // Apply Game rules 313 // Apply Game rules
286 nrFrames ++; 314 nrFrames ++;
315
316 if ( replay )
317 {
318 while( replayIt->current() && *(replayIt->current()) == nrFrames )
319 {
320 press = !press;
321 ++(*replayIt);
322 }
323 }
324
287 if ( CURRENT_GAME_TYPE == SFCAVE_GAME ) 325 if ( CURRENT_GAME_TYPE == SFCAVE_GAME )
288 handleGameSFCave(); 326 handleGameSFCave();
289 else if ( CURRENT_GAME_TYPE == GATES_GAME ) 327 else if ( CURRENT_GAME_TYPE == GATES_GAME )
290 handleGameGates(); 328 handleGameGates();
291 else if ( CURRENT_GAME_TYPE == FLY_GAME ) 329 else if ( CURRENT_GAME_TYPE == FLY_GAME )
292 handleGameFly(); 330 handleGameFly();
293 331
294 draw(); 332 draw();
295 break; 333 break;
296 } 334 }
297 } 335 }
298} 336}
299 337
300void SFCave :: handleGameSFCave() 338void SFCave :: handleGameSFCave()
301{ 339{
302 // Update score 340 // Update score
303 if ( nrFrames % 5 == 0 ) 341 if ( nrFrames % 5 == 0 )
304 score ++; 342 score ++;
305 343
306 if ( nrFrames % 500 == 0 ) 344 if ( nrFrames % 500 == 0 )
307 { 345 {
308 if ( maxHeight < sHeight - 100 ) 346 if ( maxHeight < sHeight - 100 )
309 { 347 {
310 maxHeight += 10; 348 maxHeight += 10;
311 349
312 // Reduce block height 350 // Reduce block height
313 if ( maxHeight > sHeight - 150 ) 351 if ( maxHeight > sHeight - 150 )
314 blockHeight -= 5; 352 blockHeight -= 5;
315 } 353 }
316 } 354 }
317 355
318 if ( nrFrames % 100 == 0 ) 356 if ( nrFrames % 100 == 0 )
319 addBlock(); 357 addBlock();
320 358
321 if ( checkCollision() ) 359 if ( checkCollision() )
322 { 360 {
323 if ( score > highestScore[currentGameType][currentGameDifficulty] ) 361 if ( score > highestScore[currentGameType][currentGameDifficulty] )
324 { 362 {
325 highestScore[currentGameType][currentGameDifficulty] = score; 363 highestScore[currentGameType][currentGameDifficulty] = score;
326 saveScore(); 364 saveScore();
327 } 365 }
328 state = STATE_CRASHING; 366 state = STATE_CRASHING;
329 } 367 }
330 else 368 else
331 { 369 {
332 moveLandscape(); 370 moveLandscape();
333 } 371 }
334 372
335} 373}
336 374
337 375
338void SFCave :: handleGameGates() 376void SFCave :: handleGameGates()
339{ 377{
340 // Update score 378 // Update score
341 if ( nrFrames % 5 == 0 ) 379 if ( nrFrames % 5 == 0 )
342 score ++; 380 score ++;
343 381
344 // Slightly random gap distance 382 // Slightly random gap distance
345 if ( nrFrames >= nextGate ) 383 if ( nrFrames >= nextGate )
346 { 384 {
347 nextGate = nrFrames + nextInt( 50 ) + gateDistance; 385 nextGate = nrFrames + nextInt( 50 ) + gateDistance;
348 addGate(); 386 addGate();
349 } 387 }
350 388
351 if ( nrFrames % 500 == 0 ) 389 if ( nrFrames % 500 == 0 )
352 { 390 {
353 if ( gapHeight > 75 ) 391 if ( gapHeight > 75 )
354 gapHeight -= 5; 392 gapHeight -= 5;
355 } 393 }
356 394
357 if ( checkCollision() ) 395 if ( checkCollision() )
358 { 396 {
359 if ( score > highestScore[currentGameType][currentGameDifficulty] ) 397 if ( score > highestScore[currentGameType][currentGameDifficulty] )
360 { 398 {
361 highestScore[currentGameType][currentGameDifficulty] = score; 399 highestScore[currentGameType][currentGameDifficulty] = score;
362 saveScore(); 400 saveScore();
363 } 401 }
364 state = STATE_CRASHING; 402 state = STATE_CRASHING;
365 } 403 }
366 else 404 else
367 { 405 {
368 moveLandscape(); 406 moveLandscape();
369 } 407 }
370 408
371} 409}
372 410
373void SFCave :: handleGameFly() 411void SFCave :: handleGameFly()
374{ 412{
375 if ( nrFrames % 4 == 0 ) 413 if ( nrFrames % 4 == 0 )
376 { 414 {
377 // Update score 415 // Update score
378 // get distance between landscape and ship 416 // get distance between landscape and ship
379 int diff = mapBottom[10] - user.y(); 417 int diff = mapBottom[10] - user.y();
380 418
381 // the closer the difference is to 0 means more points 419 // the closer the difference is to 0 means more points
382 if ( diff < 10 ) 420 if ( diff < 10 )
383 score += 5; 421 score += 5;
384 else if ( diff < 20 ) 422 else if ( diff < 20 )
385 score += 3; 423 score += 3;
386 else if ( diff < 30 ) 424 else if ( diff < 30 )
387 score += 2; 425 score += 2;
388 else if ( diff < 40 ) 426 else if ( diff < 40 )
389 score += 1; 427 score += 1;
390 } 428 }
391 429
392 if ( checkFlyGameCollision() ) 430 if ( checkFlyGameCollision() )
393 { 431 {
394 if ( score > highestScore[currentGameType][currentGameDifficulty] ) 432 if ( score > highestScore[currentGameType][currentGameDifficulty] )
395 { 433 {
396 highestScore[currentGameType][currentGameDifficulty] = score; 434 highestScore[currentGameType][currentGameDifficulty] = score;
397 saveScore(); 435 saveScore();
398 } 436 }
399 state = STATE_CRASHING; 437 state = STATE_CRASHING;
400 } 438 }
401 else 439 else
402 { 440 {
403 moveFlyGameLandscape(); 441 moveFlyGameLandscape();
404 } 442 }
405} 443}
406 444
407bool SFCave :: checkFlyGameCollision() 445bool SFCave :: checkFlyGameCollision()
408{ 446{
409 if ( (user.y() + user.width()) >= mapBottom[11] ) 447 if ( (user.y() + user.width()) >= mapBottom[11] )
410 return true; 448 return true;
411 449
412 return false; 450 return false;
413} 451}
414 452
415void SFCave :: moveFlyGameLandscape() 453void SFCave :: moveFlyGameLandscape()
416{ 454{
417 offset++; 455 offset++;
418 456
419 if ( offset >= segSize ) 457 if ( offset >= segSize )
420 { 458 {
421 offset = 0; 459 offset = 0;
422 for ( int i = 0 ; i < MAPSIZE-speed ; ++i ) 460 for ( int i = 0 ; i < MAPSIZE-speed ; ++i )
423 mapBottom[i] = mapBottom[i+speed]; 461 mapBottom[i] = mapBottom[i+speed];
424 462
425 for ( int i = speed ; i > 0 ; --i ) 463 for ( int i = speed ; i > 0 ; --i )
426 setFlyPoint( MAPSIZE-i ); 464 setFlyPoint( MAPSIZE-i );
427 } 465 }
428} 466}
429 467
430void SFCave :: setFlyPoint( int point ) 468void SFCave :: setFlyPoint( int point )
431{ 469{
432 static int fly_difficulty_levels[] = { 5, 10, 15 }; 470 static int fly_difficulty_levels[] = { 5, 10, 15 };
433 if ( nextInt(100) >= 75 ) 471 if ( nextInt(100) >= 75 )
434 dir *= -1; 472 dir *= -1;
435 473
436 int prevPoint = mapBottom[point-1]; 474 int prevPoint = mapBottom[point-1];
437 475
438 int nextPoint = prevPoint + (dir * nextInt( fly_difficulty_levels[currentGameDifficulty] ) ); 476 int nextPoint = prevPoint + (dir * nextInt( fly_difficulty_levels[currentGameDifficulty] ) );
439 477
440 if ( nextPoint > sHeight ) 478 if ( nextPoint > sHeight )
441 { 479 {
442 nextPoint = sHeight; 480 nextPoint = sHeight;
443 dir *= -1; 481 dir *= -1;
444 } 482 }
445 else if ( nextPoint < maxHeight ) 483 else if ( nextPoint < maxHeight )
446 { 484 {
447 nextPoint = maxHeight; 485 nextPoint = maxHeight;
448 dir *= 1; 486 dir *= 1;
449 } 487 }
450 488
451 mapBottom[point] = nextPoint; 489 mapBottom[point] = nextPoint;
452} 490}
453 491
454bool SFCave :: checkCollision() 492bool SFCave :: checkCollision()
455{ 493{
456 if ( (user.y() + user.width()) >= mapBottom[11] || user.y() <= mapTop[11] ) 494 if ( (user.y() + user.width()) >= mapBottom[11] || user.y() <= mapTop[11] )
457 return true; 495 return true;
458 496
459 for ( int i = 0 ; i < BLOCKSIZE ; ++i ) 497 for ( int i = 0 ; i < BLOCKSIZE ; ++i )
460 { 498 {
461 if ( blocks[i].y() != -1 ) 499 if ( blocks[i].y() != -1 )
462 { 500 {
463 if ( blocks[i].intersects( user ) ) 501 if ( blocks[i].intersects( user ) )
464 return true; 502 return true;
465 } 503 }
466 } 504 }
467 return false; 505 return false;
468} 506}
469 507
470void SFCave :: moveLandscape() 508void SFCave :: moveLandscape()
471{ 509{
472 offset++; 510 offset++;
473 511
474 if ( offset >= segSize ) 512 if ( offset >= segSize )
475 { 513 {
476 offset = 0; 514 offset = 0;
477 for ( int i = 0 ; i < MAPSIZE-speed ; ++i ) 515 for ( int i = 0 ; i < MAPSIZE-speed ; ++i )
478 { 516 {
479 mapTop[i] = mapTop[i+speed]; 517 mapTop[i] = mapTop[i+speed];
480 mapBottom[i] = mapBottom[i+speed]; 518 mapBottom[i] = mapBottom[i+speed];
481 } 519 }
482 520
483 for ( int i = speed ; i > 0 ; --i ) 521 for ( int i = speed ; i > 0 ; --i )
484 setPoint( MAPSIZE-i ); 522 setPoint( MAPSIZE-i );
485 } 523 }
486 524
487 for ( int i = 0 ; i < BLOCKSIZE ; ++i ) 525 for ( int i = 0 ; i < BLOCKSIZE ; ++i )
488 { 526 {
489 if ( blocks[i].y() != -1 ) 527 if ( blocks[i].y() != -1 )
490 { 528 {
491 blocks[i].moveBy( -speed, 0 ); 529 blocks[i].moveBy( -speed, 0 );
492 if ( blocks[i].x() + blocks[i].width() < 0 ) 530 if ( blocks[i].x() + blocks[i].width() < 0 )
493 blocks[i].setY( -1 ); 531 blocks[i].setY( -1 );
494 } 532 }
495 } 533 }
496} 534}
497 535
498void SFCave :: addBlock() 536void SFCave :: addBlock()
499{ 537{
500 for ( int i = 0 ; i < BLOCKSIZE ; ++i ) 538 for ( int i = 0 ; i < BLOCKSIZE ; ++i )
501 { 539 {
502 if ( blocks[i].y() == -1 ) 540 if ( blocks[i].y() == -1 )
503 { 541 {
504 int x = sWidth; 542 int x = sWidth;
505 543
506 int y = mapTop[50] + (int)(nextInt(mapBottom[50] - mapTop[50] - blockHeight)); 544 int y = mapTop[50] + (int)(nextInt(mapBottom[50] - mapTop[50] - blockHeight));
507 545
508 blocks[i].setRect( x, y, blockWidth, blockHeight ); 546 blocks[i].setRect( x, y, blockWidth, blockHeight );
509 547
510 break; 548 break;
511 } 549 }
512 } 550 }
513} 551}
514 552
515void SFCave :: addGate() 553void SFCave :: addGate()
516{ 554{
517 for ( int i = 0 ; i < BLOCKSIZE ; ++i ) 555 for ( int i = 0 ; i < BLOCKSIZE ; ++i )
518 { 556 {
519 if ( blocks[i].y() == -1 ) 557 if ( blocks[i].y() == -1 )
520 { 558 {
521 int x1 = sWidth; 559 int x1 = sWidth;
522 int y1 = mapTop[50]; 560 int y1 = mapTop[50];
523 int b1Height = nextInt(mapBottom[50] - mapTop[50] - gapHeight); 561 int b1Height = nextInt(mapBottom[50] - mapTop[50] - gapHeight);
524 562
525 // See if height between last gate and this one is too big 563 // See if height between last gate and this one is too big
526 if ( b1Height - 200 > lastGateBottomY ) 564 if ( b1Height - 100 > lastGateBottomY )
527 b1Height -= 25; 565 b1Height -= 25;
528 else if ( b1Height + 200 < lastGateBottomY ) 566 else if ( b1Height + 100 < lastGateBottomY )
529 b1Height += 25; 567 b1Height += 25;
530 lastGateBottomY = b1Height; 568 lastGateBottomY = b1Height;
531 569
570
532 int x2 = sWidth; 571 int x2 = sWidth;
533 int y2 = y1 + b1Height + gapHeight; 572 int y2 = y1 + b1Height + gapHeight;
534 int b2Height = mapBottom[50] - y2; 573 int b2Height = mapBottom[50] - y2;
535 574
536 575
537 blocks[i].setRect( x1, y1, blockWidth, b1Height ); 576 blocks[i].setRect( x1, y1, blockWidth, b1Height );
538 blocks[i+1].setRect( x2, y2, blockWidth, b2Height ); 577 blocks[i+1].setRect( x2, y2, blockWidth, b2Height );
539 578
540 break; 579 break;
541 } 580 }
542 } 581 }
543} 582}
544 583
545void SFCave :: setPoint( int point ) 584void SFCave :: setPoint( int point )
546{ 585{
547 if ( nextInt(100) >= 80 ) 586 if ( nextInt(100) >= 80 )
548 dir *= -1; 587 dir *= -1;
549 588
550 mapTop[point] = mapTop[point-1] + (dir * nextInt( 5 ) ); 589 mapTop[point] = mapTop[point-1] + (dir * nextInt( 5 ) );
551 if ( mapTop[point] < 0 ) 590 if ( mapTop[point] < 0 )
552 { 591 {
553 mapTop[point] = 0; 592 mapTop[point] = 0;
554 dir *= -1; 593 dir *= -1;
555 } 594 }
556 else if ( mapTop[point] >= maxHeight ) 595 else if ( mapTop[point] >= maxHeight )
557 { 596 {
558 mapTop[point] = maxHeight; 597 mapTop[point] = maxHeight;
559 dir *= -1; 598 dir *= -1;
560 } 599 }
561 600
562// mapBottom[point] = sHeight - (maxHeight - mapBottom[point]); 601// mapBottom[point] = sHeight - (maxHeight - mapBottom[point]);
563 mapBottom[point] = sHeight - (maxHeight - mapTop[point]); 602 mapBottom[point] = sHeight - (maxHeight - mapTop[point]);
564} 603}
565 604
566void SFCave :: drawBoss() 605void SFCave :: drawBoss()
567{ 606{
568 offscreen->fill( Qt::black ); 607 offscreen->fill( Qt::black );
569 608
570 bitBlt( this, 0, 0, offscreen, 0, 0, sWidth, sHeight, Qt::CopyROP, true ); 609 bitBlt( this, 0, 0, offscreen, 0, 0, sWidth, sHeight, Qt::CopyROP, true );
571} 610}
572 611
573void SFCave :: draw() 612void SFCave :: draw()
574{ 613{
575 //printf( "Paint\n" ); 614 //printf( "Paint\n" );
576 offscreen->fill( Qt::black ); 615 offscreen->fill( Qt::black );
577 616
578 QPainter p( offscreen ); 617 QPainter p( offscreen );
579 QFontMetrics fm = p.fontMetrics(); 618 QFontMetrics fm = p.fontMetrics();
580 p.setPen( Qt::white ); 619 p.setPen( Qt::white );
581 620
582 for ( int i = 0 ; i < MAPSIZE -3; ++i ) 621 for ( int i = 0 ; i < MAPSIZE -3; ++i )
583 { 622 {
584 // Only display top landscape if not running FLY_GAME 623 // Only display top landscape if not running FLY_GAME
585 if ( CURRENT_GAME_TYPE != FLY_GAME ) 624 if ( CURRENT_GAME_TYPE != FLY_GAME )
586 p.drawLine( (i*segSize) - (offset*speed), mapTop[i], ((i+1)*segSize)-(offset*speed), mapTop[i+1] ); 625 p.drawLine( (i*segSize) - (offset*speed), mapTop[i], ((i+1)*segSize)-(offset*speed), mapTop[i+1] );
587 626
588 p.drawLine( (i*segSize) - (offset*speed), mapBottom[i], ((i+1)*segSize)-(offset*speed), mapBottom[i+1] ); 627 p.drawLine( (i*segSize) - (offset*speed), mapBottom[i], ((i+1)*segSize)-(offset*speed), mapBottom[i+1] );
589 628
590 if ( CURRENT_GAME_TYPE == FLY_GAME && showScoreZones ) 629 if ( CURRENT_GAME_TYPE == FLY_GAME && showScoreZones )
591 { 630 {
592 p.setPen( Qt::red ); 631 p.setPen( Qt::red );
593 p.drawLine( (i*segSize) - (offset*speed), mapBottom[i]-10, ((i+1)*segSize)-(offset*speed), mapBottom[i+1]-10 ); 632 p.drawLine( (i*segSize) - (offset*speed), mapBottom[i]-10, ((i+1)*segSize)-(offset*speed), mapBottom[i+1]-10 );
594 p.drawLine( (i*segSize) - (offset*speed), mapBottom[i]-20, ((i+1)*segSize)-(offset*speed), mapBottom[i+1]-20 ); 633 p.drawLine( (i*segSize) - (offset*speed), mapBottom[i]-20, ((i+1)*segSize)-(offset*speed), mapBottom[i+1]-20 );
595 p.drawLine( (i*segSize) - (offset*speed), mapBottom[i]-30, ((i+1)*segSize)-(offset*speed), mapBottom[i+1]-30 ); 634 p.drawLine( (i*segSize) - (offset*speed), mapBottom[i]-30, ((i+1)*segSize)-(offset*speed), mapBottom[i+1]-30 );
596 p.drawLine( (i*segSize) - (offset*speed), mapBottom[i]-40, ((i+1)*segSize)-(offset*speed), mapBottom[i+1]-40 ); 635 p.drawLine( (i*segSize) - (offset*speed), mapBottom[i]-40, ((i+1)*segSize)-(offset*speed), mapBottom[i+1]-40 );
597 p.setPen( Qt::white ); 636 p.setPen( Qt::white );
598 } 637 }
599 } 638 }
600 639
601 // Uncomment this to show user segment (usful for checking collision boundary with landscape 640 // Uncomment this to show user segment (usful for checking collision boundary with landscape
602// p.setPen( Qt::red ); 641// p.setPen( Qt::red );
603// p.drawLine( (11*segSize) - (offset*speed), 0, ((11)*segSize)-(offset*speed), sHeight ); 642// p.drawLine( (11*segSize) - (offset*speed), 0, ((11)*segSize)-(offset*speed), sHeight );
604// p.setPen( Qt::white ); 643// p.setPen( Qt::white );
605 644
606 // Draw user 645 // Draw user
607 p.drawRect( user ); 646 p.drawRect( user );
608 647
609 // Draw trails 648 // Draw trails
610 for ( int i = 0 ; i < TRAILSIZE ; ++i ) 649 for ( int i = 0 ; i < TRAILSIZE ; ++i )
611 if ( trail[i].x() >= 0 ) 650 if ( trail[i].x() >= 0 )
612 p.drawRect( trail[i].x(), trail[i].y(), 2, 2 ); 651 p.drawRect( trail[i].x(), trail[i].y(), 2, 2 );
613 652
614 // Draw blocks 653 // Draw blocks
615 for ( int i = 0 ; i < BLOCKSIZE ; ++i ) 654 for ( int i = 0 ; i < BLOCKSIZE ; ++i )
616 if ( blocks[i].y() != -1 ) 655 if ( blocks[i].y() != -1 )
617 { 656 {
618 p.fillRect( blocks[i], Qt::black ); 657 p.fillRect( blocks[i], Qt::black );
619 p.drawRect( blocks[i] ); 658 p.drawRect( blocks[i] );
620 } 659 }
621 660
622 // draw score 661 // draw score
623 QString s; 662 QString s;
624 s.sprintf( "score %06d high score %06d", score, highestScore[currentGameType][currentGameDifficulty] ); 663 s.sprintf( "score %06d high score %06d", score, highestScore[currentGameType][currentGameDifficulty] );
625 p.drawText( 5, 10, s ); 664 p.drawText( 5, 10, s );
626 665
627 666
628 if ( state == STATE_CRASHING || state == STATE_CRASHED ) 667 if ( state == STATE_CRASHING || state == STATE_CRASHED )
629 { 668 {
630 // add next crash line 669 // add next crash line
631 670
632 if ( crashLineLength != -1 ) 671 if ( crashLineLength != -1 )
633 { 672 {
634 for ( int i = 0 ; i < 36 ; ++i ) 673 for ( int i = 0 ; i < 36 ; ++i )
635 { 674 {
636 int x = (int)(user.x() + (crashLineLength+nextInt(10)) * cos( (M_PI/180) * (10.0 * i) ) ); 675 int x = (int)(user.x() + (crashLineLength+nextInt(10)) * cos( (M_PI/180) * (10.0 * i) ) );
637 int y = (int)(user.y() + (crashLineLength+nextInt(10)) * sin( (M_PI/180) * (10.0 * i) ) ); p.drawLine( user.x(), user.y(), x, y ); 676 int y = (int)(user.y() + (crashLineLength+nextInt(10)) * sin( (M_PI/180) * (10.0 * i) ) ); p.drawLine( user.x(), user.y(), x, y );
638 } 677 }
639 } 678 }
640 679
641 if ( state == STATE_CRASHING && crashLineLength >= 15 ) //|| crashLineLength == -1) ) 680 if ( state == STATE_CRASHING && crashLineLength >= 15 ) //|| crashLineLength == -1) )
642 state = STATE_CRASHED; 681 state = STATE_CRASHED;
643 682
644 if ( state == STATE_CRASHED ) 683 if ( state == STATE_CRASHED )
645 { 684 {
646 QString text = "Press up or down to start"; 685 QString text = "Press up or down to start";
647 p.drawText( (sWidth/2) - (fm.width( text )/2), 140, text ); 686 p.drawText( (sWidth/2) - (fm.width( text )/2), 140, text );
648 687
649 text = "or press OK for menu"; 688 text = "or press OK for menu";
650 p.drawText( (sWidth/2) - (fm.width( text )/2), 155, text ); 689 p.drawText( (sWidth/2) - (fm.width( text )/2), 155, text );
651 } 690 }
652 else 691 else
653 crashLineLength ++; 692 crashLineLength ++;
654 } 693 }
655 694
656 p.end(); 695 p.end();
657 bitBlt( this, 0, 0, offscreen, 0, 0, sWidth, sHeight, Qt::CopyROP, true ); 696 bitBlt( this, 0, 0, offscreen, 0, 0, sWidth, sHeight, Qt::CopyROP, true );
658 //printf( "endpaint\n" ); 697 //printf( "endpaint\n" );
659} 698}
660 699
661void SFCave :: handleKeys() 700void SFCave :: handleKeys()
662{ 701{
663 // Find enpty trail and move others 702 // Find enpty trail and move others
664 bool done = false; 703 bool done = false;
665 for ( int i = 0 ; i < TRAILSIZE ; ++i ) 704 for ( int i = 0 ; i < TRAILSIZE ; ++i )
666 { 705 {
667 if ( trail[i].x() < 0 ) 706 if ( trail[i].x() < 0 )
668 { 707 {
669 if ( !done ) 708 if ( !done )
670 { 709 {
671 trail[i].setX( user.x() - 5 ); 710 trail[i].setX( user.x() - 5 );
672 trail[i].setY( user.y() ); 711 trail[i].setY( user.y() );
673 done = true; 712 done = true;
674 } 713 }
675 } 714 }
676 else 715 else
677 { 716 {
678 trail[i].setX( trail[i].x() - (2) ); 717 trail[i].setX( trail[i].x() - (2) );
679 } 718 }
680 } 719 }
681 720
682 if ( speed <= 3 ) 721 if ( speed <= 3 )
683 { 722 {
684 if ( press ) 723 if ( press )
685 thrust -= thrustUp; 724 thrust -= thrustUp;
686 else 725 else
687 thrust += noThrust; 726 thrust += noThrust;
688 727
689 if ( thrust > maxDownThrust ) 728 if ( thrust > maxDownThrust )
690 thrust = maxDownThrust; 729 thrust = maxDownThrust;
691 else if ( thrust < maxUpThrust ) 730 else if ( thrust < maxUpThrust )
692 thrust = maxUpThrust; 731 thrust = maxUpThrust;
693 } 732 }
694 else 733 else
695 { 734 {
696 if ( press ) 735 if ( press )
697 thrust -= 0.5; 736 thrust -= 0.5;
698 else 737 else
699 thrust += 0.8; 738 thrust += 0.8;
700 739
701 if ( thrust > 5.0 ) 740 if ( thrust > 5.0 )
702 thrust = 5.0; 741 thrust = 5.0;
703 else if ( thrust < -3.5 ) 742 else if ( thrust < -3.5 )
704 thrust = -3.5; 743 thrust = -3.5;
705 } 744 }
706 user.moveBy( 0, (int)thrust ); 745 user.moveBy( 0, (int)thrust );
707} 746}
708 747
709void SFCave :: keyPressEvent( QKeyEvent *e ) 748void SFCave :: keyPressEvent( QKeyEvent *e )
710{ 749{
711 if ( state == STATE_MENU ) 750 if ( state == STATE_MENU )
712 { 751 {
713 switch( e->key() ) 752 switch( e->key() )
714 { 753 {
715 case Qt::Key_Down: 754 case Qt::Key_Down:
716 currentMenuOption[currentMenuNr] ++; 755 currentMenuOption[currentMenuNr] ++;
717 if ( menuOptions[currentMenuNr][currentMenuOption[currentMenuNr]] == "" ) 756 if ( menuOptions[currentMenuNr][currentMenuOption[currentMenuNr]] == "" )
718 currentMenuOption[currentMenuNr] = 0; 757 currentMenuOption[currentMenuNr] = 0;
719 break; 758 break;
720 case Qt::Key_Up: 759 case Qt::Key_Up:
721 currentMenuOption[currentMenuNr] --; 760 currentMenuOption[currentMenuNr] --;
722 if ( currentMenuOption[currentMenuNr] < 0 ) 761 if ( currentMenuOption[currentMenuNr] < 0 )
723 currentMenuOption[currentMenuNr] = nrMenuOptions[currentMenuNr]-1; 762 currentMenuOption[currentMenuNr] = nrMenuOptions[currentMenuNr]-1;
724 break; 763 break;
725 764
726 case Qt::Key_Left: 765 case Qt::Key_Left:
727 if ( currentMenuNr == MENU_OPTIONS_MENU ) 766 if ( currentMenuNr == MENU_OPTIONS_MENU )
728 { 767 {
729 if ( currentMenuOption[currentMenuNr] == MENU_GAME_TYPE ) 768 if ( currentMenuOption[currentMenuNr] == MENU_GAME_TYPE )
730 { 769 {
731 currentGameType --; 770 currentGameType --;
732 if ( currentGameType < 0 ) 771 if ( currentGameType < 0 )
733 currentGameType = NR_GAME_TYPES - 1; 772 currentGameType = NR_GAME_TYPES - 1;
734 } 773 }
735 else if ( currentMenuOption[currentMenuNr] == MENU_GAME_DIFFICULTY ) 774 else if ( currentMenuOption[currentMenuNr] == MENU_GAME_DIFFICULTY )
736 { 775 {
737 currentGameDifficulty --; 776 currentGameDifficulty --;
738 if ( currentGameDifficulty < 0 ) 777 if ( currentGameDifficulty < 0 )
739 currentGameDifficulty = NR_GAME_DIFFICULTIES - 1; 778 currentGameDifficulty = NR_GAME_DIFFICULTIES - 1;
740 } 779 }
741 } 780 }
742 break; 781 break;
743 782
744 case Qt::Key_Right: 783 case Qt::Key_Right:
745 if ( currentMenuNr == MENU_OPTIONS_MENU ) 784 if ( currentMenuNr == MENU_OPTIONS_MENU )
746 { 785 {
747 if ( currentMenuOption[currentMenuNr] == MENU_GAME_TYPE ) 786 if ( currentMenuOption[currentMenuNr] == MENU_GAME_TYPE )
748 { 787 {
749 currentGameType ++; 788 currentGameType ++;
750 if ( currentGameType == NR_GAME_TYPES ) 789 if ( currentGameType == NR_GAME_TYPES )
751 currentGameType = 0; 790 currentGameType = 0;
752 } 791 }
753 else if ( currentMenuOption[currentMenuNr] == MENU_GAME_DIFFICULTY ) 792 else if ( currentMenuOption[currentMenuNr] == MENU_GAME_DIFFICULTY )
754 { 793 {
755 currentGameDifficulty ++; 794 currentGameDifficulty ++;
756 if ( currentGameDifficulty == NR_GAME_DIFFICULTIES ) 795 if ( currentGameDifficulty == NR_GAME_DIFFICULTIES )
757 currentGameDifficulty = 0; 796 currentGameDifficulty = 0;
758 } 797 }
759 } 798 }
760 break; 799 break;
761 800
762 case Qt::Key_Space: 801 case Qt::Key_Space:
763 case Qt::Key_Return: 802 case Qt::Key_Return:
764 case Qt::Key_Enter: 803 case Qt::Key_Enter:
765 dealWithMenuSelection(); 804 dealWithMenuSelection();
766 break; 805 break;
767 } 806 }
768 } 807 }
769 else 808 else
770 { 809 {
771 switch( e->key() ) 810 switch( e->key() )
772 { 811 {
773 case Qt::Key_Up: 812 case Qt::Key_Up:
774 case Qt::Key_F9: 813 case Qt::Key_F9:
775 case Qt::Key_Space: 814 case Qt::Key_Space:
776 press = true; 815 if ( !press )
816 {
817 press = true;
818 replayList.append( new int( nrFrames ) );
819 }
777 break; 820 break;
778 case Qt::Key_M: 821 case Qt::Key_M:
779 case Qt::Key_Return: 822 case Qt::Key_Return:
780 case Qt::Key_Enter: 823 case Qt::Key_Enter:
781 if ( state == STATE_CRASHED ) 824 if ( state == STATE_CRASHED )
782 state = STATE_MENU; 825 state = STATE_MENU;
783 break; 826 break;
784 827
785 case Qt::Key_Z: 828 case Qt::Key_Z:
786 showScoreZones = !showScoreZones; 829 showScoreZones = !showScoreZones;
787 break; 830 break;
788 831
789 default: 832 default:
790 e->ignore(); 833 e->ignore();
791 break; 834 break;
792 } 835 }
793 } 836 }
794} 837}
795 838
796void SFCave :: keyReleaseEvent( QKeyEvent *e ) 839void SFCave :: keyReleaseEvent( QKeyEvent *e )
797{ 840{
798 if ( state == STATE_MENU ) 841 if ( state == STATE_MENU )
799 { 842 {
800 } 843 }
801 else 844 else
802 { 845 {
803 switch( e->key() ) 846 switch( e->key() )
804 { 847 {
805 case Qt::Key_F9: 848 case Qt::Key_F9:
806 case Qt::Key_Space: 849 case Qt::Key_Space:
807 press = false; 850 case Qt::Key_Up:
851 if ( press )
852 {
853 press = false;
854
855 replayList.append( new int( nrFrames ) );
856 }
808 break; 857 break;
809 858
810 case Qt::Key_Up:
811 press = false;
812
813 case Qt::Key_R: 859 case Qt::Key_R:
814 case Qt::Key_Down:
815 if ( state == STATE_CRASHED ) 860 if ( state == STATE_CRASHED )
816 { 861 {
817 state = STATE_NEWGAME; 862 state = STATE_REPLAY;
818 } 863 }
819 else
820 movel = true;
821 break; 864 break;
822 865
866 case Qt::Key_Down:
867 if ( state == STATE_CRASHED )
868 state = STATE_NEWGAME;
869 break;
823 default: 870 default:
824 e->ignore(); 871 e->ignore();
825 break; 872 break;
826 } 873 }
827 } 874 }
828 875
829} 876}
830 877
831void SFCave :: displayMenu() 878void SFCave :: displayMenu()
832{ 879{
833 offscreen->fill( Qt::black ); 880 offscreen->fill( Qt::black );
834 881
835 QPainter p( offscreen ); 882 QPainter p( offscreen );
836 p.setPen( Qt::white ); 883 p.setPen( Qt::white );
837 884
838 QFont f( "Helvetica", 16 ); 885 QFont f( "Helvetica", 16 );
839 p.setFont( f ); 886 p.setFont( f );
840 887
841 QFontMetrics fm = p.fontMetrics(); 888 QFontMetrics fm = p.fontMetrics();
842 889
843 QString text = "SFCave"; 890 QString text = "SFCave";
844 p.drawText( (sWidth/2) - (fm.width( text )/2), 60, text ); 891 p.drawText( (sWidth/2) - (fm.width( text )/2), 60, text );
845 892
846 text = "Written by Andy Qua"; 893 text = "Written by Andy Qua";
847 p.drawText( (sWidth/2) - (fm.width( text )/2), 85, text ); 894 p.drawText( (sWidth/2) - (fm.width( text )/2), 85, text );
848 895
849 // Draw options 896 // Draw options
850 int pos = 170; 897 int pos = 170;
851 for ( int i = 0 ; menuOptions[currentMenuNr][i] != "" ; ++i, pos += 25 ) 898 for ( int i = 0 ; menuOptions[currentMenuNr][i] != "" ; ++i, pos += 25 )
852 { 899 {
853 if ( currentMenuOption[currentMenuNr] == i ) 900 if ( currentMenuOption[currentMenuNr] == i )
854 p.setPen( Qt::yellow ); 901 p.setPen( Qt::yellow );
855 else 902 else
856 p.setPen( Qt::white ); 903 p.setPen( Qt::white );
857 904
858 QString text; 905 QString text;
859 if ( menuOptions[currentMenuNr][i].find( "%s" ) != -1 ) 906 if ( menuOptions[currentMenuNr][i].find( "%s" ) != -1 )
860 { 907 {
861 QString val; 908 QString val;
862 if ( i == MENU_GAME_TYPE ) 909 if ( i == MENU_GAME_TYPE )
863 val = gameTypes[currentGameType]; 910 val = gameTypes[currentGameType];
864 else 911 else
865 val = dificultyOption[currentGameDifficulty]; 912 val = dificultyOption[currentGameDifficulty];
866 913
867 text.sprintf( (const char *)menuOptions[currentMenuNr][i], (const char *)val ); 914 text.sprintf( (const char *)menuOptions[currentMenuNr][i], (const char *)val );
868 } 915 }
869 else 916 else
870 text = menuOptions[currentMenuNr][i]; 917 text = menuOptions[currentMenuNr][i];
871 918
872 p.drawText( (sWidth/2) - (fm.width( text )/2), pos, text ); 919 p.drawText( (sWidth/2) - (fm.width( text )/2), pos, text );
873 } 920 }
874 921
875 p.end(); 922 p.end();
876 bitBlt( this, 0, 0, offscreen, 0, 0, sWidth, sHeight, Qt::CopyROP, true ); 923 bitBlt( this, 0, 0, offscreen, 0, 0, sWidth, sHeight, Qt::CopyROP, true );
877} 924}
878 925
879void SFCave :: dealWithMenuSelection() 926void SFCave :: dealWithMenuSelection()
880{ 927{
881 switch( currentMenuNr ) 928 switch( currentMenuNr )
882 { 929 {
883 case MENU_MAIN_MENU: 930 case MENU_MAIN_MENU:
884 { 931 {
885 switch( currentMenuOption[currentMenuNr] ) 932 switch( currentMenuOption[currentMenuNr] )
886 { 933 {
887 case MENU_START_GAME: 934 case MENU_START_GAME:
888 state = STATE_NEWGAME; 935 state = STATE_NEWGAME;
889 break; 936 break;
890 937
891 case MENU_OPTIONS: 938 case MENU_OPTIONS:
892 currentMenuNr = MENU_OPTIONS_MENU; 939 currentMenuNr = MENU_OPTIONS_MENU;
893 currentMenuOption[currentMenuNr] = 0; 940 currentMenuOption[currentMenuNr] = 0;
894 break; 941 break;
895 942
896 case MENU_HELP: 943 case MENU_HELP:
897 { 944 {
898 // Display Help Menu 945 // Display Help Menu
899 HelpWindow *dlg = new HelpWindow( this ); 946 HelpWindow *dlg = new HelpWindow( this );
900 dlg->exec(); 947 dlg->exec();
901 delete dlg; 948 delete dlg;
902 break; 949 break;
903 } 950 }
904 951
905 case MENU_QUIT: 952 case MENU_QUIT:
906 QApplication::exit(); 953 QApplication::exit();
907 break; 954 break;
908 } 955 }
909 956
910 break; 957 break;
911 } 958 }
912 959
913 case MENU_OPTIONS_MENU: 960 case MENU_OPTIONS_MENU:
914 { 961 {
915 switch( currentMenuOption[currentMenuNr] ) 962 switch( currentMenuOption[currentMenuNr] )
916 { 963 {
917 case MENU_GAME_TYPE: 964 case MENU_GAME_TYPE:
918 break; 965 break;
919 966
920 case MENU_GAME_DIFFICULTY: 967 case MENU_GAME_DIFFICULTY:
921 break; 968 break;
922 969
923 case MENU_CLEAR_HIGHSCORES: 970 case MENU_CLEAR_HIGHSCORES:
924 for ( int i = 0 ; i < 3 ; ++i ) 971 for ( int i = 0 ; i < 3 ; ++i )
925 highestScore[currentGameType][i] = 0; 972 highestScore[currentGameType][i] = 0;
926 break; 973 break;
927 974
928 case MENU_BACK: 975 case MENU_BACK:
929 currentMenuNr = MENU_MAIN_MENU; 976 currentMenuNr = MENU_MAIN_MENU;
930 977
931#ifdef QWS 978#ifdef QWS
932 Config cfg( "sfcave" ); 979 Config cfg( "sfcave" );
933 cfg.setGroup( "settings" ); 980 cfg.setGroup( "settings" );
934 cfg.writeEntry( "difficulty", currentGameDifficulty ); 981 cfg.writeEntry( "difficulty", currentGameDifficulty );
935 cfg.writeEntry( "gameType", currentGameType ); 982 cfg.writeEntry( "gameType", currentGameType );
936#endif 983#endif
937 break; 984 break;
938 } 985 }
939 986
940 break; 987 break;
941 } 988 }
942 } 989 }
943} 990}
944 991
945void SFCave :: saveScore() 992void SFCave :: saveScore()
946{ 993{
947#ifdef QWS 994#ifdef QWS
948 Config cfg( "sfcave" ); 995 Config cfg( "sfcave" );
949 cfg.setGroup( "settings" ); 996 cfg.setGroup( "settings" );
950 QString key = "highScore_"; 997 QString key = "highScore_";
951 998
952 cfg.writeEntry( key + gameTypes[currentGameType] + "_" + dificultyOption[currentGameDifficulty], highestScore[currentGameType][currentGameDifficulty] ); 999 cfg.writeEntry( key + gameTypes[currentGameType] + "_" + dificultyOption[currentGameDifficulty], highestScore[currentGameType][currentGameDifficulty] );
953 key += CURRENT_GAME_TYPE; 1000 key += CURRENT_GAME_TYPE;
954 cfg.writeEntry( key, highestScore[currentGameType] ); 1001 cfg.writeEntry( key, highestScore[currentGameType] );
955#endif 1002#endif
956} 1003}
diff --git a/noncore/games/sfcave/sfcave.h b/noncore/games/sfcave/sfcave.h
index 69a0e13..0d9a626 100644
--- a/noncore/games/sfcave/sfcave.h
+++ b/noncore/games/sfcave/sfcave.h
@@ -1,108 +1,118 @@
1#include <qmainwindow.h> 1#include <qmainwindow.h>
2#include <qpainter.h> 2#include <qpainter.h>
3#include <qpixmap.h> 3#include <qpixmap.h>
4#include <qpoint.h> 4#include <qpoint.h>
5#include <qrect.h> 5#include <qrect.h>
6#include <qtimer.h> 6#include <qtimer.h>
7#include <qlist.h>
7 8
8 9#include "random.h"
9 10
10#define MAPSIZE 52 11#define MAPSIZE 52
11#define BLOCKSIZE 6 12#define BLOCKSIZE 6
12#define TRAILSIZE 30 13#define TRAILSIZE 30
13 14
15
16
14class SFCave : public QMainWindow 17class SFCave : public QMainWindow
15{ 18{
16Q_OBJECT 19Q_OBJECT
17 20
18public: 21public:
19 int sWidth; 22 int sWidth;
20 int sHeight; 23 int sHeight;
21 int segSize; 24 int segSize;
22 25
26 int currentSeed;
27
28 QList<int> replayList;
29 QListIterator<int> *replayIt;
30 bool replay;
31
23 int blockWidth; 32 int blockWidth;
24 int blockHeight; 33 int blockHeight;
25 int gapHeight; 34 int gapHeight;
26 int state; 35 int state;
27 int prevState; 36 int prevState;
28 int speed; 37 int speed;
29 int crashLineLength; 38 int crashLineLength;
30 39
31 static double UpThrustVals[3][3]; 40 static double UpThrustVals[3][3];
32 static double DownThrustVals[3][3]; 41 static double DownThrustVals[3][3];
33 static double MaxUpThrustVals[3][3]; 42 static double MaxUpThrustVals[3][3];
34 static double MaxDownThrustVals[3][3]; 43 static double MaxDownThrustVals[3][3];
35 static int initialGateGaps[]; 44 static int initialGateGaps[];
36 45
37 double thrustUp; 46 double thrustUp;
38 double noThrust; 47 double noThrust;
39 double maxUpThrust; 48 double maxUpThrust;
40 double maxDownThrust; 49 double maxDownThrust;
41 50
42 int gateDistance; 51 int gateDistance;
43 int nextGate; 52 int nextGate;
44 int lastGateBottomY; 53 int lastGateBottomY;
45 54
46 static QString menuOptions[2][5]; 55 static QString menuOptions[2][5];
47 int currentMenuNr; 56 int currentMenuNr;
48 static int nrMenuOptions[2]; 57 static int nrMenuOptions[2];
49 static int currentMenuOption[2]; 58 static int currentMenuOption[2];
50 59
51 static QString dificultyOption[3]; 60 static QString dificultyOption[3];
52 static QString gameTypes[3]; 61 static QString gameTypes[3];
53 int currentGameType; 62 int currentGameType;
54 int currentGameDifficulty; 63 int currentGameDifficulty;
55 64
56 QPixmap *offscreen; 65 QPixmap *offscreen;
57 QTimer *gameTimer; 66 QTimer *gameTimer;
58 67
59 int score; 68 int score;
60 int highestScore[3][3]; 69 int highestScore[3][3];
61 70
62 int mapTop[MAPSIZE]; 71 int mapTop[MAPSIZE];
63 int mapBottom[MAPSIZE]; 72 int mapBottom[MAPSIZE];
64 QRect blocks[BLOCKSIZE]; 73 QRect blocks[BLOCKSIZE];
65 QRect user; 74 QRect user;
66 QPoint trail[TRAILSIZE]; 75 QPoint trail[TRAILSIZE];
67 76
68 int offset; 77 int offset;
69 int maxHeight; 78 int maxHeight;
70 int nrFrames; 79 int nrFrames;
71 int dir; 80 int dir;
72 81
73 bool showScoreZones; 82 bool showScoreZones;
74 83
75 bool press; 84 bool press;
76 double thrust; 85 double thrust;
77 bool running; 86 bool running;
78 87
79 SFCave( int speed = 3, QWidget *p = 0, char *name = 0 ); 88 SFCave( int speed = 3, QWidget *p = 0, char *name = 0 );
80 ~SFCave(); 89 ~SFCave();
81 void start(); 90 void start();
91 void setSeed( int seed );
82 int nextInt( int range ); 92 int nextInt( int range );
83 void setUp(); 93 void setUp();
84 void handleGameSFCave(); 94 void handleGameSFCave();
85 void handleGameGates(); 95 void handleGameGates();
86 void handleGameFly(); 96 void handleGameFly();
87 bool checkFlyGameCollision(); 97 bool checkFlyGameCollision();
88 void moveFlyGameLandscape(); 98 void moveFlyGameLandscape();
89 void setFlyPoint( int point ); 99 void setFlyPoint( int point );
90 bool checkCollision(); 100 bool checkCollision();
91 void moveLandscape(); 101 void moveLandscape();
92 void addBlock(); 102 void addBlock();
93 void addGate(); 103 void addGate();
94 void setPoint( int point ); 104 void setPoint( int point );
95 void drawBoss(); 105 void drawBoss();
96 void draw(); 106 void draw();
97 void handleKeys(); 107 void handleKeys();
98 108
99 void displayMenu(); 109 void displayMenu();
100 void dealWithMenuSelection(); 110 void dealWithMenuSelection();
101 111
102 void keyPressEvent( QKeyEvent *e ); 112 void keyPressEvent( QKeyEvent *e );
103 void keyReleaseEvent( QKeyEvent *e ); 113 void keyReleaseEvent( QKeyEvent *e );
104 void saveScore(); 114 void saveScore();
105 115
106private slots: 116private slots:
107 void run(); 117 void run();
108}; 118};
diff --git a/noncore/games/sfcave/sfcave.pro b/noncore/games/sfcave/sfcave.pro
index f4b9e5d..5f49330 100644
--- a/noncore/games/sfcave/sfcave.pro
+++ b/noncore/games/sfcave/sfcave.pro
@@ -1,9 +1,9 @@
1 TEMPLATE= app 1 TEMPLATE= app
2 CONFIG += qt warn_on release 2 CONFIG += qt warn_on release
3 DESTDIR = $(OPIEDIR)/bin 3 DESTDIR = $(OPIEDIR)/bin
4 SOURCES = sfcave.cpp helpwindow.cpp 4 SOURCES = sfcave.cpp helpwindow.cpp random.cpp
5 HEADERS = sfcave.h helpwindow.h 5 HEADERS = sfcave.h helpwindow.h random.h
6 TARGET = sfcave 6 TARGET = sfcave
7 INCLUDEPATH += $(OPIEDIR)/include 7 INCLUDEPATH += $(OPIEDIR)/include
8 DEPENDPATH+= $(OPIEDIR)/include 8 DEPENDPATH+= $(OPIEDIR)/include
9LIBS += -lqpe 9LIBS += -lqpe