implement keypad, speed up portrait draw, move tick/draw to task so they can be debugged

This commit is contained in:
Jeremy Penner 2020-03-28 16:58:47 -04:00
parent 64d21bc875
commit 175b1d81cf
38 changed files with 117 additions and 15 deletions

BIN
boot.jim

Binary file not shown.

BIN
debug.jim

Binary file not shown.

View file

@ -12,7 +12,7 @@ defer dbg-cmd
dup $DOCOLON = if drop else dup $DOCOLON = if drop else
dup $DOCREATE = if drop @ else dup $DOCREATE = if drop @ else
$DODEFERRED = if @ dbg-first-ip else $DODEFERRED = if @ dbg-first-ip else
drop 0 then then then ; drop 0 then then then ; userword
: tail :| rdrop dbg-first-ip >r |; , [ ' [ , ] ; immediate : tail :| rdrop dbg-first-ip >r |; , [ ' [ , ] ; immediate
@ -84,11 +84,14 @@ array breakpoints bp, bp, bp, bp, bp,
: set-next-breakpoint ( ip -- ) : set-next-breakpoint ( ip -- )
free-breakpoint >r r@ breakpoint# reset-breakpoint free-breakpoint >r r@ breakpoint# reset-breakpoint
<r s" bp " type . s" set" type cr ; <r s" bp " type . s" set" type cr ; userword
: b word lookup drop dbg-first-ip dup if set-next-breakpoint : b word lookup drop dbg-first-ip dup if set-next-breakpoint
else s" word not found" type cr drop then ; userword else s" word not found" type cr drop then ; userword
: unb breakpoint# clear-breakpoint ; userword : unb breakpoint# clear-breakpoint ; userword
: break-after cells dbg-ip @ + set-next-breakpoint ; userword
: bh 0 break-after ; userword
: .bp 0 MAX-BREAKPOINTS for : .bp 0 MAX-BREAKPOINTS for
i . i .
i breakpoint# bp.ip @ dup . i breakpoint# bp.ip @ dup .

BIN
defs.jim

Binary file not shown.

BIN
end.jim

Binary file not shown.

Binary file not shown.

Binary file not shown.

View file

@ -67,8 +67,12 @@ var texttimer
: show-footer 48 10 footer-y move-to ; : show-footer 48 10 footer-y move-to ;
: hide-footer 0 10 footer-y move-to ; : hide-footer 0 10 footer-y move-to ;
: footer-wait show-footer ^ENTER wait-key ; : do-footer-wait show-footer ^ENTER wait-key ;
defer footer-wait
: dont-footer-wait ' do-footer-wait ' footer-wait redefine ;
dont-footer-wait
: runon ' dont-footer-wait ' footer-wait redefine ; userword
: say ( s -- ) textleftsay clear show-footer slowtext footer-wait ; userword : say ( s -- ) textleftsay clear show-footer slowtext footer-wait ; userword
: say" [ ' s" , ] ' say expile ; immediate : say" [ ' s" , ] ' say expile ; immediate
@ -111,6 +115,7 @@ var cchoose
1 YELLOW character rexx userword 1 YELLOW character rexx userword
3 LBLUE character jaye userword 3 LBLUE character jaye userword
5 CYAN character gord userword 5 CYAN character gord userword
6 LMAGENTA character pady userword
: noone WHITE text-color ! s" " dup dup dup : noone WHITE text-color ! s" " dup dup dup
8 portraity 16 portraity 24 portraity 32 portraity ; userword 8 portraity 16 portraity 24 portraity 32 portraity ; userword

BIN
game.jim

Binary file not shown.

View file

@ -292,6 +292,8 @@ does>
: create-object blankentity dup link-object ; : create-object blankentity dup link-object ;
: create-linked-object blankentity swap , dup link-object ; : create-linked-object blankentity swap , dup link-object ;
: create-extra-linked-object blankentity swap , swap ,
dup link-object ;
: create-timed-object blankentity swap , swap , 0 , : create-timed-object blankentity swap , swap , 0 ,
dup link-object obj-ticking! ; dup link-object obj-ticking! ;

View file

@ -19,6 +19,8 @@ defer tick
defer draw defer draw
defer loadlevel defer loadlevel
task :noname activate blah begin tick suspend again ; execute
:noname :noname
s" input.jor" loadfile s" input.jor" loadfile
s" timer.jor" loadfile s" timer.jor" loadfile
@ -33,6 +35,8 @@ s" game.jor" loadfile
s" debug.jor" loadfile s" debug.jor" loadfile
; execute ; execute
task :noname activate blah begin draw suspend again ; execute
' load-new-level checkpoint _loadlevel ' load-new-level checkpoint _loadlevel
' _loadlevel ' loadlevel redefine ' _loadlevel ' loadlevel redefine

BIN
input.jim

Binary file not shown.

BIN
jiles.jim

Binary file not shown.

View file

@ -3,7 +3,9 @@ var rcolor 0x10 rcolor !
var spriteindex var spriteindex
var refresh-needed var refresh-needed
var spritedirty
: refresh 1 refresh-needed ! ; : refresh 1 refresh-needed ! ;
: refresh-xy spritedirty 1 + b! spritedirty b! 2 refresh-needed ! ;
array preview 128 allot array preview 128 allot
@ -30,7 +32,8 @@ array preview 128 allot
: mousepixel! ( color -- ) : mousepixel! ( color -- )
>r mousexys getpixel r@ != if >r mousexys getpixel r@ != if
r@ mousexys putpixel refresh r@ mousexys putpixel
mousepos mousepos>sprpos refresh-xy
then rdrop ; then rdrop ;
: gfxfilename : gfxfilename
@ -96,7 +99,11 @@ var copysrc
refresh-needed @ if refresh-needed @ if
mousehide mousehide
draw-preview draw-preview
refresh-needed @ 2 = if
spritedirty b@ spritedirty 1 + b@ spriteindex @ drawfatspritepixel
else
spriteindex @ drawfatsprite spriteindex @ drawfatsprite
then
lcolor @ 77 0 drawfatbox lcolor @ 77 0 drawfatbox
rcolor @ 78 0 drawfatbox rcolor @ 78 0 drawfatbox
draw-palette draw-palette

BIN
job.jim

Binary file not shown.

View file

@ -1,6 +1,7 @@
#include <stdio.h> #include <stdio.h>
#define MEM_SIZE 24576 #define MEM_SIZE 28762
#define STACK_SIZE 64 #define STACK_SIZE 64
#define RSTACK_SIZE 64 #define RSTACK_SIZE 64

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

View file

@ -11,7 +11,7 @@ lazy 60 over 19 9 timedswitch ts
10 9 door d2 10 9 door d2
5 6 door d3 >lazy! 5 6 door d3 >lazy!
10 2 door d4 10 2 door d4
LEV_END 5 12 exitdoor dx 6 5 12 exitdoor dx
lazy dup 11 3 computer c1 lazy dup 11 3 computer c1
' c1 7 11 computer c2 >lazy! ' c1 7 11 computer c2 >lazy!

Binary file not shown.

View file

@ -1,8 +1,66 @@
( L E V E L 0 0 0 0 6 ) ( L E V E L 0 0 0 0 6 )
:noname objects: O
2 const ^1
30 const code-y
20 const code-x
: wait-for-digit ( -- n )
0 begin suspend ^1 dup 11 + for i key-pressed if drop i then next dup until
^1 - 1 + dup 10 = if drop 0 then ;
: draw-digit ( x n -- ) code-y swap 48 + text-color @ textc ;
: code-digit ( code x -- code )
wait-for-digit swap code-x + over draw-digit swap 10 * + ;
: read-code ( -- n )
WHITE text-color !
s" ####" code-x code-y textxy
0 0 code-digit
1 code-digit
2 code-digit
3 code-digit ;
var pady-introduced
: keypad-code responder entity.user cell + @ ;
: keypad create-extra-linked-object
:| dup EVTOUCH = if
pady-introduced @ not if
pady say" Hello, stranger! I'm Pady,\the friendly keypad lock!"
jaye say" I need to get through this\door, Pady."
pady say" You didn't say the magic\word, stranger!"
1 pady-introduced !
then
isneut? if move-player then
PAD-OFF responder>tile? if
runon pady say" Enter your 4-digit door code!\And have a super day!"
read-code keypad-code = if
pady say" That's right! Hooray!\You get a gold star!"
drop EVACT
else
pady say" Ohhh, sorry! That's not it.\Better luck next time!"
then
else
pady say" Oh hi again! I missed you too!"
then
then
dup PAD-ON PAD-OFF handle-onoff
PAD-ON handle-link |; listener! ;
3 1 door d1
17 1 door d2
4 11 door d3
10 9 door d4
1234 ' d1 3 2 keypad k1
-1 ' d2 17 2 keypad k2 ( must be hacked )
3456 ' d3 4 10 keypad k3
LEV_END 13 12 exitdoor dx
' dx 14 12 scanner sx
:noname O
5 1 tile>world Jaye entity.pos! 5 1 tile>world Jaye entity.pos!
4 0 tile>world Neut entity.pos! 4 0 tile>world Neut entity.pos!
with-gord with-gord
; ' onload redefine ; ' onload redefine

Binary file not shown.

View file

Binary file not shown.

View file

View file

View file

BIN
level.jim

Binary file not shown.

BIN
map.jim

Binary file not shown.

View file

@ -34,7 +34,8 @@ array tileflags
( 21:scanner-on ) NEUTABLE b, ( 21:scanner-on ) NEUTABLE b,
( 22:cracked-wall ) 0 b, ( 22:cracked-wall ) 0 b,
( 23:rexx-pod ) NEUTABLE b, ( 23:rexx-pod ) NEUTABLE b,
( 24:keypad ) NEUTABLE b, ( 24:keypad-off ) NEUTABLE b,
( 25:keypad-on ) NEUTABLE b,
here tileflags - 1 - const MAXTILE here tileflags - 1 - const MAXTILE
@ -49,6 +50,8 @@ here tileflags - 1 - const MAXTILE
20 const SCAN-OFF 20 const SCAN-OFF
21 const SCAN-ON 21 const SCAN-ON
23 const REXX-POD 23 const REXX-POD
24 const PAD-OFF
25 const PAD-ON
: mapflag? ( x y flag -- b ) >rot tile b@ tileflags + b@ & ; : mapflag? ( x y flag -- b ) >rot tile b@ tileflags + b@ & ;

Binary file not shown.

Binary file not shown.

Binary file not shown.

BIN
state.jim

Binary file not shown.

View file

@ -449,6 +449,29 @@ void f_drawfatsprite() {
} }
} }
void f_drawfatspritepixel() {
int x = ST2().i;
int y = ST1().i;
unsigned int far *spr = getTarget(TOP().i);
DROP(3);
if (editTarget != ET_PORTRAIT) {
int color = getsprpixel(x, y, spr);
setAllPlanes();
drawFatBox(x, y << 3, color);
} else {
int colorl, colorr;
x = x & 0xfffe;
colorl = getsprpixel( x, y, spr);
colorr = getsprpixel(x + 1, y, spr);
drawDoubleFatBox(x >> 1, y << 2, colorl, colorr);
setAllPlanes();
}
}
void f_drawfatbox() { void f_drawfatbox() {
drawFatBox(ST1().i, TOP().i, ST2().i); drawFatBox(ST1().i, TOP().i, ST2().i);
DROP(3); DROP(3);
@ -690,6 +713,7 @@ void game_f_init(char *exe, char *bootjor) {
CDEF("mouseshow", f_mouseshow); CDEF("mouseshow", f_mouseshow);
CDEF("mousehide", f_mousehide); CDEF("mousehide", f_mousehide);
CDEF("drawfatsprite", f_drawfatsprite); CDEF("drawfatsprite", f_drawfatsprite);
CDEF("drawfatspritepixel", f_drawfatspritepixel);
CDEF("drawfatbox", f_drawfatbox); CDEF("drawfatbox", f_drawfatbox);
CDEF("putpixel", f_putpixel); CDEF("putpixel", f_putpixel);
CDEF("getpixel", f_getpixel); CDEF("getpixel", f_getpixel);
@ -748,7 +772,6 @@ void do_repl(char *exe) {
} }
int main(int argc, char *argv[]) { int main(int argc, char *argv[]) {
cell tick, draw;
char *bootjor = "gameboot.jor"; char *bootjor = "gameboot.jor";
if (argc > 1) { if (argc > 1) {
@ -758,15 +781,11 @@ int main(int argc, char *argv[]) {
ser_init(SER_COM2, BAUD_19200, SER_8N1); ser_init(SER_COM2, BAUD_19200, SER_8N1);
game_init(); game_init();
game_f_init(argv[0], bootjor); game_f_init(argv[0], bootjor);
tick = f_lookupcp("tick");
draw = f_lookupcp("draw");
while (!keyIsDown(K_ESC)) { while (!keyIsDown(K_ESC)) {
kbd_debounce(); kbd_debounce();
f_poll(); f_poll();
f_execcp(tick);
f_taskloop(); f_taskloop();
f_execcp(draw);
} }
return 0; return 0;

BIN
timer.jim

Binary file not shown.