Jim*_*mmy 5 android facebook fresco
我在同一时间顺序播放多个图像SimpleDraweeView,问题是当提交新的imageURI请求时,SimpleDrweeView将删除当前显示的图像并将其替换为空,直到下载URI.因此,它将在播放序列中留下空白(您可以想到我正在尝试做的是使用本地照片的卡通动画).我希望SimpleDrweeView能够保留当前图像,直到下载新图像,然后在准备就绪时将其交换.
我试图使用从低分辨率/高分辨率方案这一票,把旧的URI作为一个占位符,但没有工作(有相同的效果之前).
这就是我现在拥有的:
SimpleDraweeView draweeView = (SimpleDraweeView) findViewById(R.id.my_image_view);
draweeView.setImageURI(uri /* local image */);
Run Code Online (Sandbox Code Playgroud)
这是我到目前为止尝试过的(不起作用):
SimpleDraweeView draweeView = (SimpleDraweeView) findViewById(R.id.my_image_view);
Uri lowResUri, highResUri;
DraweeController controller = Fresco.newDraweeControllerBuilder().setTapToRetryEnabled(true)
.setLowResImageRequest(ImageRequest.fromUri((Uri) draweeView.getTag())) /*naive way to test the low/high res feature*/
.setImageRequest(ImageRequest.fromUri(uri))
.setOldController(draweeView.getController())
.build();
draweeView.setTag(uri);
draweeView.setController(controller);
Run Code Online (Sandbox Code Playgroud)
我是 Fresco 团队的一员,也许可以提供帮助。奇怪的是,您在低分辨率/高分辨率组合中遇到了同样的问题。如果图像当前正在显示,则意味着它应该位于位图内存缓存中,这又意味着当您下次切换到下一帧时设置为低分辨率图像时,它应该能够立即加载。您确定将正确的 uri 设置为低分辨率图像吗?(Uri) draweeView.getTag()看起来有点可疑。我会仔细检查那部分。
如果 uri 确实正确,但图像不再位于位图缓存中,则值得研究为什么不再缓存可见图像,因为我们有明确的逻辑来防止驱逐可见图像。请参阅此处如何通过详细日志记录来跟踪此情况。
如果上述所有方法都失败了,第三种选择是实际实现您自己的DataSource。我可以帮忙,但这可能有点复杂。基本思想是实现一个DataSource包装另一个DataSource实际提供图像的对象。然后你可以做这样的事情:
// keep this instance somewhere
mMyDataSourceSupplier = new MyDataSourceSupplier();
// build controller by specifying your custom datasource supplier instead of specifying any URIs.
Fresco.newDraweeControllerBuilder()
.setDataSourceSupplier(mMyDataSourceSupplier)
.build()
// later, when you need to change the image do
mMyDataSourceSupplier.setUri(nextUri);
// this is just an outline
class MyDataSourceSupplier implements Supplier<DataSource<CloseableReference<CloseableImage>>> {
private Uri mCurrentUri;
private DataSource<CloseableReference<CloseableImage>> mCurrentDataSource;
public void setUri(Uri uri) {
mCurrentUri = uri;
if (mCurrentDatasource != null) {
mCurrentDataSource.setUri(uri);
}
}
@Override
public DataSource<CloseableReference<CloseableImage>> get() {
mCurrentDataSource = new MyDataSource();
mCurrentDataSource.setUri(uri);
return mCurrentDataSource;
}
private class MyDataSource extends AbstractDataSource<CloseableReference<CloseableImage>> {
private DataSource mUnderlyingDataSource;
@Override
protected void closeResult(@Nullable CloseableReference<CloseableImage> result) {
CloseableReference.closeSafely(result);
}
@Override
@Nullable
public CloseableReference<CloseableImage> getResult() {
return CloseableReference.cloneOrNull(super.getResult());
}
@Override
public boolean close() {
if (mUnderlyingDataSource != null) {
mUnderlyingDataSource.close();
mUnderlyingDataSource = null;
}
return super.close();
}
public void setUri(Uri uri) {
if (mUnderlyingDataSource != null) {
mUnderlyingDataSource.close();
mUnderlyingDataSource = null;
}
if (uri != null && !isClosed()) {
mUnderlyingDataSource = Fresco.getImagePipeline().fetchDecodedImage(ImageRequest.fromUri(uri), null);
mUnderlyingDataSource.subscribe(new BaseDataSubscriber {
@Override
protected void onNewResultImpl(DataSource<List<CloseableReference<CloseableImage>>> dataSource) {
MyDataSource.super.setResult(dataSource.getResult(), false);
}
});
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1766 次 |
| 最近记录: |