Automatically build and rebuild Xcode image catalogs for app icons, universal images, and more.
- Use in existing projects to generate image catalogs with no extra work. Blade will automagically refresh your image catalogs based on given master images.
- Use templates of image catalogs to generate new catalogs (see templates).
See blade-sample for a preconfigured project.
Because most of the time your image catalogs are the same image, resized to various sizes.
Here is how people solve this usually:
- Have the designer slice the images manually / automatically using a PSD template
- Use some sort of online image slicing service which emails you a zip of the various sizes
The problem with these solutions is:
- Some times the various slices are not up to date with Xcode (new devices, new sizes)
- It Almost always require extra work from you (placing each image manually in the catalog, fixing mismatches etc.)
- You can't control the quality of the resize
- You can't integrate the tooling into your build workflow or CI
Blade is an open source tool which will replace the PSD template and/or online services for you, and has a goal to satisfy the above requirements in the best way possible.
You have 2 ways to install:
Using Homebrew:
$ brew tap jondot/tap
$ brew install blade
Download one of the binaries in releases, and put in your PATH
or just include in each Xcode project's root.
This should be a typical run of blade:
Here's how a project setup with a Bladefile feels like (more in the Blade Sample repo):
The best way to use Blade, is to set up a local Bladefile
for your entire project. Within it, specify all of your resources. Blade will pick it up automatically.
See blade-sample for a preconfigured project.
$ blade --init
Wrote Bladefile.
Here is how your Bladefile
would look like:
blades:
- source: [email protected]
mount: foobar/Assets.xcassets/AppIcon.appiconset
- source: Spaceship_1024.png
mount: foobar/Assets.xcassets/Spaceship.imageset
It was made for this project structure:
foobar
├── Bladefile
├── images
│ ├── [email protected]
│ └── Spaceship_1024.png
├── foobar
│ ├── AppDelegate.swift
│ ├── Assets.xcassets
│ │ ├── AppIcon.appiconset
│ │ │ └── Contents.json
│ │ └── Spaceship.imageset
│ │ ├── Contents.json
Then use Blade (use --verbose if you want logs) within the same folder where your Bladefile
lives:
$ blade --verbose
INFO[0000] Found a local Bladefile.
INFO[0000] Bladefile contains 2 blade defs.
...
And it will generate all of the images needed within each image catalog.
To make this happen before each build see how to run a script while building a product
$ blade [email protected] --template=templates/watch.json --out=out/watch --catalog
Here's what we did:
- Use a source image (
--source
) - Make a brand new image catalog (
--catalog
), from a template (templates/watch.json
) - Put everything in
out/watch
$ blade -s [email protected] -t existing.imageset -o existing.imageset
Here's what we did:
- Use a source image (
-s
) - Point to an existing image catalog (
-t
) - Output to that same existing image catalog (
-o
) - In other words, Blade will refresh the images in this catalog
Blade parses the same Xcode image catalog configuration file as its own configuration source - no new concept introduced. This allows it to be future-proof with Xcode updates for new image sizes and catalog types.
Supported workflows:
- Prototyping ad-hoc, while prototyping projects
- Development build with Build Steps, transforming all of your source image assets to image catalogs
- CI in your CI servers, either on OSX or Linux (though Linux can't compile code in this case, you can still use it to do image processing)
Supported resize algorithms (-i
or --interpolation
flag):
l3
: Lanczos3 - Defaultl2
: Lanczos2n
: Nearest Neighborbc
: Bicubicbl
: Bilinearmn
: Mitchell-Netravali
See here for live samples.
Pull requests are happily accepted.
Here's what you should know if you want to improve Blade:
- Your workflow starting point is the
Makefile
. There you should see how to setup the development tooling, run builds, tests and coverage. - The architecture splits out the runner from the converter, so that we could swap to other, faster, converters (vips) if needed.
- The other concerns are the
Contents.json
(contents.go) parsing and dimension (dimensions.go) computation logic. - Finally, you're left with the Bladefile (bladefile.go) and CLI (main.go) logic to handle.
Also, check out fixtures for quick image catalog configuration to work with.
Here is a typical flow:
- Clone project
- Branch off for your changes
- Edit code
- Test your changes, submit PR
- (release)
make bump
- (release)
make release
- (release) use hub to upload release binaries
- (release)
make brew_sha ver=<current version>
- (release) update jondot/homebrew-tap version and sha to point to new binary
(* 'release' flows are done by core committers)
Fork, implement, add tests, pull request, get my everlasting thanks and a respectable place here :).
Copyright (c) 2015 Dotan Nahum @jondot. See MIT-LICENSE for further details.