2015-02-19 20:10:52 -08:00
/ * *
2015-03-23 13:35:08 -07:00
* Copyright ( c ) 2015 - present , Facebook , Inc .
* All rights reserved .
*
* This source code is licensed under the BSD - style license found in the
* LICENSE file in the root directory of this source tree . An additional grant
* of patent rights can be found in the PATENTS file in the same directory .
2015-02-19 20:10:52 -08:00
*
* @ providesModule Image
2015-03-26 10:06:50 -07:00
* @ flow
2018-01-14 19:32:26 -08:00
* @ format
2015-02-19 20:10:52 -08:00
* /
'use strict' ;
2016-06-07 05:29:13 -07:00
const EdgeInsetsPropType = require ( 'EdgeInsetsPropType' ) ;
const ImageResizeMode = require ( 'ImageResizeMode' ) ;
const ImageSourcePropType = require ( 'ImageSourcePropType' ) ;
const ImageStylePropTypes = require ( 'ImageStylePropTypes' ) ;
2016-11-04 05:40:26 -07:00
const NativeMethodsMixin = require ( 'NativeMethodsMixin' ) ;
2016-06-07 05:29:13 -07:00
const NativeModules = require ( 'NativeModules' ) ;
const React = require ( 'React' ) ;
2017-04-12 16:09:48 -07:00
const PropTypes = require ( 'prop-types' ) ;
2016-06-07 05:29:13 -07:00
const ReactNativeViewAttributes = require ( 'ReactNativeViewAttributes' ) ;
const StyleSheet = require ( 'StyleSheet' ) ;
const StyleSheetPropType = require ( 'StyleSheetPropType' ) ;
2017-07-07 14:24:25 -07:00
const createReactClass = require ( 'create-react-class' ) ;
2016-06-07 05:29:13 -07:00
const flattenStyle = require ( 'flattenStyle' ) ;
const requireNativeComponent = require ( 'requireNativeComponent' ) ;
const resolveAssetSource = require ( 'resolveAssetSource' ) ;
const ImageViewManager = NativeModules . ImageViewManager ;
Added getImageSize method
Summary:
public
This diff adds a `getSize()` method to `Image` to retrieve the width and height of an image prior to displaying it. This is useful when working with images from uncontrolled sources, and has been a much-requested feature.
In order to retrieve the image dimensions, the image may first need to be loaded or downloaded, after which it will be cached. This means that in principle you could use this method to preload images, however it is not optimized for that purpose, and may in future be implemented in a way that does not fully load/download the image data.
A fully supported way to preload images will be provided in a future diff.
The API (separate success and failure callbacks) is far from ideal, but until we agree on a unified standard, this was the most conventional way I could think of to implement it. If it returned a promise or something similar, it would be unique among all such APIS in the framework.
Please note that this has been a long time coming, in part due to much bikeshedding about what the API should look like, so while it's not unlikely that the API may change in future, I think having *some* way to do this is better than waiting until we can define the "perfect" way.
Reviewed By: vjeux
Differential Revision: D2797365
fb-gh-sync-id: 11eb1b8547773b1f8be0bc55ddf6dfedebf7fc0a
2015-12-31 18:50:26 -08:00
2015-02-19 20:10:52 -08:00
/ * *
2015-04-27 13:55:01 -07:00
* A React component for displaying different types of images ,
2015-02-19 20:10:52 -08:00
* including network images , static resources , temporary local images , and
2015-03-09 09:28:51 -07:00
* images from local disk , such as the camera roll .
2015-02-19 20:10:52 -08:00
*
2018-01-29 16:10:49 -08:00
* See https : //facebook.github.io/react-native/docs/image.html
2015-02-19 20:10:52 -08:00
* /
2017-07-07 14:24:25 -07:00
const Image = createReactClass ( {
displayName : 'Image' ,
2015-02-19 20:10:52 -08:00
propTypes : {
2016-06-24 10:39:06 -07:00
/ * *
2018-01-29 16:10:49 -08:00
* See https : //facebook.github.io/react-native/docs/image.html#style
2016-06-24 10:39:06 -07:00
* /
2015-07-15 19:17:13 -01:00
style : StyleSheetPropType ( ImageStylePropTypes ) ,
2015-04-01 10:56:21 -07:00
/ * *
2016-06-01 10:32:20 -07:00
* The image source ( either a remote URL or a local file resource ) .
2016-07-28 13:58:50 -07:00
*
2018-01-29 16:10:49 -08:00
* See https : //facebook.github.io/react-native/docs/image.html#source
2015-04-01 10:56:21 -07:00
* /
2016-06-01 10:32:20 -07:00
source : ImageSourcePropType ,
2015-04-16 18:17:19 -07:00
/ * *
2015-12-08 03:29:08 -08:00
* A static image to display while loading the image source .
2016-06-24 10:39:06 -07:00
*
2018-01-29 16:10:49 -08:00
* See https : //facebook.github.io/react-native/docs/image.html#defaultsource
2015-04-16 18:17:19 -07:00
* /
2015-12-08 03:29:08 -08:00
defaultSource : PropTypes . oneOfType ( [
PropTypes . shape ( {
uri : PropTypes . string ,
2016-06-01 10:32:20 -07:00
width : PropTypes . number ,
height : PropTypes . number ,
scale : PropTypes . number ,
2015-12-08 03:29:08 -08:00
} ) ,
PropTypes . number ,
] ) ,
2015-02-19 20:10:52 -08:00
/ * *
2015-07-24 06:01:33 -07:00
* When true , indicates the image is an accessibility element .
2018-01-29 16:10:49 -08:00
*
* See https : //facebook.github.io/react-native/docs/image.html#accessible
2015-02-19 20:10:52 -08:00
* /
accessible : PropTypes . bool ,
/ * *
2015-07-24 06:01:33 -07:00
* The text that ' s read by the screen reader when the user interacts with
* the image .
2018-01-29 16:10:49 -08:00
*
* See https : //facebook.github.io/react-native/docs/image.html#accessibilitylabel
2015-02-19 20:10:52 -08:00
* /
2017-02-02 22:10:35 -08:00
accessibilityLabel : PropTypes . node ,
2016-03-17 12:25:07 -07:00
/ * *
2018-01-14 19:32:26 -08:00
* blurRadius : the blur radius of the blur filter added to the image
2018-01-29 16:10:49 -08:00
*
* See https : //facebook.github.io/react-native/docs/image.html#blurradius
2018-01-14 19:32:26 -08:00
* /
2016-03-17 12:25:07 -07:00
blurRadius : PropTypes . number ,
2015-02-19 20:10:52 -08:00
/ * *
2018-01-29 16:10:49 -08:00
* See https : //facebook.github.io/react-native/docs/image.html#capinsets
2015-02-19 20:10:52 -08:00
* /
capInsets : EdgeInsetsPropType ,
2016-09-09 05:00:52 -07:00
/ * *
2018-01-29 16:10:49 -08:00
* See https : //facebook.github.io/react-native/docs/image.html#resizemethod
2016-09-09 05:00:52 -07:00
* /
resizeMethod : PropTypes . oneOf ( [ 'auto' , 'resize' , 'scale' ] ) ,
2015-04-16 18:17:19 -07:00
/ * *
* Determines how to resize the image when the frame doesn ' t match the raw
* image dimensions .
2015-12-15 17:33:37 -08:00
*
2018-01-29 16:10:49 -08:00
* See https : //facebook.github.io/react-native/docs/image.html#resizemode
2015-04-16 18:17:19 -07:00
* /
2018-01-14 19:32:26 -08:00
resizeMode : PropTypes . oneOf ( [
'cover' ,
'contain' ,
'stretch' ,
'repeat' ,
'center' ,
] ) ,
2015-02-19 20:10:52 -08:00
/ * *
2015-04-01 10:56:21 -07:00
* A unique identifier for this element to be used in UI Automation
2015-02-19 20:10:52 -08:00
* testing scripts .
2018-01-29 16:10:49 -08:00
*
* See https : //facebook.github.io/react-native/docs/image.html#testid
2015-02-19 20:10:52 -08:00
* /
testID : PropTypes . string ,
2015-05-15 18:05:49 -07:00
/ * *
* Invoked on mount and layout changes with
2015-07-24 06:01:33 -07:00
* ` {nativeEvent: {layout: {x, y, width, height}}} ` .
2018-01-29 16:10:49 -08:00
*
* See https : //facebook.github.io/react-native/docs/image.html#onlayout
2015-05-15 18:05:49 -07:00
* /
2015-07-09 15:48:22 -01:00
onLayout : PropTypes . func ,
/ * *
2016-06-24 10:39:06 -07:00
* Invoked on load start .
*
2018-01-29 16:10:49 -08:00
* See https : //facebook.github.io/react-native/docs/image.html#onloadstart
2015-07-09 15:48:22 -01:00
* /
onLoadStart : PropTypes . func ,
/ * *
2016-06-24 10:39:06 -07:00
* Invoked on download progress with ` {nativeEvent: {loaded, total}} ` .
2018-01-29 16:10:49 -08:00
*
* See https : //facebook.github.io/react-native/docs/image.html#onprogress
2015-07-09 15:48:22 -01:00
* /
2015-07-15 19:17:13 -01:00
onProgress : PropTypes . func ,
2015-07-09 15:48:22 -01:00
/ * *
2016-06-24 10:39:06 -07:00
* Invoked on load error with ` {nativeEvent: {error}} ` .
2018-01-29 16:10:49 -08:00
*
* See https : //facebook.github.io/react-native/docs/image.html#onerror
2015-07-09 15:48:22 -01:00
* /
2015-07-15 19:17:13 -01:00
onError : PropTypes . func ,
2016-09-21 12:11:19 -07:00
/ * *
2018-01-29 16:10:49 -08:00
* Invoked when a partial load of the image is complete .
*
* See https : //facebook.github.io/react-native/docs/image.html#onpartialload
2016-09-21 12:11:19 -07:00
* /
onPartialLoad : PropTypes . func ,
2015-07-09 15:48:22 -01:00
/ * *
2016-06-24 10:39:06 -07:00
* Invoked when load completes successfully .
2018-01-29 16:10:49 -08:00
*
* See https : //facebook.github.io/react-native/docs/image.html#onload
2015-07-09 15:48:22 -01:00
* /
2015-07-15 19:17:13 -01:00
onLoad : PropTypes . func ,
/ * *
2016-06-24 10:39:06 -07:00
* Invoked when load either succeeds or fails .
2018-01-29 16:10:49 -08:00
*
* See https : //facebook.github.io/react-native/docs/image.html#onloadend
2015-07-15 19:17:13 -01:00
* /
onLoadEnd : PropTypes . func ,
2015-02-19 20:10:52 -08:00
} ,
statics : {
resizeMode : ImageResizeMode ,
2016-01-21 08:22:44 -08:00
/ * *
* Retrieve the width and height ( in pixels ) of an image prior to displaying it .
*
2018-01-29 16:10:49 -08:00
* See https : //facebook.github.io/react-native/docs/image.html#getsize
2016-01-21 08:22:44 -08:00
* /
getSize : function (
uri : string ,
success : ( width : number , height : number ) => void ,
2017-04-05 10:16:30 -07:00
failure ? : ( error : any ) => void ,
2016-01-21 08:22:44 -08:00
) {
2018-01-14 19:32:26 -08:00
ImageViewManager . getSize (
uri ,
success ,
failure ||
function ( ) {
console . warn ( 'Failed to get size for image: ' + uri ) ;
} ,
) ;
2016-04-13 07:29:10 -07:00
} ,
/ * *
* Prefetches a remote image for later use by downloading it to the disk
2018-01-29 16:10:49 -08:00
* cache .
2016-06-24 10:39:06 -07:00
*
2018-01-29 16:10:49 -08:00
* See https : //facebook.github.io/react-native/docs/image.html#prefetch
2016-04-13 07:29:10 -07:00
* /
prefetch ( url : string ) {
2016-06-07 05:29:13 -07:00
return ImageViewManager . prefetchImage ( url ) ;
2016-04-13 07:29:10 -07:00
} ,
2016-11-14 21:01:02 -08:00
/ * *
2018-01-29 16:10:49 -08:00
* Resolves an asset reference into an object .
*
* See https : //facebook.github.io/react-native/docs/image.html#resolveassetsource
2016-11-14 21:01:02 -08:00
* /
resolveAssetSource : resolveAssetSource ,
2015-02-19 20:10:52 -08:00
} ,
mixins : [ NativeMethodsMixin ] ,
/ * *
* ` NativeMethodsMixin ` will look for this when invoking ` setNativeProps ` . We
* make ` this ` look like an actual native component class .
* /
viewConfig : {
uiViewClassName : 'UIView' ,
2018-01-14 19:32:26 -08:00
validAttributes : ReactNativeViewAttributes . UIView ,
2015-02-19 20:10:52 -08:00
} ,
render : function ( ) {
2018-01-14 19:32:26 -08:00
const source = resolveAssetSource ( this . props . source ) || {
uri : undefined ,
width : undefined ,
height : undefined ,
} ;
2016-06-06 13:20:09 -07:00
2016-07-28 13:58:50 -07:00
let sources ;
2017-10-25 08:04:39 -07:00
let style ;
2016-07-28 13:58:50 -07:00
if ( Array . isArray ( source ) ) {
2017-10-25 08:04:39 -07:00
style = flattenStyle ( [ styles . base , this . props . style ] ) || { } ;
2016-07-28 13:58:50 -07:00
sources = source ;
} else {
2017-10-25 08:04:39 -07:00
const { width , height , uri } = source ;
2018-01-14 19:32:26 -08:00
style =
flattenStyle ( [ { width , height } , styles . base , this . props . style ] ) || { } ;
2016-07-28 13:58:50 -07:00
sources = [ source ] ;
if ( uri === '' ) {
console . warn ( 'source.uri should not be an empty string' ) ;
}
2016-06-01 10:32:20 -07:00
}
2016-06-06 13:20:09 -07:00
2018-01-14 19:32:26 -08:00
const resizeMode =
this . props . resizeMode || ( style || { } ) . resizeMode || 'cover' ; // Workaround for flow bug t7737108
2016-07-28 13:58:50 -07:00
const tintColor = ( style || { } ) . tintColor ; // Workaround for flow bug t7737108
2016-03-04 07:31:38 -08:00
if ( this . props . src ) {
2018-01-14 19:32:26 -08:00
console . warn (
'The <Image> component requires a `source` property rather than `src`.' ,
) ;
2016-03-04 07:31:38 -08:00
}
2017-09-25 21:55:56 -07:00
if ( this . props . children ) {
2018-01-14 19:32:26 -08:00
throw new Error (
'The <Image> component cannot contain children. If you want to render content on top of the image, consider using the <ImageBackground> component or absolute positioning.' ,
) ;
2017-09-25 21:55:56 -07:00
}
2016-01-22 11:31:40 -08:00
return (
2016-06-07 05:29:13 -07:00
< RCTImageView
2016-01-22 11:31:40 -08:00
{ ... this . props }
style = { style }
resizeMode = { resizeMode }
tintColor = { tintColor }
2016-07-28 13:58:50 -07:00
source = { sources }
2016-01-22 11:31:40 -08:00
/ >
) ;
Added getImageSize method
Summary:
public
This diff adds a `getSize()` method to `Image` to retrieve the width and height of an image prior to displaying it. This is useful when working with images from uncontrolled sources, and has been a much-requested feature.
In order to retrieve the image dimensions, the image may first need to be loaded or downloaded, after which it will be cached. This means that in principle you could use this method to preload images, however it is not optimized for that purpose, and may in future be implemented in a way that does not fully load/download the image data.
A fully supported way to preload images will be provided in a future diff.
The API (separate success and failure callbacks) is far from ideal, but until we agree on a unified standard, this was the most conventional way I could think of to implement it. If it returned a promise or something similar, it would be unique among all such APIS in the framework.
Please note that this has been a long time coming, in part due to much bikeshedding about what the API should look like, so while it's not unlikely that the API may change in future, I think having *some* way to do this is better than waiting until we can define the "perfect" way.
Reviewed By: vjeux
Differential Revision: D2797365
fb-gh-sync-id: 11eb1b8547773b1f8be0bc55ddf6dfedebf7fc0a
2015-12-31 18:50:26 -08:00
} ,
2015-02-19 20:10:52 -08:00
} ) ;
2016-06-07 05:29:13 -07:00
const styles = StyleSheet . create ( {
2015-02-19 20:10:52 -08:00
base : {
overflow : 'hidden' ,
} ,
} ) ;
2016-06-07 05:29:13 -07:00
const RCTImageView = requireNativeComponent ( 'RCTImageView' , Image ) ;
Added getImageSize method
Summary:
public
This diff adds a `getSize()` method to `Image` to retrieve the width and height of an image prior to displaying it. This is useful when working with images from uncontrolled sources, and has been a much-requested feature.
In order to retrieve the image dimensions, the image may first need to be loaded or downloaded, after which it will be cached. This means that in principle you could use this method to preload images, however it is not optimized for that purpose, and may in future be implemented in a way that does not fully load/download the image data.
A fully supported way to preload images will be provided in a future diff.
The API (separate success and failure callbacks) is far from ideal, but until we agree on a unified standard, this was the most conventional way I could think of to implement it. If it returned a promise or something similar, it would be unique among all such APIS in the framework.
Please note that this has been a long time coming, in part due to much bikeshedding about what the API should look like, so while it's not unlikely that the API may change in future, I think having *some* way to do this is better than waiting until we can define the "perfect" way.
Reviewed By: vjeux
Differential Revision: D2797365
fb-gh-sync-id: 11eb1b8547773b1f8be0bc55ddf6dfedebf7fc0a
2015-12-31 18:50:26 -08:00
2015-02-19 20:10:52 -08:00
module . exports = Image ;