... | ... |
@@ -19,8 +19,8 @@ |
19 | 19 |
|0100 ( -> ) |
20 | 20 |
|
21 | 21 |
( theme ) |
22 |
- #0c5f .System/r DEO2 |
|
23 |
- #022f .System/g DEO2 |
|
22 |
+ #025f .System/r DEO2 |
|
23 |
+ #0c2f .System/g DEO2 |
|
24 | 24 |
#0da4 .System/b DEO2 |
25 | 25 |
|
26 | 26 |
( find screen center ) |
... | ... |
@@ -28,25 +28,78 @@ |
28 | 28 |
.Screen/height DEI2 #0002 DIV2 .center/y POK2 |
29 | 29 |
|
30 | 30 |
( draw ) |
31 |
+ ;draw-table JSR2 |
|
31 | 32 |
;draw-sprites JSR2 |
33 |
+ ;draw-circle JSR2 |
|
32 | 34 |
|
33 | 35 |
BRK |
34 | 36 |
|
35 | 37 |
@draw-sprites ( -- ) |
36 | 38 |
|
37 | 39 |
;preview_icn .Screen/addr DEO2 |
38 |
- |
|
39 |
- #00 #ff |
|
40 |
+ #00 #00 |
|
40 | 41 |
&loop |
41 | 42 |
( move ) OVR #0f AND #40 SFT #02 DIV #00 SWP |
42 | 43 |
.center/x PEK2 #0040 SUB2 ADD2 .Screen/x DEO2 |
43 | 44 |
( move ) OVR #f0 AND #02 DIV #00 SWP |
44 |
- .center/y PEK2 #0018 SUB2 ADD2 .Screen/y DEO2 |
|
45 |
+ .center/y PEK2 #0040 SUB2 ADD2 .Screen/y DEO2 |
|
45 | 46 |
( draw ) OVR .Screen/color DEO |
47 |
+ ( incr ) SWP #01 ADD SWP |
|
48 |
+ DUP2 NEQ ,&loop JNZ |
|
49 |
+ POP2 |
|
50 |
+ |
|
51 |
+RTN |
|
52 |
+ |
|
53 |
+@draw-table ( -- ) |
|
54 |
+ |
|
55 |
+ #00 #10 |
|
56 |
+ &loop |
|
57 |
+ OVR #08 MUL #00 SWP ;font_hex ADD2 .Screen/addr DEO2 |
|
58 |
+ |
|
59 |
+ ( x-axis ) |
|
60 |
+ OVR #08 MUL #00 SWP |
|
61 |
+ .center/x PEK2 #0040 SUB2 ADD2 .Screen/x DEO2 |
|
62 |
+ .center/y PEK2 #0050 SUB2 .Screen/y DEO2 |
|
63 |
+ ( draw ) #21 .Screen/color DEO |
|
64 |
+ |
|
65 |
+ ( y-axis ) |
|
66 |
+ OVR #08 MUL #00 SWP |
|
67 |
+ .center/y PEK2 #0040 SUB2 ADD2 .Screen/y DEO2 |
|
68 |
+ .center/x PEK2 #0050 SUB2 .Screen/x DEO2 |
|
69 |
+ ( draw ) #21 .Screen/color DEO |
|
70 |
+ |
|
46 | 71 |
( incr ) SWP #01 ADD SWP |
47 | 72 |
DUP2 LTH ,&loop JNZ |
48 | 73 |
POP2 |
74 |
+ |
|
75 |
+RTN |
|
76 |
+ |
|
77 |
+@draw-circle ( -- ) |
|
49 | 78 |
|
79 |
+ ;preview_icn .Screen/addr DEO2 |
|
80 |
+ |
|
81 |
+ .center/x PEK2 #0048 ADD2 .Screen/x DEO2 |
|
82 |
+ .center/y PEK2 #0030 ADD2 .Screen/y DEO2 |
|
83 |
+ #21 .Screen/color DEO |
|
84 |
+ .center/x PEK2 #0050 ADD2 .Screen/x DEO2 |
|
85 |
+ #61 .Screen/color DEO |
|
86 |
+ .center/x PEK2 #0048 ADD2 .Screen/x DEO2 |
|
87 |
+ .center/y PEK2 #0038 ADD2 .Screen/y DEO2 |
|
88 |
+ #a1 .Screen/color DEO |
|
89 |
+ .center/x PEK2 #0050 ADD2 .Screen/x DEO2 |
|
90 |
+ #f1 .Screen/color DEO |
|
91 |
+ |
|
50 | 92 |
RTN |
51 | 93 |
|
52 |
-@preview_icn [ 183c 66db db66 3c18 0000 183c 3c18 0000 ] |
|
53 | 94 |
\ No newline at end of file |
95 |
+@preview_icn [ |
|
96 |
+ 0f38 675f dfbf bfbf 0007 1820 2344 4848 ] |
|
97 |
+ |
|
98 |
+@font_hex [ |
|
99 |
+ 007c 8282 8282 827c 0030 1010 1010 1010 |
|
100 |
+ 007c 8202 7c80 80fe 007c 8202 1c02 827c |
|
101 |
+ 000c 1424 4484 fe04 00fe 8080 7c02 827c |
|
102 |
+ 007c 8280 fc82 827c 007c 8202 1e02 0202 |
|
103 |
+ 007c 8282 7c82 827c 007c 8282 7e02 827c |
|
104 |
+ 007c 8202 7e82 827e 00fc 8282 fc82 82fc |
|
105 |
+ 007c 8280 8080 827c 00fc 8282 8282 82fc |
|
106 |
+ 007c 8280 f080 827c 007c 8280 f080 8080 ] |
|
54 | 107 |
\ No newline at end of file |
... | ... |
@@ -224,11 +224,13 @@ screen_talk(Device *d, Uint8 b0, Uint8 w) |
224 | 224 |
Uint16 y = mempeek16(d->dat, 0xa); |
225 | 225 |
Uint8 *addr = &d->mem[mempeek16(d->dat, 0xc)]; |
226 | 226 |
Uint8 *layer = d->dat[0xe] >> 4 & 0x1 ? ppu.fg : ppu.bg; |
227 |
- switch(d->dat[0xe] >> 5) { |
|
228 |
- case 0: putpixel(&ppu, layer, x, y, d->dat[0xe] & 0x3); break; |
|
229 |
- case 1: puticn(&ppu, layer, x, y, addr, d->dat[0xe] & 0xf); break; |
|
230 |
- case 2: putchr(&ppu, layer, x, y, addr, d->dat[0xe] & 0xf); break; |
|
231 |
- } |
|
227 |
+ Uint8 mode = d->dat[0xe] >> 5; |
|
228 |
+ if(!mode) |
|
229 |
+ putpixel(&ppu, layer, x, y, d->dat[0xe] & 0x3); |
|
230 |
+ else if(mode % 2) |
|
231 |
+ puticn(&ppu, layer, x, y, addr, d->dat[0xe] & 0xf, d->dat[0xe] >> 6 & 0x1, d->dat[0xe] >> 7 & 0x1); |
|
232 |
+ else |
|
233 |
+ putchr(&ppu, layer, x, y, addr, d->dat[0xe] & 0xf, d->dat[0xe] >> 6 & 0x1, d->dat[0xe] >> 7 & 0x1); |
|
232 | 234 |
reqdraw = 1; |
233 | 235 |
} |
234 | 236 |
} |
... | ... |
@@ -80,26 +80,34 @@ putpixel(Ppu *p, Uint8 *layer, Uint16 x, Uint16 y, Uint8 color) |
80 | 80 |
} |
81 | 81 |
|
82 | 82 |
void |
83 |
-puticn(Ppu *p, Uint8 *layer, Uint16 x, Uint16 y, Uint8 *sprite, Uint8 color) |
|
83 |
+puticn(Ppu *p, Uint8 *layer, Uint16 x, Uint16 y, Uint8 *sprite, Uint8 color, Uint8 flipx, Uint8 flipy) |
|
84 | 84 |
{ |
85 | 85 |
Uint16 v, h; |
86 | 86 |
for(v = 0; v < 8; v++) |
87 | 87 |
for(h = 0; h < 8; h++) { |
88 | 88 |
Uint8 ch1 = ((sprite[v] >> (7 - h)) & 0x1); |
89 | 89 |
if(ch1 == 1 || (color != 0x05 && color != 0x0a && color != 0x0f)) |
90 |
- putpixel(p, layer, x + h, y + v, ch1 ? color % 4 : color / 4); |
|
90 |
+ putpixel(p, |
|
91 |
+ layer, |
|
92 |
+ x + (flipx ? 7 - h : h), |
|
93 |
+ y + (flipy ? 7 - v : v), |
|
94 |
+ ch1 ? color % 4 : color / 4); |
|
91 | 95 |
} |
92 | 96 |
} |
93 | 97 |
|
94 | 98 |
void |
95 |
-putchr(Ppu *p, Uint8 *layer, Uint16 x, Uint16 y, Uint8 *sprite, Uint8 color) |
|
99 |
+putchr(Ppu *p, Uint8 *layer, Uint16 x, Uint16 y, Uint8 *sprite, Uint8 color, Uint8 flipx, Uint8 flipy) |
|
96 | 100 |
{ |
97 | 101 |
Uint16 v, h; |
98 | 102 |
for(v = 0; v < 8; v++) |
99 | 103 |
for(h = 0; h < 8; h++) { |
100 | 104 |
Uint8 ch1 = ((sprite[v] >> (7 - h)) & 0x1) * color; |
101 | 105 |
Uint8 ch2 = ((sprite[v + 8] >> (7 - h)) & 0x1) * color; |
102 |
- putpixel(p, layer, x + h, y + v, (((ch1 + ch2 * 2) + color / 4) & 0x3)); |
|
106 |
+ putpixel(p, |
|
107 |
+ layer, |
|
108 |
+ x + (flipx ? 7 - h : h), |
|
109 |
+ y + (flipy ? 7 - v : v), |
|
110 |
+ (((ch1 + ch2 * 2) + color / 4) & 0x3)); |
|
103 | 111 |
} |
104 | 112 |
} |
105 | 113 |
|
... | ... |
@@ -118,8 +126,8 @@ drawdebugger(Ppu *p, Uint8 *stack, Uint8 ptr) |
118 | 126 |
Uint8 i, x, y, b; |
119 | 127 |
for(i = 0; i < 0x20; ++i) { /* memory */ |
120 | 128 |
x = ((i % 8) * 3 + 1) * 8, y = (i / 8 + 1) * 8, b = stack[i]; |
121 |
- puticn(p, p->bg, x, y, font[(b >> 4) & 0xf], 1 + (ptr == i) * 0x7); |
|
122 |
- puticn(p, p->bg, x + 8, y, font[b & 0xf], 1 + (ptr == i) * 0x7); |
|
129 |
+ puticn(p, p->bg, x, y, font[(b >> 4) & 0xf], 1 + (ptr == i) * 0x7, 0, 0); |
|
130 |
+ puticn(p, p->bg, x + 8, y, font[b & 0xf], 1 + (ptr == i) * 0x7, 0, 0); |
|
123 | 131 |
} |
124 | 132 |
for(x = 0; x < 0x20; ++x) { |
125 | 133 |
drawpixel(p, x, p->height / 2, 2); |
... | ... |
@@ -26,7 +26,7 @@ typedef struct Ppu { |
26 | 26 |
int initppu(Ppu *p, Uint8 hor, Uint8 ver, Uint8 pad); |
27 | 27 |
void putcolors(Ppu *p, Uint8 *addr); |
28 | 28 |
void putpixel(Ppu *p, Uint8 *layer, Uint16 x, Uint16 y, Uint8 color); |
29 |
-void puticn(Ppu *p, Uint8 *layer, Uint16 x, Uint16 y, Uint8 *sprite, Uint8 color); |
|
30 |
-void putchr(Ppu *p, Uint8 *layer, Uint16 x, Uint16 y, Uint8 *sprite, Uint8 color); |
|
29 |
+void puticn(Ppu *p, Uint8 *layer, Uint16 x, Uint16 y, Uint8 *sprite, Uint8 color, Uint8 flipx, Uint8 flipy); |
|
30 |
+void putchr(Ppu *p, Uint8 *layer, Uint16 x, Uint16 y, Uint8 *sprite, Uint8 color, Uint8 flipx, Uint8 flipy); |
|
31 | 31 |
void drawppu(Ppu *p); |
32 | 32 |
void drawdebugger(Ppu *p, Uint8 *stack, Uint8 ptr); |