Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/EngineerSmith/Export-TextureAtlas
Extends the Runtime-TextureAtlas library and allows it to be exported as file
https://github.com/EngineerSmith/Export-TextureAtlas
love texture-atlas
Last synced: 2 months ago
JSON representation
Extends the Runtime-TextureAtlas library and allows it to be exported as file
- Host: GitHub
- URL: https://github.com/EngineerSmith/Export-TextureAtlas
- Owner: EngineerSmith
- License: mit
- Created: 2021-11-25T10:34:27.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2022-02-04T00:45:08.000Z (almost 3 years ago)
- Last Synced: 2024-08-02T06:17:10.982Z (6 months ago)
- Topics: love, texture-atlas
- Language: Lua
- Homepage:
- Size: 82 KB
- Stars: 6
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-love2d - Export-TextureAtlas - Extends Runtime-TextureAtlas as a commandline tool to export an atlas. (Drawing)
README
# Export-TextureAtlas (ETA)
Extends the [Runtime-TextureAtlas library](https://github.com/EngineerSmith/Runtime-TextureAtlas) and allows it to be exported as a file. This tool requires [Love2d](https://love2d.org/) to work, but the resulting files are not tied to Love2D. Use a custom template to change the format of the quads file to how you want it. See `-template ` argument on how to create your own export template, or just use the default one provided.This tool can be fused similarly to any other love project. Follow these [instructions](https://love2d.org/wiki/Game_Distribution) for your platform. Note, all arguments will work the same, but `love . `/`love ` will become `fused.exe `, etc.
**Note, the default maxSize of the atlas is 16,384.** You can increase or decrease this using the argument `-maxSize `
## Clone
`git clone https://github.com/EngineerSmith/Export-TextureAtlas --recurse-submodules`
## Example use
`love . ./bin/in/ ./bin/out/ -removeFileExtension -extrude 1 -padding 1``love . ./bin/in/ ./bin/out/ -removeFileExtension -extrude 1 -padding 1 -fixedSize 16 16 -template ./bin/template.lua`
`love . ./bin/in/ ./bin/out/ -removeFileExtension -padding 2 -template ./bin/template.json`
`love . -input ./bin/in/ ./bin/in2/ -output ./bin/out/atlases/ -padding 2 -template ./bin/template.json`
Must be one or equal number of output directories. Directories must end in `/` or they will be mistaken as a file name.`love . -input ./bin/in/ ./bin/in2/ -output ./bin/out/atlas1.png ./bin/out/atlas2.png`
You can define the name of the atlas, if you do equal number of directories to output.`love . -input ./bin/in/ -output ./assets/atlas/image.png -dataOutput ./assets/atlas/data.json -template ./bin/in/template.json -padding 1 -extrude 1 -removeFileExtension`
# Arguments
`love . [<...>]`
## inputDir or -input \ \<...>
Required argument. Directory must exist; containing all images to add to texture atlas. You can define more than one input directory with the `-input` flag, if the flag supplies an input `` is not required.**Note**, directory must end with `\` or `/` or neither.
### Example
`love . ./bin/in ``love . ./assets/images/ `
`love . C:\user\Santa\game\assets\images\ `
## outputDir or -output \ \<...>
Required argument. The directory doesn't need to exist, once ran it will overwrite files and (hopefully) output the files within as `atlas.png` and `data.`. If the flag `-output` is supplied `` is not required. If the given path is to a file, then it will name the outputted texture atlas that file, whilst the data file will be called `data.`, if mulitple input and output directories are given, it will then append a number to make it a unique file. E.g. `data1.lua`, `data2.lua`, `data3.png`. The same happens to atlas if only one output directory is defined, but `atlas` is appended in place of `data`. E.g. `atlas1.png`, `atlas2.png`, `atlas3.png`**Note**, file must end with an extension, otherwise it will be treated as a directory.
### Example
`love . ./bin/out``love . ./assets/textureAtlas/`
`love . C:\user\Santa\game\assets\textureAtlas\`
`love . -input -output ./bin/out` -> `atlas1.png`+`data1.lua`, `atlas2.png`+`data2.lua`
`love . -input -output ./bin/out/imageA ./bin/out/imageB.png ./bin/out/imageC.banana` -> `imageA/atlas1.png`+`imageA/data1.lua`, `imageB.png`+`data2.lua`, `imageC.banana`+`data3.lua`
**Note**, that `image3.banana` will be encoded as a `png` file.
## -dataOutput \ \<..>
Optional. Where the data file is saved that is generated from the given template or the default template. If a directory is given, it will be called `data.` (if there are multiple input directories then a number will be added as a prefix).**Note**, file must end with an extension, otherwise it will be treated as a directory.
### Example
`love . -dataOutput ./bin/quads.lua``love . -input -output -dataOutput ./bin/quadData`
`love . -input -output -dataOutput /dir1.lua /dir2.lua`
## -padding \
Optional. Padding between images on the atlas, defaults to 1. Will throw a handled error if it cannot be converted to a number.**Note**, it cannot be a negative, otherwise it will be mistaken as an argument. This value does not get added onto the exported quad, but does shift its location on the atlas.
### Example
`love . -padding 1``love . -padding 12`
## -extrude \
Optional. Extrudes the given image on the atlas, defaults to 0. Will throw a handled error if it cannot be converted to a number. It will use the [clamp warp mode](https://love2d.org/wiki/WrapMode).**Note**, it cannot be a negative, otherwise it will be mistaken as an argument. This value does not get added onto the exported quad, but does shift its location on the atlas.
### Example
`love . -extrude 1``love . -extrude 16`
## -spacing \
Optional. Adds spacing between images on the atlas, does not add spacing between an image and the edge of the atlas.**Note**, it cannot be a negative, otherwise it will be mistaken as an argument. This value does not get added onto the exported quad, but does shift its location on the atlas.
### Example
`love . -spacing 1``love . -spacing 5`
## -fixedSize \ [\]
Optional. Uses a fixed size atlas from [Runtime-TextureAtlas](https://github.com/EngineerSmith/Runtime-TextureAtlas). All given images in a directory must be the same size. `height` is an optional value and will default to the required `width` value.
### Example
`love . -fixedSize 16``love . -fixedSize 16 32`
## -pow2
Optional. This argument will round the width and height of the atlas to the nearest power of 2 value. Note, the packing algorithms are not designed to pack to the nearest power of two, and so you may be left with additional empty space. PNG encoding used shouldn't add too much overhead to this from testing.
### Example
`love . -pow2`
## -maxSize \ [\]
Set the max size the atlas is allowed to reach. Must be greater than 0. If height is excluded, it will be set to the default max size of 16,384
### Example
`love . -maxSize 100 100``love . -maxSize 1000`
## -ignore \ \<...>
Optional. Skip a directory or a file path from being added or searched through to the texture atlas. Can use wild cards.
### Example
`love . -ignore ./foo/``love . -ignore *.png`
`love . -ignore ./foo/ ./bar/ *.tga`
## -removeFileExtension
Optional. This argument will remove image file extension for their given id. This could clash and overwrite other quads if you have the same image name with different extensions.
`foo/bar.png` becomes `foo/bar`
### Example
`love . -removeFileExtension`
## -template \
Optional. This overrides the default internal templated. See [Lustache](https://github.com/Olivine-Labs/lustache) for how to create a template.**Note**, the file extension of the template is used to sign the file. E.g. `template.lua` -> `quads.lua`, `template.json` -> `quads.json`
The default(lua table) is as followed, and contains all available variables:
```
return {
quads = {
{{#quads}}
["{{{id}}}"] = {
x = {{x}},
y = {{y}},
w = {{w}},
h = {{h}}
}{{^last}},{{/last}}
{{/quads}}
},
meta = {
padding = {{meta.padding}},
extrude = {{meta.extrude}},
atlasWidth = {{meta.width}},
atlasHeight = {{meta.height}},
quadCount = {{meta.quadCount}}{{#meta.fixedSize}},
fixedSize = {
width = {{width}},
height = {{height}},
}
{{/meta.fixedSize}}
{{^meta.fixedSize}}{{/meta.fixedSize}}
}
}
```
Formatted JSON example that could be used:
```
{
"quads": {
{{#quads}}
"{{{id}}}": {
"x": {{x}},
"y": {{y}},
"w": {{w}},
"h": {{h}}
}{{^last}},{{/last}}
{{/quads}}
},
"meta" = {
"padding": {{meta.padding}},
"extrude": {{meta.extrude}},
"atlasWidth": {{meta.width}},
"atlasHeight": {{meta.height}},
"quadCount": {{meta.quadCount}}{{#meta.fixedSize}},
"fixedSize": {
"width": {{width}},
"height": {{height}}
}
{{/meta.fixedSize}}
{{^meta.fixedSize}}{{/meta.fixedSize}}
}
}
```
### Example
`love . -template ./bin/in/template.lua``love . -template ./assets/textureAtlas/template.json`
# Libraries used
* [Runtime-TextureAtlas](https://github.com/EngineerSmith/Runtime-TextureAtlas)
* [Native FS](https://github.com/megagrump/nativefs)
* [Lustache](https://github.com/Olivine-Labs/lustache)