Загрузка изображения в FireStore и отображение - PullRequest
0 голосов
/ 13 июня 2019

У меня было действие, которое я преобразовал во фрагмент.

КОД:

    mImageBtn.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {

            Intent galleryIntent = new Intent();
            galleryIntent.setType("image/*");
            galleryIntent.setAction(Intent.ACTION_GET_CONTENT);

            startActivityForResult(Intent.createChooser(galleryIntent, "Select Image"), GALLERY_PICK);

        }
    });



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

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

        String imageUri = data.getDataString();

        CropImage.activity(Uri.parse(imageUri))
                .setAspectRatio(1, 1)
                .start(Objects.requireNonNull(getActivity()));

    }

    if (requestCode == CropImage.CROP_IMAGE_ACTIVITY_REQUEST_CODE) {
        CropImage.ActivityResult result = CropImage.getActivityResult(data);

            mProgressDialog = new ProgressDialog((getActivity()));
            mProgressDialog.setTitle("Uploading");
            mProgressDialog.setMessage("Pleas Stand By");
            mProgressDialog.setCanceledOnTouchOutside(false);
            mProgressDialog.show();

            Uri resultUri = result.getUri();

            final String current_user_id = mCurrentUser.getUid();

            final StorageReference filepath = mImageStorage.child("profile_images").child(current_user_id + (".jpeg"));
            filepath.putFile(resultUri).addOnSuccessListener(new OnSuccessListener<UploadTask.TaskSnapshot>() {
                @Override
                public void onSuccess(UploadTask.TaskSnapshot taskSnapshot) {

                    filepath.getDownloadUrl().addOnSuccessListener(new OnSuccessListener<Uri>() {
                        @Override
                        public void onSuccess(Uri uri) {

                            Map<String, String> newImageUrl = new HashMap<>();
                            newImageUrl.put("image", filepath.toString());

                            db.collection("Users").document(current_user_id)
                                    .set(newImageUrl, SetOptions.merge())
                                    .addOnSuccessListener(new OnSuccessListener<Void>() {
                                        @Override
                                        public void onSuccess(Void aVoid) {
                                            Log.d(TAG, "Image uploaded!");
                                            mProgressDialog.dismiss();
                                            //Toast.makeText(user_profile.this, "Succesful Upload", Toast.LENGTH_LONG).show();

                                            filepath.getDownloadUrl().addOnSuccessListener(new OnSuccessListener<Uri>() {
                                                @Override
                                                public void onSuccess(Uri uri) {

                                                    //The download url
                                                    final String downloadUrl =
                                                            uri.toString();
                                                    Log.d("tag", downloadUrl);
                                                    if (!downloadUrl.equals("default")) {
                                                        // I changed this to glide since i thought picasso was the problem.
                                                        // Picasso still should work. Glide is recommended by google tho
                                                        Glide.with(Objects.requireNonNull(getContext())).load(downloadUrl).into(mDisplayImage);
                                                    }

                                                }
                                            })
                                                    .addOnFailureListener(new OnFailureListener() {
                                                        @Override
                                                        public void onFailure(@NonNull Exception e) {
                                                            Log.w(TAG, "Error writing document", e);
                                                         //   Toast.makeText(getApplicationContext(), "There was some error in saving Changes.", Toast.LENGTH_LONG).show();
                                                        }
                                                    });

То, что этот код пытается сделать, это вызвать средство выбора изображений, позволяющее пользователю загружатьизображение в Firestore, а затем отобразить его в виде просмотра

приложение не аварийно завершает работу, но после этой строки не запускается код if (requestCode == CropImage.CROP_IMAGE_ACTIVITY_REQUEST_CODE)

Я играл в отладчике, пытаясь диагностироватьпроблема, которую я нашел result code = 1 и Request code = -1, когда я нажимаю на (requestCode == CropImage.CROP_IMAGE_ACTIVITY_REQUEST_CODE), значение IMAGE_ACTIVITY_REQUEST_CODE там равно 203, так как оно не соответствует условиям оператора if.Этот код отлично работал в действии, поэтому я очень запутался, почему он не работает сейчас

1 Ответ

0 голосов
/ 15 июня 2019

Решил проблему, заменив

.start(Objects.requireNonNull(getActivity()));

С

.start(getContext(), this);

Этот пост github объясняет это более подробно

...