A image module for React Native.
depend on SDWebImage。
- Loading progress indicator for network image
- Auto scale assets image
- More coming soon...
If your project use CocoaPod
- Like above
- Like above
- Add
pod 'SDWebImage', '~> 3.7.2'
to projectPodfile
pod install
RCTExImage.xcodeproj > Build Phase > Link Bindary With Libraries > +
AddImageIO.framework
.RCTExImage.xcodeproj > Build Settings > Header Search Paths
Look forHeader Search Paths
and make sure it contains$(SRCROOT)/../react-native/React
and$(SRCROOT)/../../Pods/Headers/Public
- mark asrecursive
.
Else
- Drag & Drop the
{projectDir}/node_modules/react-native-eximage/RCTExImage.xcodeproj
into your project - Add
libRCTExImage.a
to your project'sBuild Phases > Link Binary With Libraries
cd {projectDir}/node_modules/react-native-eximage
git clone https://github.com/rs/SDWebImage.git
- Drag & Drop the
SDWebImage.xcodeproj
file underRCTExImage.xcodeproj
- Rebuild SDWebImage automagically if you ever decide to assimilate some changes in the future from git ... then goto
RCTExImage.xcodeproj > Build Phase > Target Dependencies > + > SDWebImage
. RCTExImage.xcodeproj > Build Phase > Link Bindary With Libraries > +
AddlibSDWebImage.a
andImageIO.framework
.RCTExImage.xcodeproj > Build Settings > Header Search Paths
Look forHeader Search Paths
and make sure it contains$(SRCROOT)/../react-native/Rend
$(SRCROOT)/SDWebImage- mark as
recursive`.
'use strict';
var React = require('react-native');
var {
AppRegistry,
StyleSheet,
Text,
View,
ScrollView,
} = React;
var Dimensions = require('Dimensions');
var SCREEN_WIDTH = Dimensions.get('window').width;
var ExImage = require('react-native-eximage');
var RCTExImageExample = React.createClass({
getInitialState: function() {
return {
loadFailed: false,
}
},
render: function() {
var errorEle = null;
if (this.state.loadFailed) {
errorEle = (<Text>Reload</Text>);
}
return (
<View style={styles.container}>
<ScrollView>
<ExImage
source={{uri:'http://i.ytimg.com/vi/SQEbPn36m1c/maxresdefault.jpg'}}
style={{width: SCREEN_WIDTH, height: SCREEN_WIDTH, alignItems:'center', justifyContent:'center'}}
resizeMode='cover'
onLoadStart={(event) => {
this.setState({loadFailed: false});
console.log('onLoadStart: ' + event);
}}
onLoadProgress={(event) => {
console.log('onLoadProgress: ' + event);
}}
onLoadError={(event) => {
this.setState({loadFailed: true})
console.log('onLoadError: ' + event);
}}
onLoaded={(event) => {
console.log('onLoaded: ' + event);
}}
>
{errorEle}
</ExImage>
<ExImage source={{uri:'assets-library://asset/asset.JPG?id=A1844CD1-28A1-43EB-8894-B769BFABFF12&ext=JPG'}} style={{width: SCREEN_WIDTH, height: SCREEN_WIDTH}} />
</ScrollView>
</View>
);
}
});
var styles = StyleSheet.create({
container: {
flex: 1,
flexDirection: 'column',
backgroundColor: '#FFFFFF',
}
});
AppRegistry.registerComponent('RCTExImageExample', () => RCTExImageExample);
thumbnail generate: http://www.mindsea.com/2012/12/downscaling-huge-alassets-without-fear-of-sigkill/
Olivier Poitrey (the author of SDWebImage): https://github.com/rs