Невозможно получить изображение для отображения в программе повторного просмотра из вложенной базы данных в реальном времени - PullRequest
0 голосов
/ 08 ноября 2018

Вот моя таблица базы данных в реальном времени. У меня есть изображение, хранящееся в хранилище Firebase. Я планирую использовать несколько символов в этой таблице под столбцом символов.

База данных в реальном времени

Я не понимаю, почему я не могу получить photo_id из базы данных в реальном времени. Ссылка (photo_id): "https://firebasestorage.googleapis.com/v0/b/occreations-b6c14.appspot.com/o?name=characterimage%2FWk80hB04oZRMQxK9Ig0DDgoL5n52%20be58f895-8fda-4dd1-9e15-32e4186eae8a&uploadType=resumable&upload_id=AEnB2UrkBecZTlE4kpNypl-1ACjekw1CIM3UsUxXgRGXHLB4DCmyLDI-i70OxqjwKchf7sf3YURhgCFq3KxV7JUPDy55GyZWSg&upload_protocol=resumable" Когда я нажимаю на эту ссылку, появляется сообщение "Недопустимый запрос. Отсутствует заголовок X-Goog-Upload-Command."

Но когда я тестировал свой код, используя ссылку из URL-адреса в массив, это работает. Но почему я не могу получить изображение из своей базы данных?

Кажется, я не могу найти проблему. Я думал, что это может быть arraylist, url photo_id или способ загрузки в базу данных firebase для хранения / в реальном времени, может быть, потому что я не смог получить имя файла в формате .png или .jpeg и сохранить его как photo_id?

ОБНОВЛЕНИЕ: Я изменяю URL-ссылку для загрузки URL-адреса из Firebase Storage, но я не могу получить ссылку из DatabaseReference, из-за чего ничего не добавлялось в Список

Я следовал этому уроку. Урок Coding-In-Flow

UPDATE2: У меня проблемы с вложенными данными. Я хотел получить ТОЛЬКО значение photo_id (которое является URL) из базы данных реального времени, но я получаю его как нулевое значение. Изображение заполнителя становится пустым после того, как я изменил представление переработчика. Как я должен извлекать свои данные только из дочернего элемента персонажа в character_id (который уже безвозвратен), если нет способа сделать это. Я искал другие ответы на stackoverflow, но ни один из них не соответствует тому, что я ищу.

Мой бревенчатый кот говорит

W/ClassMapper: No setter/field for -LQq7dIvsJX7GgNfXeIf found on class com.example.linda.originalcharacterapp.model.CharacterInformation
           No setter/field for -LQq7SB5qvcNXdJEzwBh found on class 
           com.example.linda.originalcharacterapp.model.CharacterInformation
           D/TAG: null / null
           W/ClassMapper: No setter/field for username found on class 
           com.example.linda.originalcharacterapp.model.CharacterInformation
           No setter/field for email found on class 
           com.example.linda.originalcharacterapp.model.CharacterInformation
           No setter/field for password found on class 
           com.example.linda.originalcharacterapp.model.CharacterInformation
           D/TAG: null / null

Обновлен скриншот Android

Скриншот Android

Текущее изображение в Firebase Storage

HomeFragment.class

    mRecyclerView.setHasFixedSize(true);
    mLayoutManager = new LinearLayoutManager (this.getActivity());
    mRecyclerView.setLayoutManager(new GridLayoutManager (this.getActivity(),2));
    userOCs = new ArrayList<> ();

    //DatabaseReference characterReference = FirebaseDatabase.getInstance().getReference();

     reference.child(userid).orderByChild("characters").getRef().addValueEventListener (new ValueEventListener() {
        @Override
        public void onDataChange(DataSnapshot dataSnapshot) {
            //Display images of ocs
            for(DataSnapshot characterSnapshot : dataSnapshot.getChildren()){
                if (dataSnapshot.exists()) {
                    String photoid = dataSnapshot.child ("photo_id").getValue (String.class);
                    String cName = dataSnapshot.child ("characterName").getValue (String.class);
                    CharacterInformation oc = characterSnapshot.getValue (CharacterInformation.class);
                    Log.d ("TAG", photoid + " / " + cName);
                    userOCs.add (oc);
                    Toast.makeText (getActivity (), "Adding images " + oc.getCharacterName (), Toast.LENGTH_SHORT).show ();
                }
           }
           String file = "https://firebasestorage.googleapis.com/v0/b/occreations-b6c14.appspot.com/o/characterimage%2FWk80hB04oZRMQxK9Ig0DDgoL5n52%2F3aa5daa6-86b7-41e5-b6aa-2dae58a991ef.png?alt=media&token=5a4e9c2a-e1f8-4d05-904a-a1d934524a09";
           userOCs.add(new CharacterInformation("12", "23",file, " Linda", "12", "Time ANGEL", "Quirk","Justin", "Flight", "lIVES IN MAIN"));

            mAdapter = new RecycleViewAdapter (userOCs, getActivity()); //where the image is inserted
            mRecyclerView.setAdapter(mAdapter);
        }

CreateCharacter.class

  private void uploadOC() {
    //String values
    nameValue = cName.getText ().toString ().trim ();
    ageValue = cAge.getText ().toString ().trim ();
    speciesValue = cSpecies.getText ().toString ().trim();
    personalityValue = cPersonality.getText ().toString ().trim();
    familyValue = cFamily.getText ().toString ().trim();
    powerValue = cPowers.getText ().toString ().trim();
    bioValue = cBiography.getText ().toString ().trim();
    currentUserID = firebaseAuth.getCurrentUser().getUid();


    if (!TextUtils.isEmpty (nameValue) && selectedImage != null) {
      //  StorageReference fileReference = storageReference.child(System.currentTimeMillis()+ "." + getFileExtension(downloadImage));

        storageReference = storageReference.child("characterimage").child (currentUserID + "/" + UUID.randomUUID ().toString ());

            storageReference.putFile (selectedImage)

                     .addOnSuccessListener (new OnSuccessListener<UploadTask.TaskSnapshot> () {
                        @Override
                        public void onSuccess(UploadTask.TaskSnapshot taskSnapshot) {
                           downloadImage = taskSnapshot.getUploadSessionUri ();
                            String characterId = databaseReference.child("characters").push ().getKey(); //creates unique random id
                      //      String photoName = taskSnapshot.getMetadata().getReference().getDownloadUrl().toString();
                            CharacterInformation newCharacter =  new CharacterInformation (currentUserID, characterId, downloadImage.toString(),nameValue, ageValue, speciesValue,
                                    personalityValue, familyValue, powerValue, bioValue);

                            Map<String, Object> postValue = newCharacter.toMap();
                            Map<String, Object> childUpdates = new HashMap<> ();
                            databaseReference.child("User Account").child(currentUserID).child("character").child(characterId).setValue(newCharacter);

                            childUpdates.put(nameValue, newCharacter);
                            databaseReference.updateChildren (childUpdates);
                            Toast.makeText (getActivity (), "Uploaded", Toast.LENGTH_SHORT).show ();

                        }
                    })
                    .addOnFailureListener (new OnFailureListener () {
                        @Override
                        public void onFailure(@NonNull Exception e) {
                            Toast.makeText (getActivity (), "Failed " + e.getMessage (), Toast.LENGTH_SHORT).show ();
                        }
                    })
                    .addOnProgressListener (new OnProgressListener<UploadTask.TaskSnapshot> () {
                        @Override
                        public void onProgress(UploadTask.TaskSnapshot taskSnapshot) {
                            double progress = (100.0 * taskSnapshot.getBytesTransferred () / taskSnapshot
                                    .getTotalByteCount ());
                        }
                    });

    }
    else {
        Toast.makeText (getActivity (), "Character needs name", Toast.LENGTH_SHORT).show ();
    }
}

RecyclerViewAdapter.class

public class RecycleViewAdapter extends RecyclerView.Adapter<RecycleViewAdapter.ViewHolder> {
    private List<CharacterInformation> mDataset;
    private Context context;

    public static class ViewHolder extends RecyclerView.ViewHolder {
        private ImageView image;
        private Context context;

        private ViewHolder(View view) {
            super(view);
           image = (ImageView) view.findViewById(R.id.recycleImage);
        }

    }

    public RecycleViewAdapter(List<CharacterInformation> myDataset, Context context) {
        mDataset = myDataset;
        this.context = context;
    }

    @Override
    public RecycleViewAdapter.ViewHolder onCreateViewHolder(ViewGroup parent,
                                                     int viewType) {
        View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.recyclerview_row, parent, false);
        ViewHolder vh = new ViewHolder(view);
        return vh;
    }

    @Override
    public void onBindViewHolder(ViewHolder holder, int position) {
        holder.image.setScaleType (ImageView.ScaleType.CENTER_CROP);
        CharacterInformation oc = mDataset.get(position);
        Picasso.get().load(oc.getPhoto_id ())
                .into(holder.image);
        System.out.println("Binding images...");
        Toast.makeText (context,"Binding images" + oc.getCharacterName(), Toast.LENGTH_SHORT).show();
       holder.image.setOnClickListener (new View.OnClickListener () {

            @Override
            public void onClick(View v) {
                AppCompatActivity activity = (AppCompatActivity) v.getContext();
                DisplayCharacter ocFragment = new DisplayCharacter ();
                activity.getSupportFragmentManager().beginTransaction().replace(R.id.fragment_container, ocFragment).addToBackStack(null).commit();
            }
        });
    }

    @Override
    public int getItemCount() {
        return mDataset.size();
    }

}

1 Ответ

0 голосов
/ 14 ноября 2018

И я уже нашел свой ответ на этот вопрос Вот как я решаю свою проблему, но это больше похоже на то, что у меня возникла проблема с отсутствующим полем установки и проблемы с вызовом из базы данных.

W / ClassMapper: нет установки / поля для класса

Мне пришлось вспомнить ссылку на базу данных, чтобы получить мои вложенные данные.

public void retrieveUserOCs() {
        System.out.println("Revoke the character reference ");
        reference = FirebaseDatabase.getInstance().getReference("User Account");
        DatabaseReference characterReference = reference.child(user.getUid()).child("character");
        // final Query query = characterReference;
        reference.child(user.getUid()).child("character").addValueEventListener(new ValueEventListener() {
            @Override
            public void onDataChange(DataSnapshot dataSnapshot) {
                ////Loop 1 to go through all the child nodes of characters
                for(DataSnapshot characterSnapshot : dataSnapshot.getChildren()){
                        if (dataSnapshot.getValue() != null ) {
                            CharacterInformation oc = characterSnapshot.getValue (CharacterInformation.class);
                            String ocKey = characterSnapshot.getKey ();
                            System.out.println ("Adding ocs: " + ocKey + " Name: " + oc.getCharacterName ());
                            Log.d ("TAGGING OCS", ocKey + " / " + oc.getCharacterName ());
                            userOCs.add (oc);
                            Toast.makeText (getContext(), "Adding images " + oc.getCharacterName (), Toast.LENGTH_SHORT).show ();
                        } else { //if user haven't added any characters
                            break;
                        }
                }
                String file2 ="http://ghostfinder101.weebly.com/uploads/1/9/7/3/19737887/published/gear-of-diamond_1.png?1541826567";
                userOCs.add(new CharacterInformation("34", "124",file2, "Diamond", "2002", "Diamond Angel", "Narcissistic","Jahara(friend)", "Flight, shard attacks", "lIVES IN MAIN"));
                mAdapter = new RecycleViewAdapter (userOCs, getActivity()); //where the image is inserted
                mRecyclerView.setAdapter(mAdapter);
            }

            @Override
            public void onCancelled(DatabaseError databaseError) {
                System.out.println("Database error");
            }

        });
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...