shithub: rgbds

Download patch

ref: 02d957278da707dfea6ce02ab867f7e127d5a645
parent: 6feb1fb73a0c6e3127ab58f82d4673f3aba2c06c
author: ISSOtm <[email protected]>
date: Tue Apr 12 21:05:37 EDT 2022

Document output formats

--- a/man/rgbgfx.1
+++ b/man/rgbgfx.1
@@ -435,15 +435,37 @@
 Since few image editors (such as GIMP) expose that detail, this behavior is only kept for compatibility and should be considered deprecated.
 .Sh OUTPUT FILES
 .Ss Tile data
-TODO.
+Tile data is output like a binary dump of VRAM, following the Game Boy's native format.
+Each tile is 16 bytes, 2 per row of 8 pixels; the first byte
+.Pq or Dq bitplane
+contains the least significant bit of the color ID of each pixel, the second one the most significant bit.
+The most significant bits of each byte are for the leftmost pixel of its row, and so on, with the least significant bits describing the rightmost pixel.
+.Pp
+When the bit depth
+.Pq Fl d
+is set to 1, every other byte (being all zeros) is simply not output.
 .Ss Palette data
 Palette data is output like a dump of GBC palette memory: the output is a binary file.
-Each color is written as GBC-native little-endian RGB555 (that is, the first byte contains the red and the lower 3 bits of green).
+Each color is written as GBC-native little-endian RGB555 (that is, the first byte contains the red and the lower 3 bits of green, and the second byte the upper 2 bits of green and the 5 bits of blue, plus an unused bit set to 0).
 There is no padding between colors, nor between palettes; however, empty colors in the palettes are TODO.
-.Ss Tilemap data
-TODO.
-.Ss Attrmap data
-TODO.
+.Ss Tile map data
+Tile maps are output as binary files.
+A tile map is an array of tile IDs, with one byte per tile ID.
+The first byte always corresponds to the ID of the tile in top-left corner of the input image; the second byte is either the ID of the tile to its right (by default), or below it
+.Pq with Fl Z ;
+and so on.
+Rows / columns (respectively) are stored consecutively, with no padding.
+.Ss Attribute map data
+Attribute maps mirror the format of tile maps, like on the GBC, especially the order in which bytes are output.
+The contents of individual bytes follows the GBC's native format:
+.Bl -column "Bit 2\(en0" "Background Palette number"
+.It Bit 7 Ta BG-to-OAM Priority Ta Set to 0
+.It Bit 6 Ta Vertical Flip Ta 0=Normal, 1=Mirror vertically
+.It Bit 5 Ta Horizontal Flip Ta 0=Normal, 1=Mirror horizontally
+.It Bit 4 Ta Not used Ta Set to 0
+.It Bit 3 Ta Tile VRAM Bank number Ta 0=Bank 0, 1=Bank 1
+.It Bit 2\(en0 Ta Background Palette number Ta BGP0-7
+.El
 .Sh REVERSE MODE
 .Nm
 can produce a PNG image from valid data.
@@ -527,6 +549,10 @@
 .Xr rgblink 1 ,
 .Xr rgbfix 1 ,
 .Xr gbz80 7
+.Pp
+The Game Boy hardware reference
+.Lk https://gbdev.io/pandocs/Rendering.html Pan Docs ,
+particularly the section about graphics.
 .Sh HISTORY
 .Nm
 was originally created by
--- a/src/gfx/main.cpp
+++ b/src/gfx/main.cpp
@@ -130,15 +130,15 @@
 };
 
 static void printUsage(void) {
-	fputs("Usage: rgbgfx [-r] [-CmuVZ] [-v [-v ...]] [-a <attr_map> | -A] [-b base_ids]\n"
-	      "       [-c color_spec] [-d <depth>] [-L slice] [-N nb_tiles] [-n nb_pals]\n"
-	      "	      [-o <out_file>] [-p <pal_file> | -P] [-s nb_colors] [-t <tile_map> | -T]\n"
-	      "	      [-U unit_size] [-x <tiles>] <file>\n"
+	fputs("Usage: rgbgfx [-r stride] [-CmuVZ] [-v [-v ...]] [-a <attr_map> | -A]\n"
+	      "       [-b base_ids] [-c color_spec] [-d <depth>] [-L slice] [-N nb_tiles]\n"
+	      "	      [-n nb_pals] [-o <out_file>] [-p <pal_file> | -P] [-s nb_colors]\n"
+	      "	      [-t <tile_map> | -T] [-U unit_size] [-x <tiles>] <file>\n"
 	      "Useful options:\n"
-	      "    -m, --mirror-tiles	optimize out mirrored tiles\n"
-	      "    -o, --output <path>       set the output binary file\n"
-	      "    -t, --tilemap <path>      set the output tilemap file\n"
-	      "    -u, --unique-tiles	optimize out identical tiles\n"
+	      "    -m, --mirror-tiles    optimize out mirrored tiles\n"
+	      "    -o, --output <path>   set the output binary file\n"
+	      "    -t, --tilemap <path>  set the output tilemap file\n"
+	      "    -u, --unique-tiles    optimize out identical tiles\n"
 	      "    -V, --version	     print RGBGFX version and exit\n"
 	      "\n"
 	      "For help, use `man rgbgfx' or go to https://rgbds.gbdev.io/docs/\n",