Skip to content

Commit

Permalink
[Exp] Support prefetch image.
Browse files Browse the repository at this point in the history
  • Loading branch information
jondot authored and ide committed Mar 12, 2016
1 parent c348def commit e32131c
Show file tree
Hide file tree
Showing 5 changed files with 67 additions and 4 deletions.
21 changes: 18 additions & 3 deletions Examples/UIExplorer/ImageExample.js
Original file line number Diff line number Diff line change
Expand Up @@ -27,11 +27,14 @@ var {
var base64Icon = '';

var ImageCapInsetsExample = require('./ImageCapInsetsExample');
const IMAGE_PREFETCH_URL = 'http://facebook.github.io/origami/public/images/blog-hero.jpg?r=1&t=' + Date.now();
Image.prefetch(IMAGE_PREFETCH_URL);

var NetworkImageCallbackExample = React.createClass({
getInitialState: function() {
return {
events: [],
startLoadPrefetched: false,
mountTime: new Date(),
};
},
Expand All @@ -50,9 +53,20 @@ var NetworkImageCallbackExample = React.createClass({
style={[styles.base, {overflow: 'visible'}]}
onLoadStart={() => this._loadEventFired(`✔ onLoadStart (+${new Date() - mountTime}ms)`)}
onLoad={() => this._loadEventFired(`✔ onLoad (+${new Date() - mountTime}ms)`)}
onLoadEnd={() => this._loadEventFired(`✔ onLoadEnd (+${new Date() - mountTime}ms)`)}
onLoadEnd={() => {
this._loadEventFired(`✔ onLoadEnd (+${new Date() - mountTime}ms)`);
this.setState({startLoadPrefetched: true});
}}
/>

{this.state.startLoadPrefetched ?
<Image
source={this.props.prefetchedSource}
style={[styles.base, {overflow: 'visible'}]}
onLoadStart={() => this._loadEventFired(`✔ (prefetched)onLoadStart (+${new Date() - mountTime}ms)`)}
onLoad={() => this._loadEventFired(`✔ (prefetched)onLoad (+${new Date() - mountTime}ms)`)}
onLoadEnd={() => this._loadEventFired(`✔ (prefetched)onLoadEnd (+${new Date() - mountTime}ms)`)}
/>
: null}
<Text style={{marginTop: 20}}>
{this.state.events.join('\n')}
</Text>
Expand Down Expand Up @@ -165,7 +179,8 @@ exports.examples = [
title: 'Image Loading Events',
render: function() {
return (
<NetworkImageCallbackExample source={{uri: 'http://facebook.github.io/origami/public/images/blog-hero.jpg?r=1'}}/>
<NetworkImageCallbackExample source={{uri: 'http://facebook.github.io/origami/public/images/blog-hero.jpg?r=1&t=' + Date.now()}}
prefetchedSource={{uri: IMAGE_PREFETCH_URL}}/>
);
},
},
Expand Down
5 changes: 5 additions & 0 deletions Libraries/Image/Image.android.js
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ var invariant = require('fbjs/lib/invariant');
var merge = require('merge');
var requireNativeComponent = require('requireNativeComponent');
var resolveAssetSource = require('resolveAssetSource');
var Networking = NativeModules.Networking;

/**
* <Image> - A react component for displaying different types of images,
Expand Down Expand Up @@ -110,6 +111,10 @@ var Image = React.createClass({

statics: {
resizeMode: ImageResizeMode,
/**
* Prefetch image for later use. Download remote image to the disk cache.
*/
prefetch: (url) => { Networking .prefetchImage(url); },
},

mixins: [NativeMethodsMixin],
Expand Down
8 changes: 7 additions & 1 deletion Libraries/Image/Image.ios.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ var EdgeInsetsPropType = require('EdgeInsetsPropType');
var ImageResizeMode = require('ImageResizeMode');
var ImageStylePropTypes = require('ImageStylePropTypes');
var NativeMethodsMixin = require('NativeMethodsMixin');
var NativeModules = require('NativeModules');
var PropTypes = require('ReactPropTypes');
var React = require('React');
var ReactNativeViewAttributes = require('ReactNativeViewAttributes');
Expand All @@ -31,6 +32,7 @@ var warning = require('fbjs/lib/warning');
var {
ImageViewManager,
NetworkImageViewManager,
Networking,
} = require('NativeModules');

/**
Expand Down Expand Up @@ -176,7 +178,11 @@ var Image = React.createClass({
ImageViewManager.getSize(uri, success, failure || function() {
console.warn('Failed to get size for image: ' + uri);
});
}
},
/**
* Prefetch image for later use. Download remote image to the disk cache.
*/
prefetch: (url) => { Networking.prefetchImage(url); },
},

mixins: [NativeMethodsMixin],
Expand Down
6 changes: 6 additions & 0 deletions Libraries/Network/RCTNetworking.m
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
#import "RCTHTTPRequestHandler.h"
#import "RCTLog.h"
#import "RCTUtils.h"
#import "RCTImageLoader.h"

typedef RCTURLRequestCancellationBlock (^RCTHTTPQueryResult)(NSError *error, NSDictionary<NSString *, id> *result);

Expand Down Expand Up @@ -449,6 +450,11 @@ - (RCTNetworkTask *)networkTaskWithRequest:(NSURLRequest *)request
[_tasksByRequestID removeObjectForKey:requestID];
}

RCT_EXPORT_METHOD(prefetchImage:(NSString *)url)
{
[_bridge.imageLoader loadImageWithTag:url callback:^(NSError *error, UIImage *image) {}];
}

@end

@implementation RCTBridge (RCTNetworking)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,12 +11,19 @@

import javax.annotation.Nullable;

import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.io.Reader;

import java.util.concurrent.TimeUnit;

import android.net.Uri;
import com.facebook.common.logging.FLog;
import com.facebook.drawee.backends.pipeline.Fresco;
import com.facebook.imagepipeline.core.ImagePipeline;
import com.facebook.imagepipeline.request.ImageRequest;
import com.facebook.imagepipeline.request.ImageRequestBuilder;
import com.facebook.react.bridge.Arguments;
import com.facebook.react.bridge.ExecutorToken;
import com.facebook.react.bridge.GuardedAsyncTask;
Expand All @@ -27,6 +34,7 @@
import com.facebook.react.bridge.ReadableMap;
import com.facebook.react.bridge.WritableArray;
import com.facebook.react.bridge.WritableMap;
import com.facebook.react.common.ReactConstants;
import com.facebook.react.modules.core.DeviceEventManagerModule;
import com.facebook.stetho.okhttp.StethoInterceptor;

Expand All @@ -39,6 +47,8 @@
import com.squareup.okhttp.RequestBody;
import com.squareup.okhttp.Response;
import com.squareup.okhttp.ResponseBody;
import okio.BufferedSink;
import okio.Okio;

import static java.lang.Math.min;

Expand Down Expand Up @@ -463,4 +473,25 @@ private DeviceEventManagerModule.RCTDeviceEventEmitter getEventEmitter(ExecutorT
return getReactApplicationContext()
.getJSModule(ExecutorToken, DeviceEventManagerModule.RCTDeviceEventEmitter.class);
}

/**
* Prefetch image to the fresco image disk cache
*/
@ReactMethod
public void prefetchImage(String url) {
Uri uri = null;
try {
if (url != null && !url.isEmpty()) {
uri = Uri.parse(url);
}
} catch (Exception e){
//ignore malformed url
}
if (uri == null) {
FLog.w(ReactConstants.TAG,"Invalid prefetch image url.");
return;
}
ImageRequest request = ImageRequestBuilder.newBuilderWithSource(uri).build();
Fresco.getImagePipeline().prefetchToDiskCache(request, this);
}
}

0 comments on commit e32131c

Please sign in to comment.