Merge commit 'ba34771069f48c83aa76'
This commit is contained in:
commit
ffb4dae48c
|
@ -0,0 +1,80 @@
|
||||||
|
/* nick_invaders.c
|
||||||
|
*
|
||||||
|
* By NiciDieNase
|
||||||
|
* r0ket@nicidienase.de
|
||||||
|
*
|
||||||
|
* Known Bugs:
|
||||||
|
* - Ignores Font-Setting
|
||||||
|
* - might look odd with really short or really long nicknames
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <sysinit.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include "basic/basic.h"
|
||||||
|
#include "lcd/render.h"
|
||||||
|
#include "lcd/display.h"
|
||||||
|
#include "usetable.h"
|
||||||
|
#include "lcd/fonts.h"
|
||||||
|
#include "lcd/fonts/invaders.h"
|
||||||
|
#include "lcd/fonts/invaders.c"
|
||||||
|
|
||||||
|
void ram(void)
|
||||||
|
{
|
||||||
|
bool step = true;
|
||||||
|
const int minX = 10;
|
||||||
|
const int minY = 10;
|
||||||
|
const int maxX = 50;
|
||||||
|
const int maxY = 30;
|
||||||
|
const int space = 15;
|
||||||
|
const int delaytime = 150;
|
||||||
|
const int defaultfont = font;
|
||||||
|
int x = minX;
|
||||||
|
int y = minY;
|
||||||
|
int u = 0;
|
||||||
|
int dir = 0;
|
||||||
|
|
||||||
|
while(1){
|
||||||
|
lcdFill(0);
|
||||||
|
font = &Font_Invaders;
|
||||||
|
// Draw UFO
|
||||||
|
DoChar(-15+u,1,'U');
|
||||||
|
u+=2;
|
||||||
|
if(u > 1337) u=0;
|
||||||
|
//Draw Invaders
|
||||||
|
DoChar(x,y,step?'a':'A');
|
||||||
|
DoChar(x+space,y,step?'b':'B');
|
||||||
|
DoChar(x+2*space,y,step?'c':'C');
|
||||||
|
switch (dir){
|
||||||
|
// move left
|
||||||
|
case 0:
|
||||||
|
x++;
|
||||||
|
if(x == maxX) dir++;
|
||||||
|
break;
|
||||||
|
// move down on right end
|
||||||
|
case 1:
|
||||||
|
y++;
|
||||||
|
dir++;
|
||||||
|
if(y == maxY) y=minY;
|
||||||
|
break;
|
||||||
|
// move left
|
||||||
|
case 2:
|
||||||
|
x--;
|
||||||
|
if(x==minX) dir++;
|
||||||
|
break;
|
||||||
|
// move down on left end
|
||||||
|
case 3:
|
||||||
|
y++;
|
||||||
|
dir++;
|
||||||
|
if(y == maxY) y=minY;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
dir %= 4;
|
||||||
|
font = defaultfont;
|
||||||
|
DoString(10,40,nickname);
|
||||||
|
lcdDisplay();
|
||||||
|
if(getInputRaw()!=BTN_NONE) return;
|
||||||
|
step = !step;
|
||||||
|
delayms_queue_plus(delaytime,0);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue