react-native-turbo-image
Performant image Component for React Native. Powered by Nuke and Coil
Features
- Support New Architecture. see the example
- Support authorization headers
- Support thumbhash and blurhash for placeholder
- Memory cache, aggressive LRU disk cache and HTTP disk cache
- Prefetch, cleanMemoryCache and cleanDiskCache
- Written in TypeScript, Swift and Kotlin
- Support special formats (SVG, Gif, APNG)
Installation
npm install react-native-turbo-image
cd ios && pod install
Usage
import TurboImage from 'react-native-turbo-image';
<TurboImage
source={{ uri: "https://placedog.net/300/300?id=1" }}
style={{ width: 300, height: 300 }}
cachePolicy="urlCache"
/>;
<TurboImage
source={require('../../assets/local.png')}
style={{ width: 300, height: 300 }}
/>;
Props
source: object | number
local asset
<TurboImage
source={require('../../assets/local.png')}
style={{ width: 300, height: 300 }}
/>;
remote image
uri
: Remote url to load the image from.headers?
: Headers to load the image with. e.g. { Authorization: 'someAuthToken' }
style: ImageStyle
The style of the image
placeholder?: Partial<Placeholder>
type Placeholder = {
blurhash: string;
thumbhash: string;
};
show placeholder while loading, either thumbhash
or blurhash
cachePolicy?: enum
The cache policy of the image
memory
: LRU memory cache for processed images. set by defaultdataCache
: aggressive LRU disk cacheurlCache
: HTTP disk cache, respect cache-control
resizeMode?: enum
The resize mode of the image, default value contain
contain
cover
stretch
center
indicator?: object
show the indicator when loading,
indicator={{ style: 'large', color: 'red' }}
showPlaceholderOnFailure?: boolean
Show the blur placeholder image in the case of a failure.
fadeDuration?: number
The transition duration of the image. default value: 300 milliseconds(iOS) / 100(Android) milliseconds
note: To avoid flicking, it will be set to 0 when a placeholder is provided.
borderRadius?: number
The border radius added to the image
rounded?: boolean
Round the image into a circle
blur?: number
The blur radius of the blur filter added to the image
monochrome?: number / ColorValue
The color applied to the image.
note: For iOS and Android Q+, it works with any color. For Android Q-, it only supports grayscale.
resize?: number
Scales an image to the given width preserving aspect ratio
tint?: number / ColorValue
The color is applied to every non-transparent pixel, causing the image’s shape to adopt that color. This effect is not applied to placeholders.
enableLiveTextInteraction?: boolean
(iOS 16+ only)
Enables Live Text interaction with the image.
allowHardware?: boolean
(Android only)
Setting this to false this will reduce performance on API 26 and above. Only disable this if necessary. Coil's docs
format?: String
Specify the format for special image, e.g. svg
, gif
and apng
. In general, TurboImage will determine the decoder automatically.
onStart?: (result: NativeSyntheticEvent<TaskState>) => void
The function to call when the image is fetching
onSuccess?: (result: NativeSyntheticEvent<Success>) => void
The function to call when the image is successfully loaded
onFailure?: (result: NativeSyntheticEvent<Failure>) => void
The function to call when the request failed
onCompletion?: (result: NativeSyntheticEvent<TaskState>) => void
The function to call when the request is completed
Methods
prefetch: (sources: string[]) => Promise<void>
TurboImage.prefetch([URLs]);
clearMemoryCache: () => Promise<void>
await TurboImage.clearMemoryCache();
clearDiskCache: () => Promise<void>
await TurboImage.clearDiskCache();
Contributing
See the contributing guide to learn how to contribute to the repository and the development workflow.
License
MIT