static float jump_p[3]; /* Jump destination */
static float fade_k = 0.0; /* Fade in/out level */
static float fade_d = 0.0; /* Fade in/out direction */
-static int ball_b = 0; /* Is the ball a bonus ball? */
+
+/*---------------------------------------------------------------------------*/
static int grow = 0; /* Should the ball be changing size? */
static float grow_orig = 0; /* the original ball size */
#define GROW_BIG 1.5f /* large factor */
#define GROW_SMALL 0.5f /* small factor */
-/*---------------------------------------------------------------------------*/
+static int grow_state = 0; /* Current state (values -1, 0, +1) */
-static void grow_set(const struct s_file *fp, int type)
-{
+static void grow_init(const struct s_file *fp, int type)
+{
if (!got_orig)
{
- grow_orig = fp->uv->r;
- grow_goal = grow_orig;
- grow_strt = grow_orig;
- got_orig = 1;
+ grow_orig = fp->uv->r;
+ grow_goal = grow_orig;
+ grow_strt = grow_orig;
+
+ grow_state = 0;
+
+ got_orig = 1;
}
if (type == ITEM_SHRINK)
{
audio_play(AUD_SHRINK, 1.f);
- if (grow_goal == grow_orig * GROW_SMALL)
- return;
- else if (grow_goal == grow_orig * GROW_BIG)
+ switch (grow_state)
{
+ case -1:
+ break;
+
+ case 0:
+ grow_goal = grow_orig * GROW_SMALL;
+ grow_state = -1;
grow = 1;
+ break;
+
+ case +1:
grow_goal = grow_orig;
- }
- else
- {
- grow_goal = grow_orig * GROW_SMALL;
+ grow_state = 0;
grow = 1;
+ break;
}
}
- if (type == ITEM_GROW)
+ else if (type == ITEM_GROW)
{
audio_play(AUD_GROW, 1.f);
- if (grow_goal == grow_orig * GROW_BIG)
- return;
- else if (grow_goal == grow_orig * GROW_SMALL)
+ switch (grow_state)
{
- grow = 1;
+ case -1:
grow_goal = grow_orig;
- }
- else
- {
+ grow_state = 0;
+ grow = 1;
+ break;
+
+ case 0:
grow_goal = grow_orig * GROW_BIG;
+ grow_state = +1;
grow = 1;
+ break;
+
+ case +1:
+ break;
}
}
}
}
-static void grow_ball(const struct s_file *fp, float dt)
+static void grow_step(const struct s_file *fp, float dt)
{
float dr;
+ if (!grow)
+ return;
+
/* Calculate new size based on how long since you touched the coin... */
grow_t += dt;
fp->uv->r = dr;
}
+/*---------------------------------------------------------------------------*/
+
static void view_init(void)
{
view_a = 0.f;
/* Initialize ball size tracking... */
got_orig = 0;
+ grow = 0;
return game_state;
}
fp->uv[0].r);
glColor4fv(c);
-
- ball_draw(ball_b);
+ ball_draw();
}
glPopMatrix();
}
float r = 360.f * SDL_GetTicks() / 1000.f;
int hi;
- /* FIXME: Draw items of different types in one pass. */
+ /* FIXME: Draw items of different types in one pass? */
- item_push();
- item_push_text(ITEM_COIN);
+ item_push(ITEM_COIN);
{
for (hi = 0; hi < fp->hc; hi++)
}
item_pull();
- item_push();
- item_push_text(ITEM_SHRINK);
+ item_push(ITEM_SHRINK);
{
for (hi = 0; hi < fp->hc; hi++)
}
item_pull();
- item_push();
- item_push_text(ITEM_GROW);
+ item_push(ITEM_GROW);
{
for (hi = 0; hi < fp->hc; hi++)
fp->zv[zi].p[1],
fp->zv[zi].p[2]);
- part_draw_goal(rx, ry, fp->zv[zi].r, goal_k, fp->zv[zi].c);
+ part_draw_goal(rx, ry, fp->zv[zi].r, goal_k);
glScalef(fp->zv[zi].r, goal_k, fp->zv[zi].r);
goal_draw();
{
if (fp->xv[xi].i)
continue;
+
glPushMatrix();
{
glTranslatef(fp->xv[xi].p[0],
static void game_draw_light(void)
{
const float light_p[2][4] = {
- { -8.0f, +32.0f, -8.0f, 1.0f },
- { +8.0f, +32.0f, +8.0f, 1.0f },
+ { -8.0f, +32.0f, -8.0f, 0.0f },
+ { +8.0f, +32.0f, +8.0f, 0.0f },
};
const float light_c[2][4] = {
{ 1.0f, 0.8f, 0.8f, 1.0f },
sol_draw(&file);
- if (config_get_d(CONFIG_SHADOW))
+ if (pose == 0 && config_get_d(CONFIG_SHADOW))
{
shad_draw_set(ball_p, ball_r);
sol_shad(&file);
}
}
-static int game_update_state(int *state_value)
+static int game_update_state(int bt)
{
struct s_file *fp = &file;
struct s_goal *zp;
float p[3];
float c[3];
- int bt = state_value != NULL;
-
/* Test for an item. */
if (bt && (hp = sol_item_test(fp, p, COIN_RADIUS)))
{
item_color(hp, c);
part_burst(p, c);
- grow_set(fp, hp->t);
+ grow_init(fp, hp->t);
if (hp->t == ITEM_COIN)
{
if (bt && goal_c == 0 && (zp = sol_goal_test(fp, p, 0)))
{
- *state_value = zp->s;
audio_play(AUD_GOAL, 1.0f);
- return zp->c ? GAME_SPEC : GAME_GOAL;
+ return GAME_GOAL;
}
/* Test for time-out. */
* graphics frame rate.
*/
-int game_step(const float g[3], float dt, int *state_value)
+int game_step(const float g[3], float dt, int bt)
{
struct s_file *fp = &file;
game_rz = game_iz;
}
- if (grow)
- grow_ball(fp, dt);
+ grow_step(fp, dt);
game_update_grav(h, g);
part_step(h, t);
game_step_fade(dt);
game_update_view(dt);
- game_update_time(dt, state_value != NULL);
+ game_update_time(dt, bt);
- return game_update_state(state_value);
+ return game_update_state(bt);
}
return GAME_NONE;
}