data:image/s3,"s3://crabby-images/9541e/9541ec1107c48472a20f02e2a600537e2599ca45" alt="Preparing HighRes Icon Files with Automator"
In the past, Xcode came with a tool named IconComposer, which could be used to generate icon files. This tool, however, didn't generate high res icon files, so Apple now discourages its use. Instead, Apple provides instructions for generating icons using an iconset, a folder of image files that can be converted to an icon file using either Xcode or the iconutil command line tool. There are, of course, other ways of creating icons. In this post, however, we'll focus on an iconset.
To manually generate an iconset folder, you start by creating a square image to serve as your icon. Next, you generate versions of the image scaled to 16x16, 32x32, 128x128, 256x256, 512x512. These scaled versions are to be named as follows:
icon_16x16.pngicon_16x16@2x.pngicon_32x32.pngicon_32x32@2x.pngicon_128x128.pngicon_128x128@2x.pngicon_256x256.pngicon_256x256@2x.pngicon_512x512.pngicon_512x512@2x.png
You place all of these images into a folder named FolderName.iconset. Then, you can process it with iconutil to generate an icns file.
Sure, creating scaled images and processing them isn't too difficult, but it's a lot of repetitive work. If you create icons regularly, it can get tedious. You're probably thinking, surely, Automator can be used to streamline the process. It can. Here, we'll create an application workflow you can run anytime you want to convert an image to an icon file. Let's get started...
Note: If you're an iOS developer, feel free to adjust the workflow below accordingly.
Creating the Workflow
Launch Automator and create a new Application workflow.
data:image/s3,"s3://crabby-images/115ad/115ad111dd151e8f96142048caafd71eb7d7b0c7" alt="Preparing HighRes Icon Files with Automator"
Next, insert and configure the following actions.
Note: This workflow is pretty long and repetitive. It's easy to get lost. If you get stuck, don't worry, you can download the complete workflow here, along with a sample icon image.
1. Ask for Finder Items - Set this action to ask for an image file at least 1024x1024 in size.
data:image/s3,"s3://crabby-images/0e481/0e4818153b536d7e406b9de6d1788d2dd70f7a61" alt="Preparing HighRes Icon Files with Automator"
2. New Folder - Set this action to create a folder named MyIcon.iconset on your Desktop.
data:image/s3,"s3://crabby-images/29f4a/29f4a0515f581e5de82e2d17507b5d30b754256d" alt="Preparing HighRes Icon Files with Automator"
3. Set Value of Variable - From the popup menu in this action, choose New Variable and create a variable named iconset folder.
data:image/s3,"s3://crabby-images/30d7a/30d7a45642821333163228182c8643f5da0c5da9" alt="Preparing HighRes Icon Files with Automator"
4. Get Folder Contents
data:image/s3,"s3://crabby-images/ba48a/ba48a52b6d4aee30acea070641be6b6c922675ad" alt="Preparing HighRes Icon Files with Automator"
5. Change Type of Images - Set this action to convert images to PNG format.
data:image/s3,"s3://crabby-images/b9650/b96507b0ee9c728bd8ac8c64e48ac491a6ea48f1" alt="Preparing HighRes Icon Files with Automator"
6. Scale Images - Set this action to scale the image to a size of 1024 pixels.
data:image/s3,"s3://crabby-images/41d6f/41d6fa28d228c548abc33e6d65106a2a7273d745" alt="Preparing HighRes Icon Files with Automator"
7. Rename Finder Items - Set this action to name a single item's basename only to icon_512x512@2x. This represents a 1024 image (i.e. a Retina display ready size) when the icon is created. Note that this action's title changes in the workflow to reflect the type of naming, in this case Name Single Item.
data:image/s3,"s3://crabby-images/ea702/ea702157459765ecfad84696771c4847df5f1a96" alt="Preparing HighRes Icon Files with Automator"
8. Duplicate Finder Items
data:image/s3,"s3://crabby-images/1cf14/1cf14db8c1d04b17213947cc519158c1cf87fa87" alt="Preparing HighRes Icon Files with Automator"
9. Scale Images - Set this action to scale the image to a size of 512 pixels.
data:image/s3,"s3://crabby-images/2fdae/2fdae30d97e386c824a6ce5aac22a7e0315ed47d" alt="Preparing HighRes Icon Files with Automator"
10. Rename Finder Items - Set this action to name a single item's basename only to icon_512x512.
data:image/s3,"s3://crabby-images/5d121/5d12109a322e170def573a4fc031bea597086431" alt="Preparing HighRes Icon Files with Automator"
11. Duplicate Finder Items
data:image/s3,"s3://crabby-images/cc23e/cc23e1e21f7174c274167b6de90d1577270c0ff8" alt="Preparing HighRes Icon Files with Automator"
12. Rename Finder Items - Set this action to name a single item's basename only to icon_256x256@2x.
data:image/s3,"s3://crabby-images/cb6f5/cb6f52760340729115be5470cfd50e869fda856f" alt="Preparing HighRes Icon Files with Automator"
13. Duplicate Finder Items
data:image/s3,"s3://crabby-images/f4b44/f4b44215b6a40f60de887c9cc041841e351c311f" alt="Preparing HighRes Icon Files with Automator"
14. Scale Images - Set this action to scale the image to a size of 256 pixels.
data:image/s3,"s3://crabby-images/0bbb5/0bbb5e69ecd7a05680d0ce52767b65afc1167620" alt="Preparing HighRes Icon Files with Automator"
15. Rename Finder Items - Set this action to name a single item's basename only to icon_256x256.
data:image/s3,"s3://crabby-images/9e316/9e31608d20754300255e397d88bc73fd32c095b0" alt="Preparing HighRes Icon Files with Automator"
16. Duplicate Finder Items
data:image/s3,"s3://crabby-images/a853e/a853e65ebc1ec2e47830d79a793421f98474486f" alt="Preparing HighRes Icon Files with Automator"
17. Rename Finder Items - Set this action to name a single item's basename only to icon_128x128@2x.
data:image/s3,"s3://crabby-images/314ae/314ae06675a2a0f2715cabd415dd71fc712ccec6" alt="Preparing HighRes Icon Files with Automator"
18. Duplicate Finder Items
data:image/s3,"s3://crabby-images/9c1c8/9c1c84a1f589cc4e115dd7deccf771bd1da6d6a7" alt="Preparing HighRes Icon Files with Automator"
19. Scale Images - Set this action to scale the image to a size of 128 pixels.
data:image/s3,"s3://crabby-images/633d2/633d290ab73331608318bbff8b4a9c4054845d5b" alt="Preparing HighRes Icon Files with Automator"
20. Rename Finder Items - Set this action to name a single item's basename only to icon_128x128.
data:image/s3,"s3://crabby-images/353f1/353f1b89e2f29f3407cc341475abd417e4fa8f97" alt="Preparing HighRes Icon Files with Automator"
21. Duplicate Finder Items
data:image/s3,"s3://crabby-images/82d0f/82d0fe5bd2ca6d0b133040475b442756c5e43696" alt="Preparing HighRes Icon Files with Automator"
22. Scale Images - Set this action to scale the image to a size of 64 pixels.
data:image/s3,"s3://crabby-images/ea481/ea4818aef9d9a77e075440b43946d9ad83a4cbb5" alt="Preparing HighRes Icon Files with Automator"
23. Rename Finder Items - Set this action to name a single item's basename only to icon_32x32@2x.
data:image/s3,"s3://crabby-images/c37e7/c37e79c0d198f4eaefc2e85802dc60206df0afa0" alt="Preparing HighRes Icon Files with Automator"
24. Duplicate Finder Items
data:image/s3,"s3://crabby-images/addcd/addcd48ca43695540926a288f5ebaf78e527a7a6" alt="Preparing HighRes Icon Files with Automator"
25. Scale Images - Set this action to scale the image to a size of 32 pixels.
data:image/s3,"s3://crabby-images/d3126/d3126ebb4f79406d0f46bb02999820bd96c81b1f" alt="Preparing HighRes Icon Files with Automator"
26. Rename Finder Items - Set this action to name a single item's basename only to icon_32x32.
data:image/s3,"s3://crabby-images/183fb/183fb1533250a2a908f9e62954ff20a03843133f" alt="Preparing HighRes Icon Files with Automator"
27. Duplicate Finder Items
data:image/s3,"s3://crabby-images/9126f/9126f99faf189b6c88de794bee07d162d3079317" alt="Preparing HighRes Icon Files with Automator"
28. Rename Finder Items - Set this action to name a single item's basename only to icon_16x16@2x.
data:image/s3,"s3://crabby-images/850e7/850e7c45c8bfaf4a32cdd740c678835dbc9e76fb" alt="Preparing HighRes Icon Files with Automator"
29. Duplicate Finder Items
data:image/s3,"s3://crabby-images/c9242/c9242e4a7040c0d73e62ab91274a92b4788e421a" alt="Preparing HighRes Icon Files with Automator"
30. Scale Images - Set this action to scale the image to a size of 16 pixels.
data:image/s3,"s3://crabby-images/1192c/1192cefdf495c68b6e14c37ed0f07a9d0b81ae51" alt="Preparing HighRes Icon Files with Automator"
31. Rename Finder Items - Set this action to name a single item's basename only to icon_16x16.
data:image/s3,"s3://crabby-images/91f60/91f604d72f489085ed1adafe26c1e054b6e576d7" alt="Preparing HighRes Icon Files with Automator"
32. Get Value of Variable - Set this action to get the iconset folder variable you created way back at the beginning of the workflow. You also need to set this action to ignore its input, so it doesn't continue processing the 16x16px image from the previous action. Select Action > Ignore Image.
data:image/s3,"s3://crabby-images/13f2d/13f2d13b47fe268c44ef8e77846971b7d52f2070" alt="Preparing HighRes Icon Files with Automator"
33. Run Shell Script - Set this action to pass input as arguments. Then, enter the following command:
iconutil -c icns "$@"
data:image/s3,"s3://crabby-images/fdac7/fdac7f433eba8c4d1cbb853242110187bc0f2dfd" alt="Preparing HighRes Icon Files with Automator"
Preparing the Run the Workflow
Before you begin running the workflow, you need an image you can convert to an icon. Note that iconutil requires this image to be square. So, make sure it is. If you really want to be sure it's square, you can insert a Crop Images action between steps 5 and 6, and configure it to crop to 1024x1024, scaling to the shortest side before copping. However, if your image contains transparency, this action will remove it. So, it's best to prepare your starting image as a square.
Running the Workflow
When you run the workflow, you're first asked to choose an image. Select the desired image and click Choose.
data:image/s3,"s3://crabby-images/0fce1/0fce179e2563b5e11fdf5f7fd3304875e327e187" alt="Preparing HighRes Icon Files with Automator"
The workflow runs, an iconset folder is created on your Desktop and passed to iconutil, which generates an icns file.
data:image/s3,"s3://crabby-images/f44b8/f44b8aa36132d4e32798f993ceeaf63323dc9325" alt="Preparing HighRes Icon Files with Automator"
You're ready to plug your icns file into your app. Now, any time you need to generate an icon, just create a square image and trigger your workflow. Happy New Year and Happy App Developing!
Preparing High-Res Icon Files with Automator originally appeared on TUAW - The Unofficial Apple Weblog on Mon, 31 Dec 2012 11:00:00 EST. Please see our terms for use of feeds.
Source | Permalink | Email this | CommentsDIGITAL JUICE
No comments:
Post a Comment
Thank's!