nu aber...
This commit is contained in:
parent
ab08ab3fa2
commit
68dee06285
12 changed files with 44 additions and 46 deletions
10
games/breakout/Makefile
Normal file
10
games/breakout/Makefile
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
TARGET =
|
||||||
|
TOPDIR = ../..
|
||||||
|
|
||||||
|
include $(TOPDIR)/defaults.mk
|
||||||
|
|
||||||
|
ifeq ($(GAME_BREAKOUT),y)
|
||||||
|
SRC = breakout.c playfield.c rebound.c score.c level.c ball.c messages.c
|
||||||
|
endif
|
||||||
|
|
||||||
|
include $(TOPDIR)/rules.mk
|
|
@ -75,6 +75,7 @@ void ball_think (ball_t *b)
|
||||||
ball_die (b);
|
ball_die (b);
|
||||||
|
|
||||||
bounce = check_bounce (proj_x, b->y / 256);
|
bounce = check_bounce (proj_x, b->y / 256);
|
||||||
|
|
||||||
if (bounce & BOUNCE_UNDEF)
|
if (bounce & BOUNCE_UNDEF)
|
||||||
bounce = (BOUNCE_X | bounce) & (BOUNCE_X | BOUNCE_Y);
|
bounce = (BOUNCE_X | bounce) & (BOUNCE_X | BOUNCE_Y);
|
||||||
|
|
||||||
|
@ -98,7 +99,7 @@ void ball_think (ball_t *b)
|
||||||
#if BOUNCE_SLOWDOWN
|
#if BOUNCE_SLOWDOWN
|
||||||
if (bounce & BOUNCE_BRICK)
|
if (bounce & BOUNCE_BRICK)
|
||||||
{
|
{
|
||||||
if (b->dir_y < -BALL_MINSPEED)
|
if (b->dir_y < - BALL_MINSPEED)
|
||||||
{
|
{
|
||||||
b->dir_y += BOUNCE_SLOWDOWN;
|
b->dir_y += BOUNCE_SLOWDOWN;
|
||||||
} else if (b->dir_y > BALL_MINSPEED)
|
} else if (b->dir_y > BALL_MINSPEED)
|
||||||
|
@ -106,7 +107,7 @@ void ball_think (ball_t *b)
|
||||||
b->dir_y -= BOUNCE_SLOWDOWN;
|
b->dir_y -= BOUNCE_SLOWDOWN;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (b->dir_x < -BALL_MINSPEED)
|
if (b->dir_x < - BALL_MINSPEED)
|
||||||
{
|
{
|
||||||
b->dir_x += BOUNCE_SLOWDOWN;
|
b->dir_x += BOUNCE_SLOWDOWN;
|
||||||
} else if (b->dir_y > BALL_MINSPEED)
|
} else if (b->dir_y > BALL_MINSPEED)
|
||||||
|
@ -124,23 +125,18 @@ void ball_think (ball_t *b)
|
||||||
if (b->dir_x > BALL_MAXSPEED)
|
if (b->dir_x > BALL_MAXSPEED)
|
||||||
b->dir_x = BALL_MAXSPEED;
|
b->dir_x = BALL_MAXSPEED;
|
||||||
|
|
||||||
if (b->dir_x < - BALL_MAXSPEED)
|
if (b->dir_x < -BALL_MAXSPEED)
|
||||||
b->dir_x = - BALL_MAXSPEED;
|
b->dir_x = -BALL_MAXSPEED;
|
||||||
|
|
||||||
if (b->dir_y > BALL_MAXSPEED)
|
if (b->dir_y > BALL_MAXSPEED)
|
||||||
b->dir_y = BALL_MAXSPEED;
|
b->dir_y = BALL_MAXSPEED;
|
||||||
|
|
||||||
if (b->dir_y < - BALL_MAXSPEED)
|
if (b->dir_y < -BALL_MAXSPEED)
|
||||||
b->dir_y = - BALL_MAXSPEED;
|
b->dir_y = -BALL_MAXSPEED;
|
||||||
|
|
||||||
|
|
||||||
b->y += b->dir_y;
|
b->y += b->dir_y;
|
||||||
b->x += b->dir_x;
|
b->x += b->dir_x;
|
||||||
|
|
||||||
if (!b->dir_x || !b->dir_y)
|
|
||||||
{
|
|
||||||
printf("Ball stopped!\n");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ball_die (ball_t *in_b)
|
void ball_die (ball_t *in_b)
|
||||||
|
|
|
@ -15,13 +15,11 @@
|
||||||
* Author & Copyright (C) 2010: Soeren Heisrath (forename@surename.org)
|
* Author & Copyright (C) 2010: Soeren Heisrath (forename@surename.org)
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
#include "common.h"
|
||||||
|
|
||||||
#ifndef BALL_H
|
#ifndef BALL_H
|
||||||
#define BALL_H
|
#define BALL_H
|
||||||
|
|
||||||
#include <stdint.h>
|
|
||||||
#include "common.h"
|
|
||||||
|
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
|
|
|
@ -16,9 +16,8 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdint.h>
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
void borg_breakout();
|
static void borg_breakout();
|
||||||
|
|
||||||
#ifdef MENU_SUPPORT
|
#ifdef MENU_SUPPORT
|
||||||
//static uint8_t breakout_icon[8] PROGMEM = {0x03, 0x03, 0x00, 0x00, 0xff, 0xff, 0x00, 0x00}; /* our Icon */
|
//static uint8_t breakout_icon[8] PROGMEM = {0x03, 0x03, 0x00, 0x00, 0xff, 0xff, 0x00, 0x00}; /* our Icon */
|
||||||
|
@ -33,7 +32,7 @@ game_descriptor_t breakout_game_descriptor __attribute__((section(".game_descrip
|
||||||
|
|
||||||
void borg_breakout()
|
void borg_breakout()
|
||||||
{
|
{
|
||||||
uint8_t rungame = 1, num_balls = 1, level = 0;
|
uint8_t level = 0;
|
||||||
ball_t balls[1];
|
ball_t balls[1];
|
||||||
|
|
||||||
/* spawn a ball in the middle bottom of the field, let it move upwards with random speed & direction */
|
/* spawn a ball in the middle bottom of the field, let it move upwards with random speed & direction */
|
||||||
|
@ -57,7 +56,6 @@ void borg_breakout()
|
||||||
|
|
||||||
if (!level_getscorediff())
|
if (!level_getscorediff())
|
||||||
{
|
{
|
||||||
printf("lvl done\n");
|
|
||||||
level++;
|
level++;
|
||||||
/* respawn ball at rebound position */
|
/* respawn ball at rebound position */
|
||||||
ball_spawn_default (&(balls[0]));
|
ball_spawn_default (&(balls[0]));
|
||||||
|
|
|
@ -31,12 +31,10 @@
|
||||||
#include "../../menu/menu.h"
|
#include "../../menu/menu.h"
|
||||||
#include "../../pixel.h"
|
#include "../../pixel.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "playfield.h"
|
|
||||||
#include "ball.h"
|
#include "ball.h"
|
||||||
|
#include "playfield.h"
|
||||||
#include "score.h"
|
#include "score.h"
|
||||||
#include "level.h"
|
#include "level.h"
|
||||||
#include "rebound.h"
|
#include "rebound.h"
|
||||||
#include "messages.h"
|
#include "messages.h"
|
||||||
|
|
||||||
#define MAX(a,b) (a > b) ? a : b
|
|
||||||
#endif /* COMMON_H */
|
#endif /* COMMON_H */
|
||||||
|
|
|
@ -13,18 +13,6 @@
|
||||||
/* rebound size */
|
/* rebound size */
|
||||||
#define REBOUND_SIZE 4
|
#define REBOUND_SIZE 4
|
||||||
|
|
||||||
/* rebound reflection: values to add to the vector at rebound field n
|
|
||||||
* note: directions are inverted
|
|
||||||
*/
|
|
||||||
static int8_t rebound_reflection[6][2] =
|
|
||||||
{
|
|
||||||
{-54,-20}, /* offside */
|
|
||||||
{-32,-12},
|
|
||||||
{-16, -8}, /* side ... middle */
|
|
||||||
{16, -8},
|
|
||||||
{32, -12},
|
|
||||||
{54, -20}
|
|
||||||
};
|
|
||||||
|
|
||||||
/* "color" of the rebound */
|
/* "color" of the rebound */
|
||||||
#define REBOUND_COLOR 2
|
#define REBOUND_COLOR 2
|
||||||
|
|
|
@ -21,7 +21,7 @@
|
||||||
void print_ballsleft (ball_t *in_b)
|
void print_ballsleft (ball_t *in_b)
|
||||||
{
|
{
|
||||||
#ifdef SCROLLTEXT_SUPPORT
|
#ifdef SCROLLTEXT_SUPPORT
|
||||||
uint8_t txt[20];
|
char txt[20];
|
||||||
snprintf (txt, sizeof(txt), "</#%u balls left", in_b->strength);
|
snprintf (txt, sizeof(txt), "</#%u balls left", in_b->strength);
|
||||||
scrolltext(txt);
|
scrolltext(txt);
|
||||||
#endif
|
#endif
|
||||||
|
@ -30,9 +30,8 @@ void print_ballsleft (ball_t *in_b)
|
||||||
void print_score ()
|
void print_score ()
|
||||||
{
|
{
|
||||||
#ifdef SCROLLTEXT_SUPPORT
|
#ifdef SCROLLTEXT_SUPPORT
|
||||||
uint8_t txt[32];
|
char txt[32];
|
||||||
snprintf (txt, sizeof(txt), "</#GAME OVER. Your score: %u", score_get());
|
snprintf (txt, sizeof(txt), "</#GAME OVER. Your score: %u", score_get());
|
||||||
scrolltext(txt);
|
scrolltext(txt);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
|
|
||||||
#ifndef MESSAGES_H
|
#ifndef MESSAGES_H
|
||||||
#define MESSAGES_H
|
#define MESSAGES_H
|
||||||
|
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "common.h"
|
#include "playfield.h"
|
||||||
static enum game_field_t playfield[NUM_COLS][NUM_ROWS];
|
static enum game_field_t playfield[NUM_COLS][NUM_ROWS];
|
||||||
|
|
||||||
void playfield_set (uint8_t in_x, uint8_t in_y, enum game_field_t in_field)
|
void playfield_set (uint8_t in_x, uint8_t in_y, enum game_field_t in_field)
|
||||||
|
@ -30,8 +30,6 @@ void playfield_set (uint8_t in_x, uint8_t in_y, enum game_field_t in_field)
|
||||||
|
|
||||||
void brick_damage (uint8_t in_x, uint8_t in_y)
|
void brick_damage (uint8_t in_x, uint8_t in_y)
|
||||||
{
|
{
|
||||||
enum game_field_t newtype;
|
|
||||||
|
|
||||||
if (playfield[in_x][in_y] >= bs || playfield[in_x][in_y] == 0)
|
if (playfield[in_x][in_y] >= bs || playfield[in_x][in_y] == 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
|
|
@ -16,9 +16,9 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "common.h"
|
||||||
#ifndef PLAYFIELD_H
|
#ifndef PLAYFIELD_H
|
||||||
#define PLAYFIELD_H
|
#define PLAYFIELD_H
|
||||||
#include "common.h"
|
|
||||||
|
|
||||||
#define BOUNCE_NONE 0x00
|
#define BOUNCE_NONE 0x00
|
||||||
#define BOUNCE_X 0x01
|
#define BOUNCE_X 0x01
|
||||||
|
|
|
@ -17,6 +17,18 @@
|
||||||
*/
|
*/
|
||||||
#include "rebound.h"
|
#include "rebound.h"
|
||||||
|
|
||||||
|
/* rebound reflection: values to add to the vector at rebound field n
|
||||||
|
*/
|
||||||
|
const int8_t rebound_reflection[6][2] =
|
||||||
|
{
|
||||||
|
{-54, -20}, /* offside */
|
||||||
|
{-32, -12}, /* left */
|
||||||
|
{-16, -8}, /* center */
|
||||||
|
{ 16, -8},
|
||||||
|
{ 32, -12},
|
||||||
|
{ 54, -20}
|
||||||
|
};
|
||||||
|
|
||||||
static uint8_t rbpos;
|
static uint8_t rbpos;
|
||||||
|
|
||||||
void rebound_reflect (ball_t *b, int8_t in_x)
|
void rebound_reflect (ball_t *b, int8_t in_x)
|
||||||
|
@ -25,8 +37,6 @@ void rebound_reflect (ball_t *b, int8_t in_x)
|
||||||
|
|
||||||
tmpidx = (in_x - rbpos) +1;
|
tmpidx = (in_x - rbpos) +1;
|
||||||
|
|
||||||
printf("bounce idx %i\n", tmpidx);
|
|
||||||
|
|
||||||
b->dir_x += rebound_reflection[tmpidx][0];
|
b->dir_x += rebound_reflection[tmpidx][0];
|
||||||
b->dir_y += rebound_reflection[tmpidx][1];
|
b->dir_y += rebound_reflection[tmpidx][1];
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,11 +15,13 @@
|
||||||
* Author & Copyright (C) 2010: Soeren Heisrath (forename@surename.org)
|
* Author & Copyright (C) 2010: Soeren Heisrath (forename@surename.org)
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
#include "common.h"
|
||||||
|
|
||||||
#ifndef REBOUND_H
|
#ifndef REBOUND_H
|
||||||
#define REBOUND_H
|
#define REBOUND_H
|
||||||
#include "common.h"
|
|
||||||
void rebound_init();
|
void rebound_init();
|
||||||
void rebound_tick();
|
void rebound_tick();
|
||||||
uint8_t rebound_getpos ();
|
void rebound_draw();
|
||||||
void rebound_reflect (ball_t *b, int8_t in_x);
|
uint8_t rebound_getpos();
|
||||||
#endif
|
void rebound_reflect(ball_t *b, int8_t in_x);
|
||||||
|
#endif /* REBOUND_H */
|
||||||
|
|
Loading…
Reference in a new issue