#2d-game #2d #graphics #load-image #sprite-sheet #game

aseprite

A crate to load files from the aseprite sprite editor

4 releases

Uses old Rust 2015

0.1.3 Jun 3, 2017
0.1.2 Apr 27, 2017
0.1.1 Apr 25, 2017
0.1.0 Apr 25, 2017

#146 in Data formats

Download history 69/week @ 2024-07-22 27/week @ 2024-07-29 32/week @ 2024-08-05 43/week @ 2024-08-12 28/week @ 2024-08-19 26/week @ 2024-08-26 46/week @ 2024-09-02 33/week @ 2024-09-09 37/week @ 2024-09-16 48/week @ 2024-09-23 31/week @ 2024-09-30 6/week @ 2024-10-07 33/week @ 2024-10-14 34/week @ 2024-10-21 24/week @ 2024-10-28 36/week @ 2024-11-04

127 downloads per month
Used in 8 crates (2 directly)

MIT license

8KB
185 lines

aseprite

A crate for loading data from the aseprite sprite editor. Should go along well with the tiled crate, I hope!

It does not load any actual images, just the metadata. Currently it only loads aseprite's JSON export format, and only when exported in the "json-array" format (which isn't the default for some reason but appears much more sensible than the alternative).

Automatically exporting a sprite to a given format is documented here: https://www.aseprite.org/docs/cli/

Docs

Documentation is on docs.rs

Example

Export sprite sheet with:

aseprite -b boonga.ase --sheet boonga.png --format json-array --list-tags --list-layers --data boonga.json

Then write a program to load it:

extern crate serde_json;
extern crate aseprite;

use std::fs::File;

fn main() {
   let file = File::open("boonga.json").unwrap();
   let spritesheet: aseprite::SpritesheetData = serde_json::from_reader(file).unwrap();
   println!("Spritesheet is {:?}", spritesheet);
}

Dependencies

~0.7–1.6MB
~34K SLoC