ループ用のデータベースからデータを取得するから私を妨げますか?

JMB:

ユーザーので画面を埋めるためにFirebaseからデータを取得しようとするとmyIDuserIDと、imageURLそれは、ユーザごとにユニークです。私は、以下の方法持っているreadMessage();データベースからその情報を取得するものですが、それが正常に動作していません。

これは何であるLogcatは私に語りましたCan't convert object of type java.lang.String to type com.e.chatapp.Model.Chat

最初のIで取り除くことを試みたfor Loopので、それは罰金を働かせた過去に、今回はそれが役立っていません。誰かが、エラーが私のコードであるかを示すことはできますか?

問題があるifのステートメント。

あなたは私の持っている下記のMessageActivity.javaとモデルクラスをChat.java

ここでは、画像の説明を入力します。

MessageActivity.java

private void sendMessage(String sender, String receiver, String message) {

    DatabaseReference reference = FirebaseDatabase.getInstance().getReference();

    HashMap<String, Object> hashMap = new HashMap<>();
    hashMap.put("sender", sender);
    hashMap.put("receiver", receiver);
    hashMap.put("message", message);

    reference.child("Chats").child(mFirebaseUser.getUid()).setValue(hashMap);
}

private void readMessage(final String myID, final String userID, final String imageURL) {
    mChats = new ArrayList<>();

    mReference = FirebaseDatabase.getInstance().getReference("Chats");
    mReference.addValueEventListener(new ValueEventListener() {
        @Override
        public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
            mChats.clear();
            for (DataSnapshot snapshot : dataSnapshot.getChildren()) {
                Chat chat = snapshot.getValue(Chat.class);
                if (chat.getReceiver().equals(myID) && chat.getSender().equals(userID) ||
                        chat.getReceiver().equals(userID) && chat.getSender().equals(myID)) {
                    mChats.add(chat);
                }

                mMessageAdapter = new MessageAdapter(MessageActivity.this, mChats, imageURL);
                mRecyclerView.setAdapter(mMessageAdapter);
            }
        }

        @Override
        public void onCancelled(@NonNull DatabaseError databaseError) {

        }
    });
}

また、このようにそれを試してみました

 private void readMessage(final String myID, final String userID, final String imageURL) {
        mChats = new ArrayList<>();

        mReference = FirebaseDatabase.getInstance().getReference("Chats");
        mReference.addValueEventListener(new ValueEventListener() {
            @Override
            public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
                mChats.clear();
                for (DataSnapshot snapshot : dataSnapshot.getChildren()) {
                    Chat chat = snapshot.getValue(Chat.class);
                    if (chat.getReceiver().equals(myID) && chat.getSender().equals(userID) ||
                            chat.getReceiver().equals(userID) && chat.getSender().equals(myID)) {
                        mChats.add(chat);
                    }

                    mMessageAdapter = new MessageAdapter(MessageActivity.this, mChats, imageURL);
                    mRecyclerView.setAdapter(mMessageAdapter);
                }
            }

            @Override
            public void onCancelled(@NonNull DatabaseError databaseError) {

            }
        });
    }

Chat.java

public class Chat {

private String sender;
private String receiver;
private String message;

public Chat(String sender, String receiver, String message) {
    this.sender = sender;
    this.receiver = receiver;
    this.message = message;
}

public Chat() {
}

public String getSender() {
    return sender;
}

public void setSender(String sender) {
    this.sender = sender;
}

public String getReceiver() {
    return receiver;
}

public void setReceiver(String receiver) {
    this.receiver = receiver;
}

public String getMessage() {
    return message;
}

public void setMessage(String message) {
    this.message = message;
}

}

ピーター・ハダッド:

問題は、データベース内の属性がフィールドで一致していないということであるChat Pojoクラスを。

データベース内の属性が同じすべて小文字である必要がありPojoますが、データベースにクラスをマッピングすることができるように。

また、あなたのデータベースは次のようにする必要があります:

 Chats
     randomId
         message : "hi"
         reciever: "peter"
         sender  : "jmb"

この方法では、randomidオブジェクトは、あなたの中にある3つの属性があることを対象と内側として機能するChatsもクラスを。

おすすめ

転載: http://43.154.161.224:23101/article/api/json?id=318856&siteId=1