我对此非常绝望。问题是 picasso 只显示占位符图标。
我的 FirebaseStorageRefernce
代码看起来像这样引用 Firebase Blog post :
StorageReference load = getImage(id);
load.getDownloadUrl().addOnSuccessListener(new OnSuccessListener<Uri>() {
@Override
public void onSuccess(Uri uri) {
downloadUri = uri;
}
}).addOnFailureListener(new OnFailureListener() {
@Override
public void onFailure(@NonNull Exception e) {
Log.e("Failure",e.toString());
}
});
我得到的 downloadUri 有效并且工作正常。现在我将此 downloadUri 用于 Picasso。
Picasso picasso = new Picasso.Builder(getApplicationContext()).listener(new Picasso.Listener() {
@Override
public void onImageLoadFailed(Picasso picasso, Uri uri, Exception e) {
e.printStackTrace();
}
}).build();
picasso.setLoggingEnabled(true);
picasso.load(downloadUri).placeholder(R.drawable.toxic_bait_icon).fit().into(thump, new MarkerCallback(marker));
引用answer我在 StackOverFlow 上找到的,我做了一个 MarkerCallback 类:
public class MarkerCallback implements Callback {
com.google.android.gms.maps.model.Marker marker = null;
MarkerCallback(Marker marker)
{
this.marker = marker;
}
@Override
public void onError(){
Log.e(getClass().getSimpleName(), "Error loading thumbnail!");
}
@Override
public void onSuccess(){
Log.d("onSuccess","Picasso Callback");
if(marker != null && marker.isInfoWindowShown()){
Log.d("onSuccess","Picasso Callback in if");
marker.hideInfoWindow();
marker.showInfoWindow();
}
}}
你可以看到我在 onSuccess
方法上添加了一些 Log.d
消息来跟踪它是否被调用。但看起来 onSucess
方法不会随时调用,因为 Log.d
消息从未出现在 LogCat 中。
此外,即使我启用了 Picasso,它也不会显示任何异常、错误、失败或日志。
picasso.setLoggingEnabled(true);
唯一发生的事情是信息窗口中的 ImageView 显示占位符。
我想可能是因为图片太大无法加载,但我尝试加载的图片只有 652.86 KB。
PS:Picasso 也没有在左角显示丝带来调试缓存行为。我尝试激活:
picasso.setIndicatorsEnabled(true);
我使用 Picasso 2.5.2。如果 Picasso 不显示日志或色带,我不知道我做错了什么或如何调试它。我希望有一个人可以帮助我。我非常需要这个功能。
附录: 我也检查了权限,引用这个post , 他们没问题。
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission
android:name="android.permission.INTERNET"/>
<uses-permission
android:name="android.permission.READ_SYNC_SETTINGS"/>
<uses-permission
android:name="android.permission.WRITE_SYNC_SETTINGS"/>
<uses-permission
android:name="android.permission.AUTHENTICATE_ACCOUNTS"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.CALL_PHONE" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
更新
经过反复试验,我发现 Picasso 显示了日志,但我没有在 logcat 中看到它。重启手机后,过了一会儿,我在logcat中看到了日志。日志再次消失,但这次即使重新启动也无济于事,日志没有重新出现。
但我也做了一些研究,发现了另一个 answer那指的是我的问题。
所以我更改了我的代码,但没有帮助。问题还是一样。 Picasso 仅显示占位符。
最佳答案
为什么不一次做所有事情?在 Firebase Storage getDownloadUrl() 方法中:
StorageReference load = getImage(id);
load.getDownloadUrl().addOnSuccessListener(new OnSuccessListener<Uri>() {
@Override
public void onSuccess(Uri uri) {
// Got the download URL for 'users/me/profile.png'
// Pass it to Picasso to download, show in ImageView and caching
Picasso.with(context).load(uri.toString()).into(imageView);
}
}).addOnFailureListener(new OnFailureListener() {
@Override
public void onFailure(@NonNull Exception exception) {
// Handle any errors
}
});
关于android - 使用 Picasso 从 Firebase Storage 加载图像到 Infowindow 中的 ImageView,Picasso 只显示占位符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39896511/