AssetPack is a tool for optimising assets for the web. It can be used to transform, combine, compress assets. Any asset that you want to transform or optimise into something else can be done with AssetPack.
Assetpack is framework agnostic, and can be used with any framework you like, such as PixiJS, Threejs, Phaser, etc. It uses a plugin based system to allow you to create your own plugins to do whatever you want with your assets.
AssetPack was designed to solve the problem of having assets come in many different formats, and having to convert them into a format that is suitable for your game. For example, you might have been given an audio file, e.g. music.wav
, to be put in your game, but to get the best coverage across browsers, you need to convert it into an ogg
and mp3
file. AssetPack can do this for you, and you can even compress the audio file to reduce the size of the file.
AssetPack can also be used to combine multiple images into a single sprite sheet, or to generate multiple sizes of an image. This can be useful if you want to support different screen sizes, or if you want to reduce the number of HTTP requests your game makes.
npm install --save-dev @assetpack/core @assetpack/cli
AssetPack uses a config file to define what assets you want to optimise and how you want to optimise them. The config file is a JavaScript file that exports an object with the following properties:
entry
: The directory where your raw assets are located.output
: The directory where you want your optimised assets to be outputted to.plugins
: An object containing the plugins you want to use. The key is the name of the plugin, and the value is the plugin itself.ignore
: an optional array of ignore patterns. Any file path matching the patterns will not be processed by assetpackcache
: an optional boolean to enable or disable caching. Defaults to true.logLevel
: an optional string to set the log level. Defaults to 'info'.files
: an optional object to override the settings and tags of any assets. See Config Overrides for more details.
// .assetpack.js
import { compressJpg, compressPng } from "@assetpack/plugin-compress";
import { pixiManifest } from "@assetpack/plugin-manifest";
export default {
entry: "./raw-assets",
output: "./public",
plugins: {
compressJpg: compressJpg(),
compressPng: compressPng(),
manifest: pixiManifest(),
},
};
AssetPack comes with a simple CLI that can be used to run AssetPack. You can run AssetPack by running the following command:
{
"scripts": {
"build:assets": "assetpack -c .assetpack.js"
}
}
AssetPack has a concept called tags. Tags can be placed on any folder/asset and provide a hint to each plugin as to what it is meant to be used for.
raw-assets
├── preload{m}
│ └── loader.jpg
└── game{m}
└── frames{tps}
├── char.png
└── pickup.png
As you can see here we have a {tps}
tag and a {m}
tag. The {tps}
tag tells @assetpack/plugin-texture-packer
plugin that all images inside this folder should be used to create a spritesheet.
Also each asset can have multiple tags if needed:
raw-assets
└── game{multiple}{tags}{here}
└── ...
Each plugin can define what tags it supports. For example, the @assetpack/plugin-texture-packer
plugin supports the {tps}
tag, and the @assetpack/plugin-manifest
plugin supports the {m}
tag.
AssetPack comes with a few plugins to get you started. You can also create your own plugins to do whatever you want with your assets.
- compress: Compresses images using sharp
compressJpg
: Compressesjpg
imagescompressPng
: Compressespng
imagescompressWebp
: Compressespng
andjpg
images intowebp
compressAvif
: Compressespng
andjpg
images intoavif
- ffmpeg: Converts files using ffmpeg. E.g.
wav
tomp3
&ogg
ffmpeg
: Exposes the full ffmpeg API to convert any file to any other fileaudio
: Converts audio files tomp3
andogg
- json: Minifies JSON files
- mipmap: Generates multiple sizes of an image. e.g.
image.png
toimage@1x.png
andimage@0.5x.png
mipmap
: General purpose mipmap generatorspineAtlasMipmap
: Generates multiple sizes of a spine atlas file
- texture-packer: Packs multiple images into a sprite sheet
- webfont: Generates woff2 fonts from ttf, oft, svg, and woff files
- manifest: Generates a Pixi v7 specific manifest file to load your assets
Head on over the Pixi's Open Games repository to see how AssetPack is used in the wild! There are several open source games in that repository that are using AssetPack to optimise their assets.
You can create your own plugins to do whatever you want with your assets. A plugin is just a function that returns an object with the following properties:
TODO
AssetPack allows you to override the settings and tags of any assets through the files
property in the config file. This is useful if you want to override the settings of a plugin for a specific asset.
...
export default {
...
files: [
{
// This will apply these settings to folders ending with -tps
files: ['/**/*-tps'],
// You can set what tags are applied to the asset
// Tags are usually a string but can be an array or an object
// e.g. {name: 'hi', data: {foo: 'bar'}}
tags: ['hi'],
// Using the name of the plugin, you can override the settings for that plugin
settings: {
['texture-packer']: {
// override the tag the plugin uses to find the assets
tags: {
tps: 'hi'
},
resolutionOptions: {
// override the resolution options for the plugin
resolutions: {high: 2, default: 1, low: 0.5}
}
}
}
}
]
};
If you get this error, it means that the sharp
module failed to install properly.
You can potentially fix this by running the following command:
npm rebuild sharp