#Cordova-Imaging
A configuration driven command line imaging utility for Cordova Mobile apps to generate app icons, splash screens, and app store previews for iOS and Android
Apache Cordova is an amazing framework for building mobile apps that target many platforms and form factors, but that support comes with the need to provide a version of your app icon and splash screen for each device form factor you choose to support. Additionally, when you submit your app to the app store, you will need to upload a version of each screen shot for each device form factor.
Cordova-Imaging is a Node.js command line utility, driven by an extensible configuration file, that generates these images with GraphicsMagick, using the gm npm module, based on a single source app icon, splash screen, and preview image(s).
Currently, only iOS and Android are supported.
###Installing
If you have not already done so, install GraphicsMagick. Technically, ImageMagick may also be used, as the gm module supports both, but I haven't tested it with this library extensively.
If you are on OS X:
brew install graphicsmagick
Once installed, install the Cordova-Imaging module (globally):
npm install cordova-imaging -g
###Running
To use the default configuration, from within your project's root directory, ensure you have an ./assets directory containing your app icon and splash screen images. By default, their paths are assumed to be:
- ./assets/appicon.png
- ./assets/splashscreen.png
To generate the images, from your project's directory, run the following command:
cordova-imaging
The app icons and splashscreens generated will be automatically added to the mobile projects of the platforms you support; iOS or Android. This means you will need to have already added support for that platform to your project, such as:
cordova platform add android
To view the new app icon and splash screen, just rebuild and relaunch your app using the command line/IDE. Preview images are output by default to their respective ./assets/previews/<platform>/<form factor> directory.
###Custom Configuration
You may provide a custom configuration file, called ./imaging.json, in your projects root folder, to override default behavior, provide paths to preview images for generation, configure which platforms are supported, configure icon and splash screen form factors supported, etc. Here are a few example configurations:
####Configure a new location for the source app icon and splash screen
{
"sources": {
"appicon": "assets/otherappicon.png",
"splashscreen": "assets/othersplashscreen.png"
}
}
####Add preview images to generate for each form factor
{
"sources": {
"previews": [
"assets/source/preview1.png",
"assets/source/preview2.png",
"assets/source/preview3.png"
]
}
}
####Support only generating assets for iOS
{
"platforms": ['iOS']
}
####Only generate preview images, no app icons or splash screens
{
"sources": {
"previews": [
"assets/source/preview1.png",
"assets/source/preview2.png",
"assets/source/preview3.png"
]
},
"ios": {
"generateIcons": false,
"generateSplashscreens": false
},
"android": {
"generateIcons": false,
"generateSplashscreens": false
}
}
####Generate all images except previews for android
{
"sources": {
"previews": [
"assets/source/preview1.png",
"assets/source/preview2.png",
"assets/source/preview3.png"
]
},
"android": {
"generatePreviews": false
}
}
####Override the background color for the generated splash screen
{
"sources": {
"splashscreen": {
"path": "assets/splashscreen.png",
"background": "#fff"
}
}
}
The above is useful for when you need to alter the background color used when generating a splash screen, if the image contains any transparencies, without modifying the source image itself. Since transparencies and alpha channels aren't allowed, if not specified, a background color of black will be used by default.
###Full Configuration
The default configuration file is located within your npm_modules folder where Cordova-Imaging is installed, located at ./config.js. The imaging.json configuration you provide will be extended over this default config, allowing you to fully alter the base configuration used when generating images. This can be useful, for example, if your app only supports a subset of form factors, and you dont want to generate images you dont need. Here is the full JSON configuration, with comments inline:
{
//** the name of the cordova project config xml file
configXml: 'config.xml',
//** assets like previews, etc, are output here, and source assets are read from here
assetPath: 'assets/',
//** appicon and splashscreen source paths. by default they are in an ./assets subfolder in the root of your
//** cordova project. these can be located anywhere on disk; override in the config local to your project.
sources: {
appicon: 'assets/appicon.png',
splashscreen: 'assets/splashscreen.png'
},
//** default platforms we target imaging for are ios and android
platforms: ['ios', 'android'],
//** default config for imagemagick
imagemagick: {
resize: { format: 'png', quality: 1.0 },
crop: { format: 'png', quality: 1.0, gravity: 'Center' }
},
//** platform specific configurations
//** ----
ios: {
name: 'iOS',
//** path to cordova iOS project
path: 'platforms/ios',
//** path where assets are output for mobile app
destinationPath: 'platforms/ios/$name$/Resources/',
//** by default, generate icons, splashscreens, and previews
generateIcons: true,
generateSplashscreens: true,
generatePreviews: true,
//** supported icons, source: https://developer.apple.com/library/ios/documentation/UserExperience/Conceptual/MobileHIG/IconMatrix.html
icons: [
//** non-retina
{ size: 40, output: 'icons/icon-40.png' },
{ size: 50, output: 'icons/icon-50.png' },
{ size: 60, output: 'icons/icon-60.png' },
{ size: 72, output: 'icons/icon-72.png' },
{ size: 76, output: 'icons/icon-76.png' },
{ size: 29, output: 'icons/icon-small.png' },
{ size: 57, output: 'icons/icon.png' },
//** retina
{ size: 58, output: 'icons/[email protected]' },
{ size: 80, output: 'icons/[email protected]' },
{ size: 100, output: 'icons/[email protected]' },
{ size: 120, output: 'icons/[email protected]' },
{ size: 180, output: 'icons/[email protected]' }, //** iphone 6+
{ size: 144, output: 'icons/[email protected]' },
{ size: 152, output: 'icons/[email protected]' },
{ size: 114, output: 'icons/[email protected]' }
],
//** define the app store app icon; this will be generated along with the normal app icons; no alphas or transparencies, hence the jpg
appstoreIcon: { size: 1024, output: 'appstore-icon.jpg' },
//** supported splashscreens, source: https://developer.apple.com/library/ios/documentation/UserExperience/Conceptual/MobileHIG/IconMatrix.html#//apple_ref/doc/uid/TP40006556-CH27-SW2
splashscreens: [
//** portrait
{ width : 640, height : 1136, output: 'splash/Default-568h@2x~iphone.png' },
{ width : 750, height : 1334, output: 'splash/Default-667h.png' },
{ width : 1242, height : 2208, output: 'splash/Default-736h.png' },
{ width : 1536, height : 2208, output: 'splash/Default-Portrait@2x~ipad.png' },
{ width : 768, height : 2048, output: 'splash/Default-Portrait~ipad.png' },
{ width : 640, height : 960, output: 'splash/Default@2x~iphone.png' },
{ width : 320, height : 480, output: 'splash/Default~iphone.png' },
//** landscape
{ width : 2208, height : 1242, output: 'splash/Default-Landscape-736h.png' },
{ width : 2048, height : 1536, output: 'splash/Default-Landscape@2x~ipad.png' },
{ width : 1024, height : 768, output: 'splash/Default-Landscape~ipad.png' }
],
//** https://developer.apple.com/library/ios/documentation/LanguagesUtilities/Conceptual/iTunesConnect_Guide/Appendices/Properties.html#//apple_ref/doc/uid/TP40011225-CH26-SW2
//** note: we render jpgs because the app store wont accept images with transparencies or alpha channels
previews: [
//** 3.5 inch retina displays
{ width : 640, height : 920, type: '3-5inch', output: '$file$-port.jpg' },
{ width : 640, height : 960, type: '3-5inch', output: '$file$-port-full.jpg' },
{ width : 960, height : 600, type: '3-5inch', output: '$file$-land.jpg' },
{ width : 960, height : 640, type: '3-5inch', output: '$file$-land-full.jpg' },
//** 4 inch retina displays
{ width : 640, height : 1096, type: '4inch', output: '$file$-port.jpg' },
{ width : 640, height : 1136, type: '4inch', output: '$file$-port-full.jpg' },
{ width : 1136, height : 600, type: '4inch', output: '$file$-land.jpg' },
{ width : 1136, height : 640, type: '4inch', output: '$file$-land-full.jpg' },
//** 4.7 inch retina displays (iphone6)
{ width : 750, height : 1334, type: '4-7inch', output: '$file$-port.jpg' },
{ width : 1334, height : 750, type: '4-7inch', output: '$file$-land.jpg' },
//** 5.5 inch retina displays (iphone6 plus)
{ width : 1242, height : 2208, type: '5-5inch', output: '$file$-port.jpg' },
{ width : 2208, height : 1242, type: '5-5inch', output: '$file$-land.jpg' },
//** ipad
{ width : 768, height : 1004, type: 'ipad', output: '$file$-port.jpg' },
{ width : 768, height : 1024, type: 'ipad', output: '$file$-port-full.jpg' },
{ width : 1024, height : 748, type: 'ipad', output: '$file$-land.jpg' },
{ width : 1024, height : 768, type: 'ipad', output: '$file$-land-full.jpg' },
//** ipad retina
{ width : 1536, height : 2008, type: 'ipad-retina', output: '$file$-port.jpg' },
{ width : 1536, height : 2048, type: 'ipad-retina', output: '$file$-port-full.jpg' },
{ width : 2048, height : 1496, type: 'ipad-retina', output: '$file$-land.jpg' },
{ width : 2048, height : 1536, type: 'ipad-retina', output: '$file$-land-full.jpg' }
]
},
android: {
name: 'Android',
//** path to cordova android project
path: 'platforms/android/',
//** path where assets are output for mobile app
destinationPath: 'platforms/android/res/',
//** by default, generate icons, splashscreens, and previews
generateIcons: true,
generateSplashscreens: true,
generatePreviews: true,
//** supported icons, source: http://developer.android.com/design/style/iconography.html
//** note: ldpi support is automatically provided by android
icons: [
{ size: 96, output: 'drawable/icon.png' },
{ size: 48, output: 'drawable-mdpi/icon.png' },
{ size: 72, output: 'drawable-hdpi/icon.png' },
{ size: 96, output: 'drawable-xhdpi/icon.png' }
//** cordova doesn't create these folders (yet), and imagemagick wont create folders as it writes paths...commenting out for now
//{ size: 144, output: 'drawable-xxhdpi/icon.png' },
//{ size: 192, output: 'drawable-xxxhdpi/icon.png' }
],
//** supported splashscreens, source: http://developer.android.com/guide/practices/screens_support.html
splashscreens: [
//** landscape
{ width: 320, height: 200, output: 'drawable-land-ldpi/screen.png' },
{ width: 480, height: 320, output: 'drawable-land-mdpi/screen.png' },
{ width: 800, height: 480, output: 'drawable-land-hdpi/screen.png' },
{ width: 1280, height: 720, output: 'drawable-land-xhdpi/screen.png' },
//** portrait
{ width: 200, height: 320, output: 'drawable-port-ldpi/screen.png' },
{ width: 320, height: 480, output: 'drawable-port-mdpi/screen.png' },
{ width: 480, height: 800, output: 'drawable-port-hdpi/screen.png' },
{ width: 720, height: 1280, output: 'drawable-port-xhdpi/screen.png' }
]
}
}