react-native-image-colors

Fetch prominent colors from an image.

Downloads in past

Stats

StarsIssuesVersionUpdatedCreatedSize
react-native-image-colors
63012.4.03 months ago4 years agoMinified + gzip package size for react-native-image-colors in KB

Readme

react-native-image-colors
Platform NPM Badge Publish size PRs Welcome
Fetch prominent colors from an image.

width="250px" src="https://github.com/osamaq/react-native-image-colors/raw/master/assets/example1.png" alt="Example 1" /> width="250px" src="https://github.com/osamaq/react-native-image-colors/raw/master/assets/demo1.png" alt="Demo 1 Android" /> width="250px" src="https://github.com/osamaq/react-native-image-colors/raw/master/assets/demo1_ios.png" alt="Demo 1 iOS" /> width="250px" src="https://github.com/osamaq/react-native-image-colors/raw/master/assets/demo2.png" alt="Demo 2 Android" /> width="250px" src="https://github.com/osamaq/react-native-image-colors/raw/master/assets/demo2_ios.png" alt="Demo 2 iOS" />


This module is a wrapper around the Palette class on Android, UIImageColors on iOS and node-vibrant for the web.

Installation

Expo

Requirements

  • Expo SDK 47+

yarn add react-native-image-colors

npx expo prebuild

iOS
npx expo run:ios

Android
npx expo run:android

The example is an expo app.

React Native CLI

Requirements


Users on < RN0.69 and older can use v1.x.x

yarn add react-native-image-colors

iOS
npx pod-install

npx react-native run-ios

Android
npx react-native run-android

Web

yarn add react-native-image-colors

Usage

import React from 'react'
import { getColors } from 'react-native-image-colors'

const useImageColors = () => {
  const [colors, setColors] = React.useState(null)

  React.useEffect(() => {
    const url = 'https://i.imgur.com/68jyjZT.jpg'

    getColors(url, {
      fallback: '#228B22',
      cache: true,
      key: url,
    }).then(setColors)
  }, [])

  return colors
}

API

ImageColors.getColors(uri: string, config?: Config): Promise<ImageColorsResult>

uri

A string which can be:
  • URL:

https://i.imgur.com/O3XSdU7.jpg
  • Local file:

```js const catImg = require('./images/cat.jpg') ```
  • Base64:

```js const catImgBase64 = '...' ```
> The mime type prefix for base64 is required (e.g. data:image/png;base64).

Config?

The config object is optional.
| Property | Description | Type | Default | Supported platforms | | -------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------ | ----------- | ------------------- | | fallback | If a color property couldn't be retrieved, it will default to this hex color string | string | "#000000" | All | | cache | Enables in-memory caching of the result - skip downloading the same image next time. | boolean | false | All | | key | Unique key to use for the cache entry. The image URI is used as the unique key by default. You should explicitly pass a key if you enable caching and you're using a base64 string as the URI. | string | undefined | All | | headers | HTTP headers to be sent along with the GET request to download the image | Record<string, string> | undefined | iOS, Android | | pixelSpacing | How many pixels to skip when iterating over image pixels. Higher means better performance (note: value cannot be lower than 1). | number | 5 | Android | | quality | Highest implies no downscaling and very good colors. | 'lowest'
'low'
'high'
'highest' | "low" | iOS, Web |

ImageColorsResult

Every result object contains a respective platform key to help narrow down the type.

AndroidImageColors

| Property | Type | | -------------- | ----------- | | dominant | string | | average | string | | vibrant | string | | darkVibrant | string | | lightVibrant | string | | darkMuted | string | | lightMuted | string | | muted | string | | platform | "android" |

WebImageColors

| Property | Type | | -------------- | --------- | | dominant | string | | vibrant | string | | darkVibrant | string | | lightVibrant | string | | darkMuted | string | | lightMuted | string | | muted | string | | platform | "web" |

IOSImageColors

| Property | Type | | ------------ | -------- | | background | string | | primary | string | | secondary | string | | detail | string | | platform | "ios" |

Notes

  • There is an example app.
  • Since the implementation of each platform is different you can get different color results for each.