Jump to content

Engine calls (Boktai 1): Difference between revisions

no edit summary
mNo edit summary
No edit summary
 
(5 intermediate revisions by the same user not shown)
Line 152: Line 152:
| 0xb4b4 || 0x081217d0 || 78 ||
| 0xb4b4 || 0x081217d0 || 78 ||
|-
|-
| 0x4ae5 || 0x08122bb0 || 28 || Palette related (p=3x palette file ids)
| 0x4ae5 || 0x08122bb0 || 28 || Load [[Master_file_table|background palette]] file  (p=3x palette file ids)
|-
|-
| 0x329b || 0x08123e54 || 6 ||
| 0x329b || 0x08123e54 || 6 ||
Line 256: Line 256:
| 0xb8b9 || 0x081cee2c || 6 ||
| 0xb8b9 || 0x081cee2c || 6 ||
|-
|-
| 0xc0b0 || 0x081d02c4 || 361 || Camera_Unlock()
| 0xc0b0 || 0x081d02c4 || 361 || Camera_Create()
|-
|-
| 0x430d || 0x081d0bc8 || 920
| 0x430d || 0x081d0bc8 || 920
Line 276: Line 276:
Copies values into the indexed-ptr. Partial writes are supported (you can specify less values than the size of the indexed-ptr).
Copies values into the indexed-ptr. Partial writes are supported (you can specify less values than the size of the indexed-ptr).
|-
|-
| 0x7636 || 0x08000b98 || 256 ||
| 0x7636 || 0x08000b98 || 256
| Loop(a=argument count of callback, r=number of executions, d=data to loop over, e=callback block)
This is complicated, need some examples... keywords "a" and "r" are always required, keyword "d" is optional: if provided, the loop behaves like a "for each" loop over the provided data, if not provided it behaves like a "for" loop between 0 and r.
|-
|-
| 0x3469 || 0x08000c54 || 141
| 0x3469 || 0x08000c54 || 141
Line 692: Line 694:
| 0xf00c || 0x0811c6f8 || 9 || UI_CreateItemNotification(p=position, t=sprite?)
| 0xf00c || 0x0811c6f8 || 9 || UI_CreateItemNotification(p=position, t=sprite?)
|-
|-
| 0x3535 || 0x0811d4f4 || 2
| 0x3535 || 0x0811d4f4 || 2 || Map_LoadGraphics(t=?, c=?, d=?)
| Map_LoadGraphics(t=?, c=?, d=?)
‘c’ and ‘t’ might be a paired tileset id?
|-
|-
| 0x4383 || 0x0811dfbc || 11 ||
| 0x4383 || 0x0811dfbc || 11 ||
Line 708: Line 708:
| 0x6255 || 0x08120f84 || 9 ||
| 0x6255 || 0x08120f84 || 9 ||
|-
|-
| 0x7a27 || 0x08121998 || 83 || spawn fog?
| 0x7a27 || 0x08121998 || 83
| Video_LoadTileMap(d=file id, t=type, n=layer count, i=layer indices, c=layer IDs)
d: [[Tile map file]] ID<br>
t: Type, how layers are assigned to GBA background layers: 0=BG0, 1=BG2+BG3, 2=BG3, 3=BG1, 4=BG1+BG3, 5=BG2+BG1, 6=BG2+BG3=BG1, else=BG2 but invisible in REG_DISPCNT)<br>
n: Layer count, how many layers to load. Defaults to 1. For example, t=4 and n=1 would load only BG1, t=4 and n=2 would load BG1 and BG3.<br>
i: Layer indicies: Specifies which layers to load from the tile map file, via indices into its layerDefinition array.<br>
c: Layer IDs: Specifies which layers to load from the tile map file, by referencing the TileMapLayer.id field<br>
Precedence for layer selection: keyword i, else keyword c, else defaults to [0, 1, 2].<br>
If the tile map file contains a tile set, it will also be loaded into VRAM as well.
|-
|-
| 0xe4b1 || 0x08121adc || 2 ||
| 0xe4b1 || 0x08121adc || 2 ||
|-
|-
| 0x11d4 || 0x08121bd4 || 385 ||
| 0x11d4 || 0x08121bd4 || 385
| Video_LoadTileSet(t=type, c=part ids, d=tile set file id, m=tile map file id, s=load offset)
t: Type; only two relevant cases: If 0 (=BG0), then load offset will be ''forced'' to 0x400 tiles, irrespective of the m and s keywords. Otherwise, the m and s keywords are used.<br>
c: [[Tile set file]] part IDs to load (1-n)<br>
d: Tile set file ID<br>
m: [[Tile map file]] ID, only used to determine the load offset.<br>
s: Load offset in tiles<br>
''Load offset explanation'': Tiles are copied into VRAM starting at that offset. By specifying different load offsets for different tile sets, multiple tile sets can coexist in VRAM simultaneously. If both m and s are specified, m takes precedence.
|-
|-
| 0xca7d || 0x08122370 || 31 ||
| 0xca7d || 0x08122370 || 31 ||
Line 1,020: Line 1,035:
| 0xeaac || 0x081ce324 || 1 ||
| 0xeaac || 0x081ce324 || 1 ||
|-
|-
| 0x5c9e || 0x081ce860 || 84 ||
| 0x5c9e || 0x081ce860 || 84 || With 0 parameters: Back up stat & world structs (see RAM map). With 1+ parameters: Back up specific pointers from the stat & world structs.
|-
|-
| 0xa222 || 0x081ce898 || 1 ||
| 0xa222 || 0x081ce898 || 1 ||
Line 1,026: Line 1,041:
| 0xbec2 || 0x081ced7c || 19 ||
| 0xbec2 || 0x081ced7c || 19 ||
|-
|-
| 0x30ad || 0x081cf048 || 29 ||
| 0x30ad || 0x081cf048 || 29 || Map_LoadMap(p=[[Map file]] ID, ...=?)
|-
|-
| 0x7539 || 0x081cf130 || 40 ||
| 0x7539 || 0x081cf130 || 40 ||
Line 1,042: Line 1,057:
| 0xcaee || 0x081cfa14 || 15 ||
| 0xcaee || 0x081cfa14 || 15 ||
|-
|-
| 0x2a8c || 0x081cfa6c || 296 ||
| 0x2a8c || 0x081cfa6c || 296 || Camera_ConnectToTilemap(...) - Positions the camera on the tile map (call every frame)
|-
|-
| 0x063b || 0x081cfb84 || 37 || Camera_SetBounds(min_x, max_x, min_y, max_y)
| 0x063b || 0x081cfb84 || 37 || Camera_SetBounds(min_x, max_x, min_y, max_y)