summaryrefslogtreecommitdiff
path: root/chip8.c
diff options
context:
space:
mode:
authorDaniel Jones <admin@danieljon.es>2020-08-17 15:16:02 +0930
committerDaniel Jones <admin@danieljon.es>2020-08-17 15:16:02 +0930
commit7d60741c1393ebc0c572891cfeb19a25c4579ed6 (patch)
tree4e13404b3a19933155bed5ac5c85a3387e2de79f /chip8.c
parent43b01c12d1192830034807e664843f780df8b7bb (diff)
downloadchip8-7d60741c1393ebc0c572891cfeb19a25c4579ed6.tar.gz
chip8-7d60741c1393ebc0c572891cfeb19a25c4579ed6.zip
sprite drawing basic implementation
begin implementing sprite drawing, currently draws the chip8 fontset well, no idead about other sprites yet
Diffstat (limited to 'chip8.c')
-rw-r--r--chip8.c38
1 files changed, 37 insertions, 1 deletions
diff --git a/chip8.c b/chip8.c
index 2ce911f..db2efd2 100644
--- a/chip8.c
+++ b/chip8.c
@@ -71,7 +71,7 @@ chip8_init()
draw_flag = 1; // draw by default i guess
delay_timer = 0;
sound_timer = 0;
- srand(time(NULL)); // seed rng
+ srand(time(NULL));
/* load font into memory at 0x00: we have 0x00 to 0x1FF free for anything we want */
//TODO: add whole alphabet, then can write a rom to write strings or something
@@ -80,3 +80,39 @@ chip8_init()
memory[0x0 + i] = chip8_fontset[i];
}
}
+
+void
+chip8_draw_sprite(int startx, int starty, uint8_t mem, uint8_t size)
+{
+ /*
+ * draw sprite located at loc of height size at startx,starty
+ */
+
+ uint8_t byte = 0;
+ uint8_t mask = 0x1;
+ uint8_t destbit = 0x0;
+ for (uint8_t byteoffset = 0; byteoffset < size; byteoffset++)
+ {
+ /* loop through each byte from mem to mem+size */
+ byte = memory[mem+byteoffset];
+ int bit = 0;
+ for (mask = 0x80; mask != 0; mask >>= 1)
+ {
+ if (byte&mask)
+ {
+ destbit = 1;
+ video[WIDTH*starty+(startx+bit)] = 0xFFFFFF;
+ }
+ else
+ {
+ destbit = 0;
+ video[WIDTH*starty+(startx+bit)] = 0x0;
+ }
+ printf("%d", destbit);
+ bit++;
+ }
+ starty++;
+ puts("");
+ }
+ puts("---");
+}