mirror of
https://github.com/status-im/react-native.git
synced 2025-01-13 19:15:05 +00:00
Introducing <ImageBackground>, replacement for <Image> which supports nesting views
Summary: We are removing support of nesting views inside <Image> component. We decided to do this because having this feature makes supporting `intrinsinc content size` of the `<Image>` impossible; so when the transition process is complete, there will be no need to specify image size explicitly, it can be inferred from actual image bitmap. And this is the step #0. <ImageBackground> is very simple drop-in replacement which implements this functionality via very simple styling. Please, use <ImageBackground> instead of <Image> if you want to put something inside. Reviewed By: yungsters Differential Revision: D5100021 fbshipit-source-id: 640c0fb2d1066e166d974efba39b4cfaaee7dd45
This commit is contained in:
parent
275ba316c3
commit
9637dd4a1b
64
Libraries/Image/ImageBackground.js
Normal file
64
Libraries/Image/ImageBackground.js
Normal file
@ -0,0 +1,64 @@
|
||||
/**
|
||||
* 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.
|
||||
*
|
||||
* @providesModule ImageBackground
|
||||
* @flow
|
||||
* @format
|
||||
*/
|
||||
'use strict';
|
||||
|
||||
const Image = require('Image');
|
||||
const React = require('React');
|
||||
const View = require('View');
|
||||
|
||||
/**
|
||||
* Very simple drop-in replacement for <Image> which supports nesting views.
|
||||
*
|
||||
* ```ReactNativeWebPlayer
|
||||
* import React, { Component } from 'react';
|
||||
* import { AppRegistry, View, ImageBackground, Text } from 'react-native';
|
||||
*
|
||||
* class DisplayAnImageBackground extends Component {
|
||||
* render() {
|
||||
* return (
|
||||
* <ImageBackground
|
||||
* style={{width: 50, height: 50}}
|
||||
* source={{uri: 'https://facebook.github.io/react/img/logo_og.png'}}
|
||||
* >
|
||||
* <Text>React</Text>
|
||||
* </ImageBackground>
|
||||
* );
|
||||
* }
|
||||
* }
|
||||
*
|
||||
* // App registration and rendering
|
||||
* AppRegistry.registerComponent('DisplayAnImageBackground', () => DisplayAnImageBackground);
|
||||
* ```
|
||||
*/
|
||||
class ImageBackground extends React.Component {
|
||||
render() {
|
||||
const {children, style, ...props} = this.props;
|
||||
return (
|
||||
<View style={style}>
|
||||
<Image
|
||||
{...props}
|
||||
style={{
|
||||
position: 'absolute',
|
||||
left: 0,
|
||||
right: 0,
|
||||
top: 0,
|
||||
bottom: 0,
|
||||
}}
|
||||
/>
|
||||
{children}
|
||||
</View>
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = ImageBackground;
|
@ -24,6 +24,7 @@ const ReactNative = {
|
||||
get DrawerLayoutAndroid() { return require('DrawerLayoutAndroid'); },
|
||||
get FlatList() { return require('FlatList'); },
|
||||
get Image() { return require('Image'); },
|
||||
get ImageBackground() { return require('ImageBackground'); },
|
||||
get ImageEditor() { return require('ImageEditor'); },
|
||||
get ImageStore() { return require('ImageStore'); },
|
||||
get KeyboardAvoidingView() { return require('KeyboardAvoidingView'); },
|
||||
|
@ -20,6 +20,7 @@ var {
|
||||
StyleSheet,
|
||||
Text,
|
||||
View,
|
||||
ImageBackground,
|
||||
} = ReactNative;
|
||||
|
||||
var base64Icon = '';
|
||||
@ -117,7 +118,7 @@ var NetworkImageExample = React.createClass({
|
||||
</View> : null;
|
||||
return this.state.error ?
|
||||
<Text>{this.state.error}</Text> :
|
||||
<Image
|
||||
<ImageBackground
|
||||
source={this.props.source}
|
||||
style={[styles.base, {overflow: 'visible'}]}
|
||||
onLoadStart={(e) => this.setState({loading: true})}
|
||||
@ -125,7 +126,7 @@ var NetworkImageExample = React.createClass({
|
||||
onProgress={(e) => this.setState({progress: Math.round(100 * e.nativeEvent.loaded / e.nativeEvent.total)})}
|
||||
onLoad={() => this.setState({loading: false, error: false})}>
|
||||
{loader}
|
||||
</Image>;
|
||||
</ImageBackground>;
|
||||
}
|
||||
});
|
||||
|
||||
@ -436,13 +437,13 @@ exports.examples = [
|
||||
title: 'Nesting',
|
||||
render: function() {
|
||||
return (
|
||||
<Image
|
||||
<ImageBackground
|
||||
style={{width: 60, height: 60, backgroundColor: 'transparent'}}
|
||||
source={fullImage}>
|
||||
<Text style={styles.nestedText}>
|
||||
React
|
||||
</Text>
|
||||
</Image>
|
||||
</ImageBackground>
|
||||
);
|
||||
},
|
||||
},
|
||||
|
Loading…
x
Reference in New Issue
Block a user