Skip to main content

32Blit asset preparation and upload tools

Project description

32blit Tools

Build Status Coverage Status PyPi Package Python Versions

This toolset is intended for use with the 32Blit console to prepare assets and upload games.

Running

The 32Blit toolset contains subcommands for each tool, you can list them with:

32blit --help
  • image - Convert images/sprites for 32Blit
  • font - Convert fonts for 32Blit
  • map - Convert popular tilemap formats for 32Blit
  • raw - Convert raw/binary or csv data for 32Blit
  • pack - Pack a collection of assets for 32Blit
  • cmake - Generate CMake configuration for the asset packer
  • flash - Flash a binary or save games/files to 32Blit
  • metadata - Tag a 32Blit .blit file with metadata
  • relocs - Prepend relocations to a game binary
  • version - Print the current 32blit version

To run a tool, append its name after the 32blit command, eg:

32blit version

Tools

Metadata

Build metadata, and add it to a .blit file.

Flash

Flash and manage games on your 32Blit over USB serial.

Relocs

Collate a list of addresses that need patched to make a .blit file relocatable and position-independent.

Cmake

Generate CMake files for metadata information and/or asset pipeline inputs/outputs.

Assets

You will typically create assets using the "asset pipeline", configured using an assets.yml file which lists all the files you want to include, and how they should be named in code.

An assets.yml file might look like:

# Define an output target for the asset builder
# in this case we want a CSource (and implicitly also a header file)
# type auto-detection will notice the ".cpp" and act accordingly
assets.cpp:
  prefix: asset_
  # Include assets/sprites.png
  # and place it in a variable named "asset_sprites"
  # Since it ends in ".png" the builder will run "sprites_packed" to convert our source file
  assets/sprites.png:
    name: sprites
    palette: assets/sprites.act
    strict: true  # Fail if a colour does not exist in the palette
    transparent: 255,0,255

  # Include assets/level.tmx
  # and place it in a variable named "asset_level_N_tmx"
  # Since it ends in ".tmx" the builder will run "map_tiled" to convert our source file
  assets/level*.tmx:

Fonts

Converts a ttf file or image file into a 32Blit font.

Supported formats:

  • Image .png, .gif
  • Font .ttf

Images

All image assets are handled by Pillow so most image formats will work, be careful with lossy formats since they may add unwanted colours to your palette and leave you with oversized assets.

Supported formats:

  • 8bit PNG .png
  • 24bit PNG .png

Options:

  • palette - Image or palette file (Adobe .act, Pro Motion NG .pal, GIMP .gpl) containing the asset colour palette
  • transparent - Transparent colour (if palette isn't an RGBA image), should be either hex (FFFFFF) or R,G,B (255,255,255)
  • packed - (Defaults to true) will pack the output asset into bits depending on the palette size. A 16-colour palette would use 4-bits-per-pixel.
  • strict - Only allow colours that are present in the palette image/file

Maps/Levels

Supported formats:

Raw Binaries/Text Formats

Supported formats:

  • CSV .csv
  • Binary .bin, .raw

Changelog

0.2.0

  • New: Version tool: 32blit version
  • Packer: Format support for wildcard asset names

0.1.4

  • New: migrated PIC relocs tool into tools

0.1.3

  • Packer: Fix asset path handing to be relative to working directory

0.1.2

  • Flasher: Add list/del commands
  • Packer: Fix bug where asset packer shared class instances and state
  • Metadata: Find images when building from a config not in working directory
  • Metadata: Require only one of --file or --config options

0.1.1

  • Export metadata config to CMake
  • Add support for packing metadata splash to icns format for macOS

0.1.0

  • Fix palettes to support 256 colours (count will be 0)
  • Parse metadata and relocations with Construct
  • Breaking: Packed image format has changed!

0.0.9

  • Add support for PIC reloc'd binaries with RELO header
  • Add string arg support for asset filename to cmake tool

0.0.8

  • Add autoreset from game to firmware when running flash save
  • Add flash info to determine if in game or firmware
  • Add metadata dependency output from cmake tool
  • Fix asset dependency output to include additional files like palette
  • Redirect errors to stderr
  • Quiet! Use -vvvv for info, warnings, errors and debug information.

0.0.7

  • Add metadata tool - tags binary with metadata from a .yml file
  • Fix relative paths for packer palette files
  • Add support for subdirectories to 32blit flash save

0.0.6

  • Font tool (thanks @Daft-Freak)
  • Flash command with multi-target function (thanks @Daft-Freak)
  • Bugfixes to palette handling (thanks @Daft-Freak)
  • Bugfixes to package recognition (seemed to affect Python 3.8 on Windows)
  • Friendly (ish) error message when a .tmx tilemap with 0-index tiles is used (tmx is 1-indexed for valid tiles)

0.0.5

  • Output data length symbols (thanks @Daft-Freak)
  • Fix --packed to be default, again (packed can be disabled with --packed no)
  • Various other tweaks
  • Start of 32blit file upload support

0.0.4

  • Default images to packed (packed arg now takes a bool)
  • Fix bug in sprite payload size (thanks @Daft-Freak)

0.0.3

  • Fix packaging mishap so tool actually works

0.0.2

  • Real initial release
  • Pack, cmake and asset commands working
  • Very beta!

0.0.1

  • Initial Release

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

32blit-0.2.0.tar.gz (22.5 kB view details)

Uploaded Source

Built Distribution

32blit-0.2.0-py3-none-any.whl (28.8 kB view details)

Uploaded Python 3

File details

Details for the file 32blit-0.2.0.tar.gz.

File metadata

  • Download URL: 32blit-0.2.0.tar.gz
  • Upload date:
  • Size: 22.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/46.0.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.6.9

File hashes

Hashes for 32blit-0.2.0.tar.gz
Algorithm Hash digest
SHA256 d64d0db8106859969d1e5d3d31002594d94d38458d7ad5e1b753054045e294f5
MD5 bab7d6c412791b806274f8f16bc14848
BLAKE2b-256 837ccd0381a4d37b884c09b49aae206ce238f5927762085e5a2dde78ae56e9d6

See more details on using hashes here.

File details

Details for the file 32blit-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: 32blit-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 28.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/46.0.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.6.9

File hashes

Hashes for 32blit-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9b33595d76e4f1684a3cff5bf3f9081f618591b820c56fece0eaa118215bd691
MD5 c8b18d5cd7f24f9bd26e5db592460a96
BLAKE2b-256 2b0b874eb607336bee1abcdc2f13d4d46c61736faf77c42b610cf97dceb0ebed

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page