Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/tobua/icon-numic-plugin

Numic plugin for React Native to automatically generate iOS and Android app icons from a single file.
https://github.com/tobua/icon-numic-plugin

app-icon icon react-native

Last synced: about 2 months ago
JSON representation

Numic plugin for React Native to automatically generate iOS and Android app icons from a single file.

Awesome Lists containing this project

README

        

# icon-numic-plugin

Icon Numic Plugin Logo

Numic plugin for React Native to automatically generate iOS and Android app icons from a single file. Commit only one 1024x1024 file of your app icon but get all sizes automatically. Also supports the generation of adaptive icons for Android.

## Installation

This plugin requires the project is managed through [numic](https://npmjs.com/numic).

```
npm i --save-dev icon-numic-plugin
```

## Usage

Numic automatically picks up the plugin once installed and adds the various icons to the native folders in `/android` and `/ios` without any changes to commit. The only thing **required is an icon** of the recommended size 1024x1024. The plugin will look for icons in the following locations and pick the first match:

- icon.png / icon.svg
- app-icon.png / app-icon.svg
- asset/icon.png / asset/icon.svg
- logo.png / logo.svg (also used as Avatar in SourceTree)

## Configuration

The icon can be configured in `package.json` under the `numic` property. This will override default icon paths from the file system as described above.

```js
{
"name": "my-app",
"numic": {
"icon-numic-plugin": {
"icon": "image/my-icon.png",
// Convert transparent icons to a black background for iOS, default white.
"iOSBackground": "#000000",
// Generate Android adaptive icons from SVG images.
"androidForeground": "image/my-adaptive-foreground.svg",
"androidBackground": "image/my-adaptive-background.svg",
// Pass native Android vector drawables in XML format.
"androidForeground": "image/my-adaptive-foreground.xml",
"androidBackground": "image/my-adaptive-background.xml",
// Instead of "androidBackground" it's possible to just set a solid color.
"androidBackgroundColor": "#FF0000",
}
}
}
```

## Adaptive Icons for Android

Adaptive icons use vector graphics and are composed of a foreground and a background image. Due to using vector graphics only one image size is required. This plugin will generate all the required configuration files as well as the scaled legacy images in various sizes for older devices.

For web developers the easiest way to generate the vector drawables used on Android for adaptive icons is to convert from an SVG. The vector drawable specification is largely the same as SVG so this plugin is able to take SVG icons as input and convert them to XML files in the Android Drawable syntax. It's also possible to directly pass in XML files that are already in the vector drawable format. To generate vector drawables from scratch or debug the output of the conversion from SVG by this plugin, open the `/android` folder in Android Studio. There it's possible to edit and directly preview the images. To get a preview of the resulting images for various Android versions click `Resource Manager` on the left -> `+` icon -> `Image Asset`.


Adaptive Icon preview in Android Studio

To avoid that parts of the foreground icon are cut off the icon should be centered and only take up about **60%** of the width and height.



ChatGPT's attempt at Adaptive Icons for React Native