Difference between revisions of "SPR Spritesheet"

From Final Fantasy Hacktics Wiki
Jump to navigation Jump to search
m
m
Line 9: Line 9:
 
Each set of 4 bits is the palette color index of the pixel. The spritesheet is 256 pixels wide and 488 pixels tall.
 
Each set of 4 bits is the palette color index of the pixel. The spritesheet is 256 pixels wide and 488 pixels tall.
  
The lower half of unit spritesheets (starting at the arms for attacks) has compressed regions (see [[Decompress Attack spritesheet]]). This starts at file offset 0x9200 (row 288 of the image)
+
The lower half of unit spritesheets (starting at the arms for attacks) has compressed regions (see [[Decompress Attack spritesheet]]). This starts at file offset 0x9200 (row 288 of the image). Non-unit sprites, such as OTHER and WEP do not have the compressed section.
  
 
The compression algorithm is: 0 - some half byte - how many 0s there are
 
The compression algorithm is: 0 - some half byte - how many 0s there are

Revision as of 22:39, 17 January 2025

SPR (Unit Sprite) files contain the bitmap data for a sprite. Sp2 are similar format used for extra images used by MON shp types.

Palette Data

The file starts with the palette data and contains 256 colors (512 bytes), 16 palettes of 16 colors each. Palette's use 2 bytes per color, 1 bit for alpha, followed by 5 bits per channel (B,G,R). The first 8 palettes are for the unit, the second 8 palettes are for the portrait.

OTHER.SPR is a special case and has 512 colors. 5 palettes each for chicken, frog, chest, and crystal, an all black palette between crystal and chests, and 11 mostly black palettes at the end that are normally unusable.

Pixel Data

Each set of 4 bits is the palette color index of the pixel. The spritesheet is 256 pixels wide and 488 pixels tall.

The lower half of unit spritesheets (starting at the arms for attacks) has compressed regions (see Decompress Attack spritesheet). This starts at file offset 0x9200 (row 288 of the image). Non-unit sprites, such as OTHER and WEP do not have the compressed section.

The compression algorithm is: 0 - some half byte - how many 0s there are

if halfbyte = 0, 1 digit in number of 0s

if halfbyte = 7, 2 digits in number of 0s

if halfbyte = 8, 3 digits in number of 0s

if halfbyte != [0,7,8], number of 0s = halfbyte

Example: 08100 is the hex string for 256 0s (128 bytes of 0)