import React from 'react'; import { type View } from 'react-native'; import ExpoImage from './ExpoImage'; import { ImageLoadOptions, ImagePrefetchOptions, ImageProps, ImageRef, ImageSource } from './Image.types'; export declare class Image extends React.PureComponent { nativeViewRef: React.RefObject; containerViewRef: React.RefObject; constructor(props: ImageProps); getAnimatableRef: () => View | this | null; /** * @hidden */ static Image: typeof ImageRef; /** * Preloads images at the given URLs that can be later used in the image view. * Preloaded images are cached to the memory and disk by default, so make sure * to use `disk` (default) or `memory-disk` [cache policy](#cachepolicy). * @param urls - A URL string or an array of URLs of images to prefetch. * @param {ImagePrefetchOptions['cachePolicy']} cachePolicy - The cache policy for prefetched images. * @return A promise resolving to `true` as soon as all images have been * successfully prefetched. If an image fails to be prefetched, the promise * will immediately resolve to `false` regardless of whether other images have * finished prefetching. */ static prefetch(urls: string | string[], cachePolicy?: ImagePrefetchOptions['cachePolicy']): Promise; /** * Preloads images at the given URLs that can be later used in the image view. * Preloaded images are cached to the memory and disk by default, so make sure * to use `disk` (default) or `memory-disk` [cache policy](#cachepolicy). * @param urls - A URL string or an array of URLs of images to prefetch. * @param options - Options for prefetching images. * @return A promise resolving to `true` as soon as all images have been * successfully prefetched. If an image fails to be prefetched, the promise * will immediately resolve to `false` regardless of whether other images have * finished prefetching. */ static prefetch(urls: string | string[], options?: ImagePrefetchOptions): Promise; /** * Asynchronously clears all images stored in memory. * @platform android * @platform ios * @return A promise resolving to `true` when the operation succeeds. * It may resolve to `false` on Android when the activity is no longer available. * Resolves to `false` on Web. */ static clearMemoryCache(): Promise; /** * Asynchronously clears all images from the disk cache. * @platform android * @platform ios * @return A promise resolving to `true` when the operation succeeds. * It may resolve to `false` on Android when the activity is no longer available. * Resolves to `false` on Web. */ static clearDiskCache(): Promise; /** * Asynchronously checks if an image exists in the disk cache and resolves to * the path of the cached image if it does. * @param cacheKey - The cache key for the requested image. Unless you have set * a custom cache key, this will be the source URL of the image. * @platform android * @platform ios * @return A promise resolving to the path of the cached image. It will resolve * to `null` if the image does not exist in the cache. */ static getCachePathAsync(cacheKey: string): Promise; /** * Asynchronously generates a [Blurhash](https://blurha.sh) from an image. * @param source - The image source, either a URL (string) or an ImageRef * @param numberOfComponents - The number of components to encode the blurhash with. * Must be between 1 and 9. Defaults to `[4, 3]`. * @platform android * @platform ios * @return A promise resolving to the blurhash string. */ static generateBlurhashAsync(source: string | ImageRef, numberOfComponents: [number, number] | { width: number; height: number; }): Promise; /** * Asynchronously generates a [Thumbhash](https://evanw.github.io/thumbhash/) from an image. * @param source - The image source, either a URL (string) or an ImageRef * @platform android * @platform ios * @return A promise resolving to the thumbhash string. */ static generateThumbhashAsync(source: string | ImageRef): Promise; /** * Asynchronously starts playback of the view's image if it is animated. * @platform android * @platform ios */ startAnimating(): Promise; /** * Asynchronously stops the playback of the view's image if it is animated. * @platform android * @platform ios */ stopAnimating(): Promise; /** * Prevents the resource from being reloaded by locking it. * @platform android * @platform ios */ lockResourceAsync(): Promise; /** * Releases the lock on the resource, allowing it to be reloaded. * @platform android * @platform ios */ unlockResourceAsync(): Promise; /** * Reloads the resource, ignoring lock. * @platform android * @platform ios */ reloadAsync(): Promise; /** * Loads an image from the given source to memory and resolves to * an object that references the native image instance. * @platform android * @platform ios * @platform web */ static loadAsync(source: ImageSource | string | number, options?: ImageLoadOptions): Promise; render(): React.JSX.Element; } //# sourceMappingURL=Image.d.ts.map