Skip to main content

an package to create sprite sheets or sprite atlases

Project description

PyTexturePacker PyPI Status Build status Documentation Status

PyTexturePacker is an open source python package, released under the MIT License.

A subset of feature of TexturePacker has been implemented in this package.

Now! the cpp version is available, visit CppTexturePacker for more infomation.

Features

MaxRectsBinPack algorithm is used to generate sprite sheet in this package.

MaxRectsBinPack

MaxRectsBinPack is currently the best packing algorithm. It tries to use the least texture space by applying different heuristics when placing the sprites.

  • MaxRects

    • Best-known algorithm for packing textures

    • Is fast and has a high packing ratio

    • Enable rotation for best results

Installation

Install Pillow with pip:

$ pip install PyTexturePacker

Usage

Here comes an example of using PyTexturePacker to pack texture images from a directory.

from PyTexturePacker import Packer

def pack_test():
    # create a MaxRectsBinPacker
    packer = Packer.create(max_width=2048, max_height=2048, bg_color=0xffffff00)
    # pack texture images under directory "test_case/" and name the output images as "test_case".
    # "%d" in output file name "test_case%d" is a placeholder, which is the atlas index, starting with 0.
    packer.pack("test_case/", "test_case%d")

Packer Setting

bg_color

The background color of output image. The pixels of the empty area in the output image will be filled with bg_color. The default value is 0x00000000, which is in format of “RGBA”. A tuple of values can also be accepted, like (R, G, B, A).

texture_format

Choose the texture format that the output file will use, for example “.jpg”. The default texture format is “.png”.

max_width

Sets the maximum width for the texture, default is 4096.

max_height

Sets the maximum height for the texture, default is 4096.

enable_rotated

Allows the rotating of sprites clockwise or counterclockwise by 90 degrees if they have a better fit in the texture. Might not be supported by all game/web frameworks.

force_square

Forces the texture to have a squared size.

border_padding

Border padding is the space between the sprites and the border of the sprite sheet. Value adds transparent pixels around the borders of the sprite sheet. Default is 2.

shape_padding

Shape padding is the space between sprites. Value adds transparent pixels between sprites to avoid artifacts from neighbor sprites. The transparent pixels are not added to the sprites. Default is 2. Use a value of at least 2 to avoid dragging in pixels from neighbor sprites when using OpenGL rendering.

inner_padding

Adds transparent pixels to the inside of the sprite, growing it. Default is 0.

There are two uses for this:

  • It can help in preventing cut-off artifacts near the edges of scaled sprites. E.g. if your sprite has a few pixels along its own boundaries, scaling the sprite up or down won’t let these pixels appear as gaps or cuts.

  • It considerably reduces aliasing along the polygon edges when rotating trimmed or cropped sprites. E.g. if your sprite has many pixels along its own boundaries, it will be drawn more smoothly when rotating it.

trim_mode

Removes transparent pixels from a sprite’s border. This shrinks the sprite’s size, allows tighter packing of the sheet, and speeds up rendering since transparent pixels don’t need to be processed. Pixels with an alpha value below this value will be considered transparent when trimming the sprite. Allowed values: 0 to 255, default is 0. When it’s set to 0, the trim mode is disabled. Very useful for sprites with nearly invisible alpha pixels at the borders.

reduce_border_artifacts

Adds color to transparent pixels by repeating a sprite’s outer color values. These color values can reduce artifacts around sprites and removes dark halos at transparent borders. This feature is also known as “Alpha bleeding”.

extrude

Extrude repeats the sprite’s pixels at the border. Sprite’s size is not changed.

There are two uses for this:

  • Reduce flickering in some cases where sprites have to be put next to each other in the final program.

  • Check if sprite outlines are OK. E.g. if you want to use sprites to create tilemaps this allows you to see if there are semi-transparent pixels at the borders of the tiles.

atlas_format

Choose the texture config format that file will use. Available options “plist”, “json” and “csv”. Aditionally, you can use a custom function that will receive a dictionary and a path and handle the format in some custom way. The default texture config output format is “plist”.

atlas_ext

Forces the atlas to use this extension regardless of the format. If not provided, the atlas will use the default extension for the chosen format.

Contribute

  • Issue Tracker: github.com/wo1fsea/PyTexturePacker/issues

  • Source Code: github.com/wo1fsea/PyTexturePacker

Any types of contribution are welcome. Thanks.

Support

If you are having issues, please let us know. Please feel free to contact me. email: quanyongh@foxmail.com

License

The project is released under the terms of MIT License. You may find the content of the license here, or LICENSE.txt inside the project directory.

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

PyTexturePacker-1.2.1.tar.gz (16.1 kB view details)

Uploaded Source

Built Distribution

PyTexturePacker-1.2.1-py3-none-any.whl (18.2 kB view details)

Uploaded Python 3

File details

Details for the file PyTexturePacker-1.2.1.tar.gz.

File metadata

  • Download URL: PyTexturePacker-1.2.1.tar.gz
  • Upload date:
  • Size: 16.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.8

File hashes

Hashes for PyTexturePacker-1.2.1.tar.gz
Algorithm Hash digest
SHA256 9a3b512c8644f462bd3b974d71f60a0083734e13df5308b75f01f3e744b2b55c
MD5 693318ebd0b832adacc710f958c875a7
BLAKE2b-256 a8c0c26969414cd23c13d8e68fc74b1a2766478397d91eb6a46cab0042af2b94

See more details on using hashes here.

File details

Details for the file PyTexturePacker-1.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for PyTexturePacker-1.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 53db04d8ea130c4cf1bd48343997914a7ed2d63effd424e452bb8195f5c74a45
MD5 486a85123f0d67a1a344ba726c391aaf
BLAKE2b-256 5988326a1459e27cfa470d9f0bc3343c47c1bfd2e1d6766705387cc7b9da7f34

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