Python implementation of swizzle and deswizzle of video games textures
Project description
A python library which allow to swizzle and deswizzle some video games textures. Supported platforms: Nintendo Switch and PS4
Usage
Nintendo Switch:
from pyswizzle import nsw_deswizzle, nsw_swizzle
Deswizzle bytes:
deswizzled_bytes = nsw_deswizzle(bytes, im_size, block_size, bytes_per_block, swizzle_mode)
Swizzle bytes:
swizzled_bytes = nsw_swizzle(bytes, im_size, block_size, bytes_per_block, swizzle_mode)
PS4:
from pyswizzle import ps4_deswizzle, ps4_swizzle
Deswizzle bytes:
deswizzled_bytes = ps4_deswizzle(bytes, im_size, block_size, bytes_per_block)
Swizzle bytes:
swizzled_bytes = ps4_deswizzle(bytes, im_size, block_size, bytes_per_block)
Parameters
bytes: a bytes-like object, representing image data
im_size: a tuple (im_width,im_height) representing the dimensions of the image.
block_size: a tuple (bloc_width,bloc_height) representing the dimensions of the compression blocks of the image encoding. For example, BC7 and BC1 are encoded with blocks of 4x4 pixels, so you should input (4,4), while ASTC6x6 are encoded with blocks of 6x6 pixels, so you should input (6,6). For format that are not block compressed like RGBA8888, you should input (1,1).
bytes_per_block: the number of bytes used to encode one block. For BC7, it's equal to 16; for BC1: 8; for ASTC6x6: 16; for RGBA8888: 4, etc.
swizzle_mode: the swizzle mode, for Nintendo Switch.
Notes
Not all images can be swizzled or deswizzled, they might require some padding.
For Nintendo Switch, the image width must be a multiple of 64 x block_width / bytes_per_block pixels,
and the image_height a multiple of 8 x block_height x (2**swizzle_mode) pixels.
For PS4, the image width must be a multiple of 8 x block_width pixels,
and the image_height a multiple of 8 x block_height pixels.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for pyswizzle-1.0.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | dd0139030d3130ae1d293dfc0c4d72e5882f41d476351eb62ad54a256690576a |
|
MD5 | dcbc1a6720e8ce97951f5b44f2ef2856 |
|
BLAKE2b-256 | 4ef5b5cacae0293d5f8bd1487f513209daaec7b4cab14281b593e19a232f5236 |