Загрузка переменной Hashmap в базу данных Firebase - PullRequest
0 голосов
/ 30 мая 2018

Я создаю элемент в своей Hashmap, который содержит путь к фотографии для фотографии, загруженной из хранилища моего телефона в хранилище Firebase.Если я загрузил более одной фотографии, в моей Hashmap должен быть элемент (изображение 1, изображение 2, изображение 3, .....), который содержит пути к фотографиям в зависимости от количества загружаемых фотографий.

Каждый раз, когда я буду запускать программу, будут загружаться другие элементы Hashmap «Имя, электронная почта», но путь к фотографии («изображение» + i) не загружается.

Я хочу, чтобы конечный результат в базе данных выглядел следующим образом: конечный результат в базе данных Firebase

Есть ли какие-либо ошибки в моей работе?Есть что-нибудь, что делает эту работу?

Это мой код:

import android.content.Intent;
import android.net.Uri;
import android.support.annotation.NonNull;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;

import com.google.android.gms.tasks.OnFailureListener;
import com.google.android.gms.tasks.OnSuccessListener;
import com.google.firebase.database.DatabaseReference;
import com.google.firebase.database.FirebaseDatabase;
import com.google.firebase.storage.FirebaseStorage;
import com.google.firebase.storage.StorageReference;
import com.google.firebase.storage.UploadTask;

import java.util.ArrayList;
import java.util.HashMap;

public class MainActivity extends AppCompatActivity {
    private Button mSelectimage;
    private StorageReference mStorage;
    private DatabaseReference mDatabase;
    private Uri image;
    private String photoPath;
    final static int GALLERY_INTENT = 2;
    int i;
    int j;
    int totalItelmsSelected;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        mSelectimage = (Button) findViewById(R.id.button2);
        mStorage = FirebaseStorage.getInstance().getReference();
        mDatabase = FirebaseDatabase.getInstance().getReference();

        mSelectimage.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent intent = new Intent(Intent.ACTION_PICK);
                intent.setType("image/*");
                intent.putExtra(Intent.EXTRA_ALLOW_MULTIPLE, true);
                startActivityForResult(intent, GALLERY_INTENT);
            }
        });

    }

    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);

        final HashMap <Object,Object> datamap = new HashMap<Object, Object>();

        if(requestCode == GALLERY_INTENT && resultCode == RESULT_OK){

            if(data.getClipData() != null){

                totalItelmsSelected = data.getClipData().getItemCount();

                for(i=0; i < totalItelmsSelected; i++){

                    image = data.getClipData().getItemAt(i).getUri();
                    final StorageReference filepath = mStorage.child("photos").child(image.getLastPathSegment()+".jpg");
                    filepath.putFile(image).addOnSuccessListener(new OnSuccessListener<UploadTask.TaskSnapshot>() {
                        @Override
                        public void onSuccess(UploadTask.TaskSnapshot taskSnapshot) {

                            photoPath = filepath.getPath();
                            datamap.put("image "+i , photoPath);
                            Toast.makeText(MainActivity.this, i+" Photos has been uploaded.", Toast.LENGTH_SHORT).show();

                        }
                    }).addOnFailureListener(new OnFailureListener() {
                        @Override
                        public void onFailure(@NonNull Exception e) {
                            Toast.makeText(MainActivity.this, "Problem in Uploading "+i+" Photos.", Toast.LENGTH_SHORT).show();
                        }
                    });
                }

                datamap.put("Name", "Kamil");
                datamap.put("Email", "Kamil@gmail.com");

               mDatabase.child("users").push().setValue(datamap).addOnSuccessListener(new OnSuccessListener<Void>() {
                    @Override
                    public void onSuccess(Void aVoid) {
                        Toast.makeText(MainActivity.this, "Uploading to the database is done", Toast.LENGTH_SHORT).show();
                    }
                }).addOnFailureListener(new OnFailureListener() {
                    @Override
                    public void onFailure(@NonNull Exception e) {
                        Toast.makeText(MainActivity.this, "Problem in registuring the information", Toast.LENGTH_SHORT).show();
                    }
                });
            }
        }
    }
}

Это мой код gradle:

apply plugin: 'com.android.application'

android {
    compileSdkVersion 27
    defaultConfig {
        applicationId "com.example.mohammed.storemultipleimages"
        minSdkVersion 26
        targetSdkVersion 27
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    //noinspection GradleCompatible
    implementation 'com.android.support:appcompat-v7:27.1.1'
    implementation 'com.android.support.constraint:constraint-layout:1.1.0'
    implementation 'com.google.firebase:firebase-database:11.8.0'
    implementation 'com.google.firebase:firebase-storage:11.8.0'
    implementation 'com.google.firebase:firebase-auth:11.8.0'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.2'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
}

apply plugin: 'com.google.gms.google-services'

Ответы [ 3 ]

0 голосов
/ 30 мая 2018
public class MainActivity extends AppCompatActivity {
private Button mSelectimage;
private StorageReference mStorage;
private DatabaseReference mDatabase;
private Uri image;
private String photoPath;
final static int GALLERY_INTENT = 2;
int i;
int j;
int totalItelmsSelected;
String push_id;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    mSelectimage = (Button) findViewById(R.id.button2);
    mStorage = FirebaseStorage.getInstance().getReference();
    mDatabase = FirebaseDatabase.getInstance().getReference();

    push_id = mDatabase.child("users").push().getKey();

    mSelectimage.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            Intent intent = new Intent(Intent.ACTION_PICK);
            intent.setType("image/*");
            intent.putExtra(Intent.EXTRA_ALLOW_MULTIPLE, true);
            startActivityForResult(intent, GALLERY_INTENT);
        }
    });

}

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);

    final HashMap <Object,Object> datamap = new HashMap<Object, Object>();

    if(requestCode == GALLERY_INTENT && resultCode == RESULT_OK){

        if(data.getClipData() != null){

            totalItelmsSelected = data.getClipData().getItemCount();

            for(i=0; i < totalItelmsSelected; i++){

                image = data.getClipData().getItemAt(i).getUri();
                final StorageReference filepath = mStorage.child("photos").child(image.getLastPathSegment()+".jpg");
                filepath.putFile(image).addOnSuccessListener(new OnSuccessListener<UploadTask.TaskSnapshot>() {
                    @Override
                    public void onSuccess(UploadTask.TaskSnapshot taskSnapshot) {

                        photoPath = filepath.getPath();
                        datamap.put("image "+i , photoPath);
                        Toast.makeText(MainActivity.this, i+" Photos has been uploaded.", Toast.LENGTH_SHORT).show();
                        datamap.put("Name", "Kamil");
                        datamap.put("Email", "Kamil@gmail.com");

                        mDatabase.child("users").child(push_id).setValue(datamap).addOnSuccessListener(new OnSuccessListener<Void>() {
                        @Override
                        public void onSuccess(Void aVoid) {
                        Toast.makeText(MainActivity.this, "Uploading to the database is done", Toast.LENGTH_SHORT).show();
                        }
                        }).addOnFailureListener(new OnFailureListener() {
                        @Override
                        public void onFailure(@NonNull Exception e) {
                          Toast.makeText(MainActivity.this, "Problem in registuring the information", Toast.LENGTH_SHORT).show();
                        }
                        });

                    }
                }).addOnFailureListener(new OnFailureListener() {
                    @Override
                    public void onFailure(@NonNull Exception e) {
                        Toast.makeText(MainActivity.this, "Problem in Uploading "+i+" Photos.", Toast.LENGTH_SHORT).show();
                    }
                });
            }


        }
    }
}

}

0 голосов
/ 30 мая 2018

Проблема в том, что когда вы помещаете образ в хранилище, этот процесс происходит асинхронно.Поэтому, прежде чем поместить изображение в хранилище и добавить URI в hashmap, вызывается метод в базе данных firebase:

Поэтому вы должны убедиться, что перед вызовом метода в firebase вы завершили процесс hashmap:

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);

    final HashMap <Object,Object> datamap = new HashMap<Object, Object>();

    if(requestCode == GALLERY_INTENT && resultCode == RESULT_OK){

        if(data.getClipData() != null){

            totalItelmsSelected = data.getClipData().getItemCount();

            for(i=0; i < totalItelmsSelected; i++){

                image = data.getClipData().getItemAt(i).getUri();
                final StorageReference filepath = mStorage.child("photos").child(image.getLastPathSegment()+".jpg");
                filepath.putFile(image).addOnSuccessListener(new OnSuccessListener<UploadTask.TaskSnapshot>() {
                    @Override
                    public void onSuccess(UploadTask.TaskSnapshot taskSnapshot) {

                        photoPath = filepath.getPath();
                        datamap.put("image "+i , photoPath);
                        datamap.put("Name", "Kamil");
                        datamap.put("Email", "Kamil@gmail.com");

                      mDatabase.child("users").push().setValue(datamap).addOnSuccessListener(new OnSuccessListener<Void>() {
                           @Override
                           public void onSuccess(Void aVoid) {
                               Toast.makeText(MainActivity.this, "Uploading to the database is done", Toast.LENGTH_SHORT).show();
                           }
                       }).addOnFailureListener(new OnFailureListener() {
                           @Override
                           public void onFailure(@NonNull Exception e) {
                               Toast.makeText(MainActivity.this, "Problem in registuring the information", Toast.LENGTH_SHORT).show();
                           }
                       });
                        Toast.makeText(MainActivity.this, i+" Photos has been uploaded.", Toast.LENGTH_SHORT).show();

                    }
                }).addOnFailureListener(new OnFailureListener() {
                    @Override
                    public void onFailure(@NonNull Exception e) {
                        Toast.makeText(MainActivity.this, "Problem in Uploading "+i+" Photos.", Toast.LENGTH_SHORT).show();
                    }
                });
            }
        }
    }
}
0 голосов
/ 30 мая 2018

Попробуйте использовать последнюю версию google-сервисов, например (Уровень проекта):

classpath 'com.google.gms:google-services:4.0.1'

И замените существующий код следующим:

apply plugin: 'com.android.application'

android {
    compileSdkVersion 27
    defaultConfig {
        applicationId "com.example.mohammed.storemultipleimages"
        minSdkVersion 26
        targetSdkVersion 27
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    //noinspection GradleCompatible
    implementation 'com.android.support:appcompat-v7:27.1.1'
    implementation 'com.android.support.constraint:constraint-layout:1.1.0'
    implementation 'com.google.firebase:firebase-database:16.0.1'
    implementation 'com.google.firebase:firebase-storage:16.0.1'
    implementation 'com.google.firebase:firebase-auth:16.0.1'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.2'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
}

apply plugin: 'com.google.gms.google-services'
...