2.4.0 • Published 4 months ago

react-native-image-colors v2.4.0

Weekly downloads
548
License
MIT
Repository
github
Last release
4 months ago

react-native-image-colors

Platform NPM Badge Publish size PRs Welcome

Fetch prominent colors from an image.

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:

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

    const catImgBase64 = '...'

    The mime type prefix for base64 is required (e.g. data:image/png;base64).

Config?

The config object is optional.

PropertyDescriptionTypeDefaultSupported platforms
fallbackIf a color property couldn't be retrieved, it will default to this hex color stringstring"#000000"All
cacheEnables in-memory caching of the result - skip downloading the same image next time.booleanfalseAll
keyUnique 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.stringundefinedAll
headersHTTP headers to be sent along with the GET request to download the imageRecord<string, string>undefinediOS, Android
pixelSpacingHow many pixels to skip when iterating over image pixels. Higher means better performance (note: value cannot be lower than 1).number5Android
qualityHighest 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

PropertyType
dominantstring
averagestring
vibrantstring
darkVibrantstring
lightVibrantstring
darkMutedstring
lightMutedstring
mutedstring
platform"android"

WebImageColors

PropertyType
dominantstring
vibrantstring
darkVibrantstring
lightVibrantstring
darkMutedstring
lightMutedstring
mutedstring
platform"web"

IOSImageColors

PropertyType
backgroundstring
primarystring
secondarystring
detailstring
platform"ios"

Notes

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

4 months ago

2.3.0

10 months ago

2.2.0

10 months ago

2.1.0

11 months ago

1.5.2

1 year ago

2.0.0-ab19382.0

12 months ago

2.0.0

12 months ago

2.0.0-d836a6c.0

12 months ago

1.5.1

2 years ago

1.5.0

2 years ago

1.4.0

3 years ago

1.4.0-beta.0

3 years ago

1.3.1

3 years ago

1.3.0

3 years ago

1.3.0-beta.0

3 years ago

1.2.8

3 years ago

1.2.8-beta.0

3 years ago

1.2.8-beta.1

3 years ago

1.2.7

3 years ago

1.2.6

3 years ago

1.2.5

3 years ago

1.2.4

4 years ago

1.2.3

4 years ago

1.2.2

4 years ago

1.2.1

4 years ago

1.2.0

4 years ago

1.1.4

4 years ago

1.1.3

4 years ago

1.1.2

4 years ago

1.1.1

4 years ago

1.1.0

4 years ago

1.0.6

4 years ago

1.0.5

4 years ago

1.0.4

4 years ago

1.0.3

4 years ago

1.0.2

4 years ago

1.0.1

4 years ago

1.0.0

4 years ago