summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSimponic <loganthebean222@gmail.com>2020-08-08 18:16:34 -0600
committerSimponic <loganthebean222@gmail.com>2020-08-08 18:16:34 -0600
commit7f856467a086ec9a3ebd1ccdf12e578dffb9c98b (patch)
tree191714e3ef0daf90d5252532dd0db3f4f0256de5
parent6a44a34e0ebb867753df26f1cb0a38f53420a606 (diff)
downloadgeometry-dash-gba-7f856467a086ec9a3ebd1ccdf12e578dffb9c98b.tar.gz
geometry-dash-gba-7f856467a086ec9a3ebd1ccdf12e578dffb9c98b.zip
Player added
-rwxr-xr-xGBA-Dash.elfbin208888 -> 211852 bytes
-rwxr-xr-xGBA-Dash.gbabin1932 -> 2036 bytes
-rw-r--r--build/GBA-Dash.map183
-rw-r--r--build/main.d14
-rw-r--r--build/main.obin6748 -> 11528 bytes
-rw-r--r--include/.playerObject.h.swpbin0 -> 12288 bytes
-rw-r--r--include/fixed.h77
-rw-r--r--include/playerObject.h73
-rw-r--r--include/point.h28
-rw-r--r--include/velocity.h35
-rw-r--r--source/.main.c.swpbin0 -> 12288 bytes
-rw-r--r--source/main.c22
12 files changed, 337 insertions, 95 deletions
diff --git a/GBA-Dash.elf b/GBA-Dash.elf
index 5722245..1a156a8 100755
--- a/GBA-Dash.elf
+++ b/GBA-Dash.elf
Binary files differ
diff --git a/GBA-Dash.gba b/GBA-Dash.gba
index 67332d6..bf0c0cf 100755
--- a/GBA-Dash.gba
+++ b/GBA-Dash.gba
Binary files differ
diff --git a/build/GBA-Dash.map b/build/GBA-Dash.map
index e1b69e4..f89749a 100644
--- a/build/GBA-Dash.map
+++ b/build/GBA-Dash.map
@@ -20,6 +20,7 @@ Discarded input sections
.bss 0x0000000000000000 0x0 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/thumb/crtbegin.o
.data.__dso_handle
0x0000000000000000 0x4 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/thumb/crtbegin.o
+ .text 0x0000000000000000 0x5c main.o
.data 0x0000000000000000 0x4 main.o
.text 0x0000000000000000 0x0 player.o
.data 0x0000000000000000 0x0 player.o
@@ -81,7 +82,7 @@ Linker script and memory map
*(.plt)
0x000000000800021c . = ALIGN (0x4)
-.text 0x000000000800021c 0x2d0
+.text 0x000000000800021c 0x338
*(EXCLUDE_FILE(*.iwram*) .text*)
.text.deregister_tm_clones
0x000000000800021c 0x2c /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/thumb/crtbegin.o
@@ -91,99 +92,97 @@ Linker script and memory map
0x000000000800027c 0x30 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/thumb/crtbegin.o
.text.frame_dummy
0x00000000080002ac 0x28 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/thumb/crtbegin.o
- .text 0x00000000080002d4 0x5c main.o
- 0x00000000080002d4 obj_test
- .text.startup 0x0000000008000330 0x44 main.o
- 0x0000000008000330 main
- .text 0x0000000008000374 0x80 toolbox.o
- 0x0000000008000374 oam_init
- 0x00000000080003b4 oam_copy
- 0x00000000080003d4 obj_copy
+ .text.startup 0x00000000080002d4 0x108 main.o
+ 0x00000000080002d4 main
+ .text 0x00000000080003dc 0x80 toolbox.o
+ 0x00000000080003dc oam_init
+ 0x000000000800041c oam_copy
+ 0x000000000800043c obj_copy
.text.__libc_init_array
- 0x00000000080003f4 0x50 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/../../../../arm-none-eabi/lib/thumb/libg.a(lib_a-init.o)
- 0x00000000080003f4 __libc_init_array
- .text.memcpy 0x0000000008000444 0xa8 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/../../../../arm-none-eabi/lib/thumb/libg.a(lib_a-memcpy-stub.o)
- 0x0000000008000444 memcpy
+ 0x000000000800045c 0x50 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/../../../../arm-none-eabi/lib/thumb/libg.a(lib_a-init.o)
+ 0x000000000800045c __libc_init_array
+ .text.memcpy 0x00000000080004ac 0xa8 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/../../../../arm-none-eabi/lib/thumb/libg.a(lib_a-memcpy-stub.o)
+ 0x00000000080004ac memcpy
*(.gnu.linkonce.t.*)
*(.text.*personality*)
*(.gnu.warning)
*(.glue_7t)
- .glue_7t 0x00000000080004ec 0x0 linker stubs
+ .glue_7t 0x0000000008000554 0x0 linker stubs
*(.glue_7)
- .glue_7 0x00000000080004ec 0x0 linker stubs
+ .glue_7 0x0000000008000554 0x0 linker stubs
*(.vfp11_veneer)
- .vfp11_veneer 0x00000000080004ec 0x0 linker stubs
- 0x00000000080004ec . = ALIGN (0x4)
- 0x00000000080004ec __text_end = .
+ .vfp11_veneer 0x0000000008000554 0x0 linker stubs
+ 0x0000000008000554 . = ALIGN (0x4)
+ 0x0000000008000554 __text_end = .
-.v4_bx 0x00000000080004ec 0x0
- .v4_bx 0x00000000080004ec 0x0 linker stubs
+.v4_bx 0x0000000008000554 0x0
+ .v4_bx 0x0000000008000554 0x0 linker stubs
-.iplt 0x00000000080004ec 0x0
- .iplt 0x00000000080004ec 0x0 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/../../../../arm-none-eabi/lib/thumb/gba_crt0.o
+.iplt 0x0000000008000554 0x0
+ .iplt 0x0000000008000554 0x0 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/../../../../arm-none-eabi/lib/thumb/gba_crt0.o
-.fini 0x00000000080004ec 0xc
+.fini 0x0000000008000554 0xc
*(.fini)
- .fini 0x00000000080004ec 0x4 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/thumb/crti.o
- 0x00000000080004ec _fini
- .fini 0x00000000080004f0 0x8 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/thumb/crtn.o
- 0x00000000080004f8 . = ALIGN (0x4)
+ .fini 0x0000000008000554 0x4 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/thumb/crti.o
+ 0x0000000008000554 _fini
+ .fini 0x0000000008000558 0x8 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/thumb/crtn.o
+ 0x0000000008000560 . = ALIGN (0x4)
-.rodata 0x00000000080004f8 0x280
+.rodata 0x0000000008000560 0x280
*(.rodata)
- .rodata 0x00000000080004f8 0x280 player.o
- 0x00000000080004f8 playerTiles
- 0x0000000008000578 playerPal
+ .rodata 0x0000000008000560 0x280 player.o
+ 0x0000000008000560 playerTiles
+ 0x00000000080005e0 playerPal
*all.rodata*(*)
*(.roda)
*(.rodata.*)
*(.gnu.linkonce.r*)
- 0x0000000008000778 . = ALIGN (0x4)
+ 0x00000000080007e0 . = ALIGN (0x4)
.ARM.extab
*(.ARM.extab* .gnu.linkonce.armextab.*)
- 0x0000000008000778 __exidx_start = .
+ 0x00000000080007e0 __exidx_start = .
.ARM.exidx
*(.ARM.exidx* .gnu.linkonce.armexidx.*)
- 0x0000000008000778 __exidx_end = .
+ 0x00000000080007e0 __exidx_end = .
-.ctors 0x0000000008000778 0x0
+.ctors 0x00000000080007e0 0x0
*crtbegin.o(.ctors)
*(EXCLUDE_FILE(*crtend.o) .ctors)
*(SORT_BY_NAME(.ctors.*))
*(.ctors)
- 0x0000000008000778 . = ALIGN (0x4)
+ 0x00000000080007e0 . = ALIGN (0x4)
-.dtors 0x0000000008000778 0x0
+.dtors 0x00000000080007e0 0x0
*crtbegin.o(.dtors)
*(EXCLUDE_FILE(*crtend.o) .dtors)
*(SORT_BY_NAME(.dtors.*))
*(.dtors)
- 0x0000000008000778 . = ALIGN (0x4)
+ 0x00000000080007e0 . = ALIGN (0x4)
-.eh_frame 0x0000000008000778 0x4
+.eh_frame 0x00000000080007e0 0x4
*(.eh_frame)
- .eh_frame 0x0000000008000778 0x0 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/thumb/crtbegin.o
- .eh_frame 0x0000000008000778 0x4 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/thumb/crtend.o
- 0x000000000800077c . = ALIGN (0x4)
+ .eh_frame 0x00000000080007e0 0x0 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/thumb/crtbegin.o
+ .eh_frame 0x00000000080007e0 0x4 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/thumb/crtend.o
+ 0x00000000080007e4 . = ALIGN (0x4)
-.rel.dyn 0x000000000800077c 0x0
- .rel.iplt 0x000000000800077c 0x0 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/../../../../arm-none-eabi/lib/thumb/gba_crt0.o
+.rel.dyn 0x00000000080007e4 0x0
+ .rel.iplt 0x00000000080007e4 0x0 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/../../../../arm-none-eabi/lib/thumb/gba_crt0.o
.gcc_except_table
- 0x000000000800077c 0x0
+ 0x00000000080007e4 0x0
*(.gcc_except_table)
- 0x000000000800077c . = ALIGN (0x4)
- 0x000000000800077c __iwram_lma = .
+ 0x00000000080007e4 . = ALIGN (0x4)
+ 0x00000000080007e4 __iwram_lma = .
-.iwram 0x0000000003000000 0x0 load address 0x000000000800077c
+.iwram 0x0000000003000000 0x0 load address 0x00000000080007e4
0x0000000003000000 __iwram_start__ = ABSOLUTE (.)
*(.iwram .iwram*)
*iwram.*(.text* .data*)
0x0000000003000000 . = ALIGN (0x4)
0x0000000003000000 __iwram_end__ = ABSOLUTE (.)
- 0x000000000800077c __data_lma = (__iwram_lma + SIZEOF (.iwram))
+ 0x00000000080007e4 __data_lma = (__iwram_lma + SIZEOF (.iwram))
.bss 0x0000000003000000 0x424
0x0000000003000000 __bss_start = ABSOLUTE (.)
@@ -207,12 +206,12 @@ Linker script and memory map
0x0000000003000424 . = ALIGN (0x4)
0x0000000003000424 __bss_end__ = ABSOLUTE (.)
-.data 0x0000000003000424 0x0 load address 0x000000000800077c
+.data 0x0000000003000424 0x0 load address 0x00000000080007e4
0x0000000003000424 __data_start__ = ABSOLUTE (.)
*(.data*)
*(.gnu.linkonce.d*)
0x0000000003000424 . = ALIGN (0x4)
- 0x000000000800077c __preinit_lma = (__data_lma + SIZEOF (.data))
+ 0x00000000080007e4 __preinit_lma = (__data_lma + SIZEOF (.data))
.igot.plt 0x0000000003000000 0x0
.igot.plt 0x0000000003000000 0x0 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/../../../../arm-none-eabi/lib/thumb/gba_crt0.o
@@ -224,39 +223,39 @@ Linker script and memory map
.tm_clone_table
0x0000000003000000 0x0 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/thumb/crtend.o
-.preinit_array 0x0000000003000424 0x0 load address 0x000000000800077c
+.preinit_array 0x0000000003000424 0x0 load address 0x00000000080007e4
0x0000000003000424 __preinit_array_start = ABSOLUTE (.)
*(.preinit_array)
0x0000000003000424 __preinit_array_end = ABSOLUTE (.)
- 0x000000000800077c __init_lma = (__preinit_lma + SIZEOF (.preinit_array))
+ 0x00000000080007e4 __init_lma = (__preinit_lma + SIZEOF (.preinit_array))
-.init_array 0x0000000003000424 0x4 load address 0x000000000800077c
+.init_array 0x0000000003000424 0x4 load address 0x00000000080007e4
0x0000000003000424 __init_array_start = ABSOLUTE (.)
*(SORT_BY_NAME(.init_array.*))
*(.init_array)
.init_array 0x0000000003000424 0x4 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/thumb/crtbegin.o
0x0000000003000428 __init_array_end = ABSOLUTE (.)
- 0x0000000008000780 __fini_lma = (__init_lma + SIZEOF (.init_array))
+ 0x00000000080007e8 __fini_lma = (__init_lma + SIZEOF (.init_array))
-.fini_array 0x0000000003000428 0x4 load address 0x0000000008000780
+.fini_array 0x0000000003000428 0x4 load address 0x00000000080007e8
0x0000000003000428 __fini_array_start = ABSOLUTE (.)
*(SORT_BY_NAME(.fini_array.*))
*(.fini_array)
.fini_array 0x0000000003000428 0x4 /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/thumb/crtbegin.o
0x000000000300042c __fini_array_end = ABSOLUTE (.)
- 0x0000000008000784 __jcr_lma = (__fini_lma + SIZEOF (.fini_array))
+ 0x00000000080007ec __jcr_lma = (__fini_lma + SIZEOF (.fini_array))
-.jcr 0x000000000300042c 0x0 load address 0x0000000008000784
+.jcr 0x000000000300042c 0x0 load address 0x00000000080007ec
*(.jcr)
0x000000000300042c __data_end__ = ABSOLUTE (.)
- 0x0000000008000784 __iwram_overlay_lma = (__jcr_lma + SIZEOF (.jcr))
+ 0x00000000080007ec __iwram_overlay_lma = (__jcr_lma + SIZEOF (.jcr))
0x000000000300042c __iwram_overlay_start = .
-.iwram0 0x000000000300042c 0x0 load address 0x0000000008000784
+.iwram0 0x000000000300042c 0x0 load address 0x00000000080007ec
*(.iwram0)
0x000000000300042c . = ALIGN (0x4)
- 0x0000000008000784 PROVIDE (__load_start_iwram0 = LOADADDR (.iwram0))
- 0x0000000008000784 PROVIDE (__load_stop_iwram0 = (LOADADDR (.iwram0) + SIZEOF (.iwram0)))
+ 0x00000000080007ec PROVIDE (__load_start_iwram0 = LOADADDR (.iwram0))
+ 0x00000000080007ec PROVIDE (__load_stop_iwram0 = (LOADADDR (.iwram0) + SIZEOF (.iwram0)))
.iwram1 0x000000000300042c 0x0
*(.iwram1)
@@ -312,15 +311,15 @@ Linker script and memory map
[!provide] PROVIDE (__load_start_iwram9 = LOADADDR (.iwram9))
[!provide] PROVIDE (__load_stop_iwram9 = (LOADADDR (.iwram9) + SIZEOF (.iwram9)))
0x000000000300042c __iwram_overlay_end = .
- 0x0000000008000784 __ewram_lma = (__iwram_overlay_lma + (__iwram_overlay_end - __iwram_overlay_start))
+ 0x00000000080007ec __ewram_lma = (__iwram_overlay_lma + (__iwram_overlay_end - __iwram_overlay_start))
0x000000000300042c __iheap_start = .
0x0000000002000000 __ewram_start = ORIGIN (ewram)
-.ewram 0x0000000002000000 0x0 load address 0x0000000008000784
+.ewram 0x0000000002000000 0x0 load address 0x00000000080007ec
*(.ewram*)
0x0000000002000000 . = ALIGN (0x4)
0x0000000002000000 __ewram_end = ABSOLUTE (.)
- 0x0000000008000784 __pad_lma = (__ewram_lma + SIZEOF (.ewram))
+ 0x00000000080007ec __pad_lma = (__ewram_lma + SIZEOF (.ewram))
.sbss 0x0000000002000000 0x0
0x0000000002000000 __sbss_start__ = ABSOLUTE (.)
@@ -330,11 +329,11 @@ Linker script and memory map
0x0000000002000000 __end__ = ABSOLUTE (.)
0x0000000002000000 __eheap_start = ABSOLUTE (.)
-.pad 0x0000000002000000 0x8 load address 0x0000000008000784
+.pad 0x0000000002000000 0x8 load address 0x00000000080007ec
0x0000000002000000 0x4 LONG 0x52416b64
0x0000000002000004 0x4 LONG 0x4d
0x0000000002000008 . = ALIGN (0x4)
- 0x000000000800078c __rom_end__ = (__pad_lma + SIZEOF (.pad))
+ 0x00000000080007f4 __rom_end__ = (__pad_lma + SIZEOF (.pad))
.stab
*(.stab)
@@ -390,42 +389,42 @@ Linker script and memory map
.debug_pubnames
*(.debug_pubnames)
-.debug_info 0x0000000000000000 0x7e1
+.debug_info 0x0000000000000000 0xc70
*(.debug_info)
- .debug_info 0x0000000000000000 0x4d8 main.o
- .debug_info 0x00000000000004d8 0x7f player.o
- .debug_info 0x0000000000000557 0x28a toolbox.o
+ .debug_info 0x0000000000000000 0x967 main.o
+ .debug_info 0x0000000000000967 0x7f player.o
+ .debug_info 0x00000000000009e6 0x28a toolbox.o
-.debug_abbrev 0x0000000000000000 0x3cb
+.debug_abbrev 0x0000000000000000 0x46c
*(.debug_abbrev)
- .debug_abbrev 0x0000000000000000 0x22a main.o
- .debug_abbrev 0x000000000000022a 0x47 player.o
- .debug_abbrev 0x0000000000000271 0x15a toolbox.o
+ .debug_abbrev 0x0000000000000000 0x2cb main.o
+ .debug_abbrev 0x00000000000002cb 0x47 player.o
+ .debug_abbrev 0x0000000000000312 0x15a toolbox.o
-.debug_line 0x0000000000000000 0x3c5
+.debug_line 0x0000000000000000 0x603
*(.debug_line)
- .debug_line 0x0000000000000000 0x1f1 main.o
- .debug_line 0x00000000000001f1 0x4a player.o
- .debug_line 0x000000000000023b 0x18a toolbox.o
+ .debug_line 0x0000000000000000 0x42f main.o
+ .debug_line 0x000000000000042f 0x4a player.o
+ .debug_line 0x0000000000000479 0x18a toolbox.o
-.debug_frame 0x0000000000000000 0xa8
+.debug_frame 0x0000000000000000 0xbc
*(.debug_frame)
- .debug_frame 0x0000000000000000 0x4c main.o
- .debug_frame 0x000000000000004c 0x5c toolbox.o
+ .debug_frame 0x0000000000000000 0x60 main.o
+ .debug_frame 0x0000000000000060 0x5c toolbox.o
-.debug_str 0x0000000000000000 0x274
+.debug_str 0x0000000000000000 0x36b
*(.debug_str)
- .debug_str 0x0000000000000000 0x210 main.o
- 0x250 (size before relaxing)
- .debug_str 0x0000000000000210 0x2a player.o
+ .debug_str 0x0000000000000000 0x307 main.o
+ 0x347 (size before relaxing)
+ .debug_str 0x0000000000000307 0x2a player.o
0xdc (size before relaxing)
- .debug_str 0x000000000000023a 0x3a toolbox.o
+ .debug_str 0x0000000000000331 0x3a toolbox.o
0x167 (size before relaxing)
-.debug_loc 0x0000000000000000 0x36a
+.debug_loc 0x0000000000000000 0x5ea
*(.debug_loc)
- .debug_loc 0x0000000000000000 0x90 main.o
- .debug_loc 0x0000000000000090 0x2da toolbox.o
+ .debug_loc 0x0000000000000000 0x310 main.o
+ .debug_loc 0x0000000000000310 0x2da toolbox.o
.debug_macinfo
*(.debug_macinfo)
@@ -495,5 +494,5 @@ LOAD /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/thumb/crtend.o
LOAD /opt/devkitpro/devkitARM/lib/gcc/arm-none-eabi/10.1.0/thumb/crtn.o
OUTPUT(/home/logan/git/GBA-Dash/GBA-Dash.elf elf32-littlearm)
-.debug_ranges 0x0000000000000000 0x98
- .debug_ranges 0x0000000000000000 0x98 main.o
+.debug_ranges 0x0000000000000000 0x168
+ .debug_ranges 0x0000000000000000 0x168 main.o
diff --git a/build/main.d b/build/main.d
index 78bc462..0d8f8cf 100644
--- a/build/main.d
+++ b/build/main.d
@@ -8,6 +8,13 @@ main.o: /home/logan/git/GBA-Dash/source/main.c \
/home/logan/git/GBA-Dash/source/../include/memmap.h \
/home/logan/git/GBA-Dash/source/../include/types.h \
/home/logan/git/GBA-Dash/source/../include/memdef.h \
+ /home/logan/git/GBA-Dash/source/../include/point.h \
+ /home/logan/git/GBA-Dash/source/../include/fixed.h \
+ /home/logan/git/GBA-Dash/source/../include/velocity.h \
+ /home/logan/git/GBA-Dash/source/../include/point.h \
+ /home/logan/git/GBA-Dash/source/../include/playerObject.h \
+ /home/logan/git/GBA-Dash/source/../include/velocity.h \
+ /home/logan/git/GBA-Dash/source/../include/toolbox.h \
/home/logan/git/GBA-Dash/source/../sprites/player.h
/home/logan/git/GBA-Dash/source/../include/input.h:
/home/logan/git/GBA-Dash/source/../include/memmap.h:
@@ -18,4 +25,11 @@ main.o: /home/logan/git/GBA-Dash/source/main.c \
/home/logan/git/GBA-Dash/source/../include/memmap.h:
/home/logan/git/GBA-Dash/source/../include/types.h:
/home/logan/git/GBA-Dash/source/../include/memdef.h:
+/home/logan/git/GBA-Dash/source/../include/point.h:
+/home/logan/git/GBA-Dash/source/../include/fixed.h:
+/home/logan/git/GBA-Dash/source/../include/velocity.h:
+/home/logan/git/GBA-Dash/source/../include/point.h:
+/home/logan/git/GBA-Dash/source/../include/playerObject.h:
+/home/logan/git/GBA-Dash/source/../include/velocity.h:
+/home/logan/git/GBA-Dash/source/../include/toolbox.h:
/home/logan/git/GBA-Dash/source/../sprites/player.h:
diff --git a/build/main.o b/build/main.o
index fc8766d..387b526 100644
--- a/build/main.o
+++ b/build/main.o
Binary files differ
diff --git a/include/.playerObject.h.swp b/include/.playerObject.h.swp
new file mode 100644
index 0000000..00a18a7
--- /dev/null
+++ b/include/.playerObject.h.swp
Binary files differ
diff --git a/include/fixed.h b/include/fixed.h
new file mode 100644
index 0000000..80d3ee9
--- /dev/null
+++ b/include/fixed.h
@@ -0,0 +1,77 @@
+#include "types.h"
+
+#ifndef FIXED_H
+#define FIXED_H
+
+#define FIX_SHIFT 8
+#define HALF_FIX_SHIFT 4
+#define FIX_SCALE ( 1 << FIX_SHIFT )
+#define FIX_SCALE_FLOAT ((float)(FIX_SCALE))
+
+typedef s32 FIXED;
+
+static inline FIXED fixed_OverMultiply(FIXED a, FIXED b) {
+ // This should multiply two fixed-point numbers sacrificing a little
+ // accuracy in exchange for less chance of an overflow
+
+ return ((a >> HALF_FIX_SHIFT) * (b >> HALF_FIX_SHIFT));
+}
+
+static inline FIXED fixed_multiply (FIXED a, FIXED b) {
+ // Multiply two fixed numbers. Possibility of overflow.
+ return (a * b) >> FIX_SHIFT;
+}
+
+static inline FIXED fixed_divide(FIXED a, FIXED b) {
+ // Divide two fixed point numbers
+ if (b != 0){
+ return (a * FIX_SCALE) / b;
+ }
+ else {
+ // Return a large number if division by zero
+ // Hopefully this won't break anything :P
+ return 100000 << FIX_SHIFT;
+ }
+}
+
+static inline FIXED float_to_fixed(float a) {
+ // Convert a float to fixed point
+ return ((FIXED)(a * FIX_SCALE_FLOAT));
+}
+
+static inline float fixed_to_float(FIXED a) {
+ // Convert fixed point to float
+ return (a / FIX_SCALE_FLOAT);
+}
+
+static inline void swapFixed(FIXED *a, FIXED *b) {
+ // Swap two fixed point integer pointers
+ FIXED temp;
+ temp = *a;
+ *a = *b;
+ *b = temp;
+}
+
+static inline FIXED fixed_sqrt(FIXED a, int iterations) {
+ // Calculate square root of a fixed-point number using Binary-Search
+ FIXED low = 0;
+ FIXED high = a;
+ FIXED mid;
+ FIXED midSquared;
+ for (int i = 0; i < iterations; i++) {
+ mid = fixed_divide((low + high), 2 << FIX_SHIFT);
+ midSquared = fixed_OverMultiply(mid, mid);
+ if (midSquared == a) {
+ return mid;
+ }
+ else if (midSquared > a) {
+ high = mid;
+ }
+ else {
+ low = mid;
+ }
+ }
+ return mid;
+}
+
+#endif // FIXED_H
diff --git a/include/playerObject.h b/include/playerObject.h
new file mode 100644
index 0000000..9394c4f
--- /dev/null
+++ b/include/playerObject.h
@@ -0,0 +1,73 @@
+#include "types.h"
+#include "point.h"
+#include "velocity.h"
+#include "toolbox.h"
+#include "fixed.h"
+
+#ifndef PLAYEROBJECT_H
+#define PLAYEROBJECT_H
+
+#define GRAVITY 0.75
+
+typedef struct playerObject {
+ VELOCITY vel;
+ POINT pt;
+ u32 rotation; // Rotation amount
+ OBJ_ATTR *obj; // Attributes of the object for GBA
+ int pallete_bank; // Index of pallete
+ int tile_id; // Index of player tile
+ int isJumping;
+} ALIGN(4) playerObject; // Word-align to ensure corruption doesn't occur
+
+static inline void initializePlayerObject (playerObject *object) {
+ // Initialize the point and velocity of an object
+ object->vel = createVelocity(0, 0);
+ object->pt = createPoint(20 << FIX_SHIFT, 100 << FIX_SHIFT);
+}
+
+static inline playerObject createPlayerObject (OBJ_ATTR *obj_buffer, int pallete_bank, int tile_id) {
+ // Create a player object from data
+ playerObject temp;
+ initializePlayerObject(&temp);
+ temp.rotation = 0;
+ temp.obj = obj_buffer;
+ temp.pallete_bank = pallete_bank;
+ temp.tile_id = tile_id;
+ temp.isJumping = 0;
+ obj_set_attr(temp.obj,
+ ATTR0_SQUARE, // Set attribute 1 to be a square
+ ATTR1_SIZE_16, // Set size to 16 x 16
+ ATTR2_PALBANK(pallete_bank) | tile_id // Which pallete to use, as we are in
+ // 16-color mode
+ );
+ obj_set_pos(temp.obj, temp.pt.x >> FIX_SHIFT, temp.pt.y >> FIX_SHIFT);
+ return temp;
+}
+
+static inline void applyGravity (playerObject *object) {
+ // Apply a gravity constant to a player
+ object->vel.dy += float_to_fixed(GRAVITY);
+ // This is a weird convention to have gravity in the positive direction,
+ // but I don't want to deal with coordinate changing. Too lazy
+}
+
+static inline void updatePlayer (playerObject *object, u32 GROUND_LEVEL) {
+ // Update the position of a player object
+ updatePoint(&object->pt, &object->vel);
+ if (object->pt.y >> FIX_SHIFT >= GROUND_LEVEL) {
+ // Only apply gravity if player is not touching the ground
+ object->isJumping = 0;
+ object->pt.y = GROUND_LEVEL << FIX_SHIFT; // Don't go through ground
+ object->vel.dy = 0;
+ }
+ else {
+ object->isJumping = 1;
+ applyGravity(object);
+ }
+ // Update the player object's attributes' position
+ obj_set_pos(object->obj, object->pt.x >> FIX_SHIFT, object->pt.y >> FIX_SHIFT);
+ // Update the player's second attribute (tile and pallete bank)
+ object->obj->attr2 = ATTR2_BUILD(object->tile_id, object->pallete_bank, 0);
+}
+
+#endif // PLAYEROBJECT_H
diff --git a/include/point.h b/include/point.h
new file mode 100644
index 0000000..5c69422
--- /dev/null
+++ b/include/point.h
@@ -0,0 +1,28 @@
+#include "types.h"
+#include "fixed.h"
+
+#ifndef POINT_H
+#define POINT_H
+
+typedef struct POINT {
+ FIXED x;
+ FIXED y;
+} ALIGN(4) POINT;
+
+static inline POINT createPoint (FIXED x, FIXED y) {
+ // Create a point from data
+ POINT temp;
+ temp.x = x;
+ temp.y = y;
+ return temp;
+}
+
+static inline POINT addPoint (POINT *a, POINT *b) {
+ // Add two points
+ POINT temp;
+ temp.x = a->x + b->x;
+ temp.y = a->y + b->y;
+ return temp;
+}
+
+#endif // POINT_H
diff --git a/include/velocity.h b/include/velocity.h
new file mode 100644
index 0000000..278226c
--- /dev/null
+++ b/include/velocity.h
@@ -0,0 +1,35 @@
+#include "types.h"
+#include "fixed.h"
+#include "point.h"
+
+#ifndef VELOCITY_H
+#define VELOCITY_H
+
+typedef struct VELOCITY {
+ FIXED dx;
+ FIXED dy;
+} ALIGN(4) VELOCITY;
+
+static inline VELOCITY createVelocity (FIXED dx, FIXED dy) {
+ // Create velocity from data
+ VELOCITY temp;
+ temp.dx = dx;
+ temp.dy = dy;
+ return temp;
+}
+
+static inline VELOCITY addVelocities (VELOCITY *a, VELOCITY *b) {
+ // Add two velocities
+ VELOCITY temp;
+ temp.dx = a->dx + b->dx;
+ temp.dy = a->dy + b->dy;
+ return temp;
+}
+
+static inline void updatePoint (POINT *pt, VELOCITY *vel) {
+ // Update a point with a velocity
+ pt->x += vel->dx;
+ pt->y += vel->dy;
+}
+
+#endif // VELOCITY_H
diff --git a/source/.main.c.swp b/source/.main.c.swp
new file mode 100644
index 0000000..b3f5f6d
--- /dev/null
+++ b/source/.main.c.swp
Binary files differ
diff --git a/source/main.c b/source/main.c
index a36688d..ae0cf05 100644
--- a/source/main.c
+++ b/source/main.c
@@ -4,13 +4,18 @@
#include "../include/memmap.h"
#include "../include/types.h"
#include "../include/memdef.h"
+
+#include "../include/point.h"
+#include "../include/velocity.h"
+#include "../include/playerObject.h"
#include "../sprites/player.h"
OBJ_ATTR obj_buffer[128];
OBJ_AFFINE *obj_aff_buffer= (OBJ_AFFINE*)obj_buffer; // Object affine-buffer
void obj_test() {
- int x= 96, y= 32;
+ int x, y;
+ x = 10; y = 10;
u32 tid= 0, pb= 0;
OBJ_ATTR *player = &obj_buffer[0];
@@ -38,9 +43,20 @@ int main() {
REG_DISPCNT= DCNT_OBJ | DCNT_OBJ_1D;
- obj_test();
+ playerObject player = createPlayerObject(&obj_buffer[0], 0, 0);
+
+
+ while(1) {
+ vid_vsync();
+ key_poll();
+
+ if ((key_is_down(KEY_A) || key_hit(KEY_A)) && !player.isJumping) {
+ player.vel.dy -= 9 << FIX_SHIFT;
+ }
- while(1);
+ updatePlayer(&player, 140);
+ oam_copy(oam_mem, obj_buffer, 1);
+ }
return 0;
}