This Script-fu scripts could help with certain tileset manipulations. Specifically changing margin and spacing.
data:image/s3,"s3://crabby-images/5b2b5/5b2b5983ae5373244e71dd93f905b7ae2e507d97" alt=""
- Add spacing and margin - Will add spacing and margin to a tileset which has no spacing and no margin.
- Remove spacing and margin - The opposite of Add.
- Fill spaces - After spacing-margin is added the new space has background color. This script can be used to fill the space by copying some columns and rows (border of tiles):
data:image/s3,"s3://crabby-images/b5327/b53279bf04ea346af289057a9111578ff7f225cb" alt=""
Installation steps
- Unzip and copy the file respace-tiles.scm to Gimp script directory (Goto edit/preferences/Directories/Scripts to find the right location)
- Reload scripts by Filters/Script-Fu/Refresh Scripts or just restart Gimp)
Plugins are registered under Filtres/Map/Tileset.
Example
Say I have a tileset with tile size 64x64, margin 1 and spacing 2 and I want scale it down to 32x32 with the same margin and spacing. I can't just scaled the whole image as there are two problems with that:
- Spacing and margin will be also scaled so spacing will be 1 and margin even half pixel.
- Borders of tiles will be slightly changed because of interpolation (they will get flavor of neighbor tiles or background color)
So instead I usually do the following steps:
- Remove margin/spacing.
data:image/s3,"s3://crabby-images/56ce6/56ce6b2d2dfe7cc526d3f0cdee85e391710afcf0" alt=""
- Add margin 8 and spacing 8. Note: When increasing spacing and/or margin, increase also layer size otherwise the bottom and right tiles might get cropped. It is also good idea to have even number image size.
data:image/s3,"s3://crabby-images/42331/42331639b3c0f63b1b28f872b69ba1bf973073f9" alt=""
- Invoke Fill spaces with Tile size=64, margin=8 spacing=8 Copy distance 1. This will create frame around each tile.
- Again Fill spaces but this time Tile size=66 margin=7 spacing=6 and with Copy distance 1 (2 or 3 will also do the job). This will create another (bigger) frame.
data:image/s3,"s3://crabby-images/f8cfa/f8cfa82f32f985a8b2696e33f656fb7d88d52a53" alt=""
- Scale down 2x and move the scaled layer back to top left corner. Now the Tile size=32x32 margin=4 spacing=4
data:image/s3,"s3://crabby-images/0c5be/0c5bef0aad5b76782eb7802f65ba9eed4c58b671" alt=""
- Invoke Remove spacing and margin. Tiles are half size now and still seamless.
data:image/s3,"s3://crabby-images/09439/09439e85fc26f6ca1300849ce8c0550d3b51ae62" alt=""
- Now I can add required spacing=2 and margin=1 and then fill spaces.
Recent comments