加载位于Firebase存储中的映像

时间:2019-04-23 16:35:05

标签: java android firebase firebase-storage android-glide

当我尝试加载Firebase存储中的图像时遇到问题。在我的Firebase项目中,我将名为“ profile.png”的图像存储在名为“ imgProjects”的文件夹中。

在StackOverflow中进行搜索时,我找到了一些答案,这些答案指示要使用Glide将图像加载到“ ImageView”元素中,但无法正常工作...

我在活动中尝试:

FirebaseStorage storage2 = FirebaseStorage.getInstance("gs://myURLfirebaseProjecy/profile.png"); //I get this URL through firebase console

Glide.with(this)
    .load(storage2)
    .into(imgPerfil);

StorageReference storageRef = storage.getReference();
StorageReference imagesRef = storageRef.child("imgProjects\profile.png");
Glide.with(this)
        .load(imagesRef)
        .into(imgPerfil);

我在Java文件类中定义了“ MyAppGlideModule”

@GlideModule
public class MyAppGlideModule extends AppGlideModule {

    @Override
    public void registerComponents(Context context, Glide glide, Registry registry) {
        // Register FirebaseImageLoader to handle StorageReference
        registry.append(StorageReference.class, InputStream.class,
                new FirebaseImageLoader.Factory());
    }
}

然后设置依赖项:

implementation 'com.firebaseui:firebase-ui-storage:3.3.0'
implementation 'com.google.firebase:firebase-storage:16.0.5'

当我加载活动时,ImageView是空的...我需要使用“ gs://”引用或相对路径。

抱歉,...我该怎么办才能解决我的问题?

1 个答案:

答案 0 :(得分:0)

如果您知道图像的名称是这样的,您可以获取图像:-

StorageReference mImageStorage = FirebaseStorage.getInstance().getReference();
        StorageReference ref = mImageStorage.child("storage name")
                .child("your image name.jpg");

        ref.getDownloadUrl().addOnCompleteListener(new OnCompleteListener<Uri>() {
            @Override
            public void onComplete(@NonNull Task<Uri> task) {
                if (task.isSuccessful()) {
                    Uri downUri = task.getResult();
                    String imageUrl = downUri.toString();
                    Toast.makeText(MainActivity.this, imageUrl , Toast.LENGTH_SHORT).show();
                }else{
                    Toast.makeText(MainActivity.this, ""+task.getException(), Toast.LENGTH_SHORT).show(); 
                }
            }
        });