This guide outlines best practices and naming conventions to help graphic designers and developers manage a large number of icons prepared for an iOS project.
Your input is welcome: pull requests or Twitter 😄
Naming an asset starts with breaking up the user interface of each screen into namespaces (or sections). Each namespace represents a logical grouping for the assets and can be used to create asset names.
- Shorter is better (one word if possible).
- Meaningful namespace name.
- Use lower case.
- No spaces or special characters (use dashes).
Namespaces can correspond to view controllers, typical namespaces are top
, bottom
, content
although more specific names are better.
Examples
Twitter Profile | Tumblr Home | Instagram Explore |
---|---|---|
top actions tweet tab |
post tab |
top photo tab |
- Using Asset Catalogs is the preferred way to manage assets in Xcode, it eliminates keeping track of files in a project. However naming assets (image sets) remains important especially when collaborating with a designer.
- If you choose to manage assets directly, use a main folder to store all assets for the app (usually named
assets
orimages
). This may seem radical but it works in conjunction with prefixing.- An alternative is to use subfolders for each namespace, be aware that subfolders can create problems with asset name uniqueness.
- For extra credit, check out Structuring an iOS Project by Sebastian Rehnby and the Tools section.
PNG is typically used for icons (JPG is better for photos).
- PNG is good for small assets.
- PNG is non-lossy.
- PNG supports transparency.
To use PNG assets:
- Create 1x, 2x and 3x assets in the same folder.
- Add
@2x
or@3x
at the end of the appropriate asset name.
asset.png
asset@2x.png
asset@3x.png
To save disk space or time, one can omit the 1x, 2x or 3x asset: the system automatically scales up or down for the appropriate resolution (in particular, you could provide only 2x/3x assets when targeting retina devices).
Xcode 6 added support for PDF / vector icons eliminating the need for multiple resolution per asset (goodbye 1x, 2x, 3x). However doing so will
re-create PNG assets at compile time, embedding the rasterized bitmaps in the final application instead of embedding the original PDF vector image.
If you add PDF files directly as resources, they can be used as vector assets which have no size restriction (like an icon font).
If you still want to use a PDF asset with assets catalogs, create an image set for each PDF asset in Xcode. Then in the Utility panel (right) set:
- Devices:
Universal
- Scale Factors:
Single Vector
- Render As:
Template Image
(corresponds to setting theUIImageRenderingMode
property toUIImageRenderingModeAlwaysTemplate
)
This last setting allows an asset to be tinted (colored). If setting up a large number of assets sounds tedious, check out a tool appropriately called pdf_xcassets
.
PDF assets still need to be sized appropriately, i.e. the designer would provide 2 assets for an arrow if the mockup required assets sized 20x20
and 40x40
. For more details, read this article.
Another alternative for icon generation is to use icon fonts. These can be scaled without quality loss and colored just like any text. For more details, read this article.
Here are some tools to help you manage your assets.
- blade: Generate Xcode image catalogs for iOS / OSX app icons, universal images, and more.
- Cat2Cat: Generate a category on UIImage from asset catalogs in order to reduce typos and enable Xcode auto-completion.
- OHPDFImage: A library to easily load PDF files as UIImages.
- pdf_xcassets: Generate Xcode xcassets for pdf assets.
- Synx: A command-line tool that reorganizes your Xcode project folder to match your Xcode groups.
- Misen: Script to support using Xcode Asset Catalog in Swift.
- SwiftGen: A collection of Swift tools to generate Swift code (enums for your assets and more).
An important attribute of an asset name is uniqueness.
- This prevents confusion: for example having two different
share
assets (say one for iPhone and one for iPad, or one in a main view and one in a detail view). - More importantly, while it is possible in Xcode to have two files of the same names in different folders, you can only reference one of them using
+ (UIImage *)imageNamed:(NSString *)name
. - Update: Asset catalogs support a namespace based on the asset "Group" that allows for the same name to be reused (read the documentation or summary).
"properties" : {
"provides-namespace" : true
}
Prefixing is optional but it ensures that asset names are unique across the project.
- Prefix the asset with the app name so you can tell which project it belongs to (use a 2 or 3 letter prefix for long app names).
- Add a device prefix (especially for universal apps with device-specific assets).
- Add a
namespace
prefix so you can quickly organize your assets. - Format:
project
-device
-namespace
-asset-name
.png
ss-ipad-intro-arrow-right.png
bpc-iphone-intro-arrow-right.png
twitter-iphone-top-user.png
twitter-iphone-top-search.png
twitter-iphone-top-write.png
tumblr-iphone-card-action.png
tumblr-iphone-card-comment.png
tumblr-iphone-card-reblog.png
tumblr-iphone-card-heart.png
- The asset name describes the icon, not the function of the icon (when possible, see special cases).
- Use lower case.
- No spaces or special characters (use dashes).
Examples
ss-rack-minus.png
ss-top-bars.png
ss-tree-check.png
Not
delete.png
menu.png
selected.png
While CamelCase is the convention in Objective-C, it does not necessarily mean it needs to be applied to asset names (by all means feel free to use it if you prefer SSRackMinus.png
).
chevron
for>
caret
for►
Sometimes the name is well represented by its function (refer to Charbase for Unicode).
refresh
foropen circle arrow
(⟳ U+21BB)edit
forpencil
(✎ U+270E)search
formagnifying glass
(🔍 U+1F50D)user
forbust in silhouette
(👤 U+1F464)comment
forspeech balloon
(💬 U+1F4AC)
Should two assets have the same name, add a qualifier at the end.
ss-top-plus-pink.png
ss-top-plus-gray.png
*-square
*-circle
*-outline
ss-top-arrow-right-circle.png
ss-top-arrow-right-square.png
*-square-outline
for square and outline
*-right
*-left
*-up
, etc
ss-top-arrow-right.png
ss-top-arrow-square-right.png
*-normal
*-selected
*-highlighted
, etc
ss-profile-gear-normal.png
ss-profile-gear-highlighted.png
*-portrait
*-landscape
*-landscape-right
, etc
Apple recommends using Xcode storyboards for launch screens.
In the US, we would favor American over British spelling (sorry M'lady).
Examples
ss-top-hanger-gray.png
ss-tree-color-swatch.png
Not
hanger-grey.png
colour-swatch.png
Do not abbreviate.
Examples
ss-share-facebook.png
ss-share-twitter.png
Not
fb.png
tw.png
This guide was inspired by the NYTimes Objective-C Style Guide and Font Awesome.
Special thanks to the following individuals for their feedback: Ash Furrow, Sergio Campama, Matteo Crippa, Marco Sousa, Dave McKinney.