mirror of
https://github.com/status-im/react-native.git
synced 2025-01-25 00:39:03 +00:00
9c73e2ff7a
Summary: Update to https://github.com/facebook/react-native/pull/1969 -- Recent improvements allow RCTImageLoader to select a more appropriate sized image based on the layout dimensions. Sizes: - asset.thumbnail - asset.aspectRatioThumbnail - asset.defaultRepresentation.fullScreenImage - asset.defaultRepresentation.fullResolutionImage Prior, only the fullResolutionImage was used. This was memory intensive and resulted in crashes when loading several large images at once. The updated implementation works well, but can be made more efficient: Consider loading 10 8MP (3264x2448) images in 150x150 pixel containers. The target size (150x150) is larger than asset.thumbnail (approx 100x100), therefore the fullScreenImage representation is used instead (approx 1334x1000). This commit will scale the asset to the minimum size required while taking into account original aspect ratio and device scale. Memory usage is considerably lower and many more images can be loaded in sequence without having to worry Closes https://github.com/facebook/react-native/pull/2008 Github Author: Adam Roth <adamjroth@gmail.com>
139 lines
3.6 KiB
JavaScript
139 lines
3.6 KiB
JavaScript
/**
|
|
* The examples provided by Facebook are for non-commercial testing and
|
|
* evaluation purposes only.
|
|
*
|
|
* Facebook reserves all rights not expressly granted.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
|
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NON INFRINGEMENT. IN NO EVENT SHALL
|
|
* FACEBOOK BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
|
|
* AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
*
|
|
* @flow
|
|
*/
|
|
'use strict';
|
|
|
|
var React = require('react-native');
|
|
var {
|
|
CameraRoll,
|
|
Image,
|
|
SliderIOS,
|
|
StyleSheet,
|
|
SwitchIOS,
|
|
Text,
|
|
View,
|
|
TouchableOpacity
|
|
} = React;
|
|
|
|
var CameraRollView = require('./CameraRollView.ios');
|
|
var AssetScaledImageExampleView = require('./AssetScaledImageExample');
|
|
|
|
var CAMERA_ROLL_VIEW = 'camera_roll_view';
|
|
|
|
var CameraRollExample = React.createClass({
|
|
|
|
getInitialState() {
|
|
return {
|
|
groupTypes: 'SavedPhotos',
|
|
sliderValue: 1,
|
|
bigImages: true,
|
|
};
|
|
},
|
|
|
|
render() {
|
|
return (
|
|
<View>
|
|
<SwitchIOS
|
|
onValueChange={this._onSwitchChange}
|
|
value={this.state.bigImages} />
|
|
<Text>{(this.state.bigImages ? 'Big' : 'Small') + ' Images'}</Text>
|
|
<SliderIOS
|
|
value={this.state.sliderValue}
|
|
onValueChange={this._onSliderChange}
|
|
/>
|
|
<Text>{'Group Type: ' + this.state.groupTypes}</Text>
|
|
<CameraRollView
|
|
ref={CAMERA_ROLL_VIEW}
|
|
batchSize={20}
|
|
groupTypes={this.state.groupTypes}
|
|
renderImage={this._renderImage}
|
|
/>
|
|
</View>
|
|
);
|
|
},
|
|
|
|
loadAsset(asset){
|
|
this.props.navigator.push({
|
|
title: 'Camera Roll Image',
|
|
component: AssetScaledImageExampleView,
|
|
backButtonTitle: 'Back',
|
|
passProps: { asset: asset },
|
|
});
|
|
},
|
|
|
|
_renderImage(asset) {
|
|
var imageSize = this.state.bigImages ? 150 : 75;
|
|
var imageStyle = [styles.image, {width: imageSize, height: imageSize}];
|
|
var location = asset.node.location.longitude ?
|
|
JSON.stringify(asset.node.location) : 'Unknown location';
|
|
return (
|
|
<TouchableOpacity onPress={ this.loadAsset.bind( this, asset ) }>
|
|
<View key={asset} style={styles.row}>
|
|
<Image
|
|
source={asset.node.image}
|
|
style={imageStyle}
|
|
/>
|
|
<View style={styles.info}>
|
|
<Text style={styles.url}>{asset.node.image.uri}</Text>
|
|
<Text>{location}</Text>
|
|
<Text>{asset.node.group_name}</Text>
|
|
<Text>{new Date(asset.node.timestamp).toString()}</Text>
|
|
</View>
|
|
</View>
|
|
</TouchableOpacity>
|
|
);
|
|
},
|
|
|
|
_onSliderChange(value) {
|
|
var options = CameraRoll.GroupTypesOptions;
|
|
var index = Math.floor(value * options.length * 0.99);
|
|
var groupTypes = options[index];
|
|
if (groupTypes !== this.state.groupTypes) {
|
|
this.setState({groupTypes: groupTypes});
|
|
}
|
|
},
|
|
|
|
_onSwitchChange(value) {
|
|
this.refs[CAMERA_ROLL_VIEW].rendererChanged();
|
|
this.setState({ bigImages: value });
|
|
}
|
|
});
|
|
|
|
var styles = StyleSheet.create({
|
|
row: {
|
|
flexDirection: 'row',
|
|
flex: 1,
|
|
},
|
|
url: {
|
|
fontSize: 9,
|
|
marginBottom: 14,
|
|
},
|
|
image: {
|
|
margin: 4,
|
|
},
|
|
info: {
|
|
flex: 1,
|
|
},
|
|
});
|
|
|
|
exports.title = 'Camera Roll';
|
|
exports.description = 'Example component that uses CameraRoll to list user\'s photos';
|
|
exports.examples = [
|
|
{
|
|
title: 'Photos',
|
|
render(): ReactElement { return <CameraRollExample />; }
|
|
}
|
|
];
|