не отображаются запросы в друзья во фрагменте запросов друзей kotlin-firebase

#android #firebase #kotlin #firebase-realtime-database

#Android #firebase #kotlin #firebase-база данных в реальном времени

Вопрос:

введите описание изображения здесь Проблема в том, что я хочу отображать все запросы друзей во фрагменте с именем FriendsFragment.Этот фрагмент вызывает класс адаптера, содержащий внутренний класс с именем ViewHolder . Но запросы в друзья не отображаются. И в logcat всегда отображается сообщение «Адаптер не подключен; пропущенный макет».В чем проблема?

вот код моего фрагмента под названием FriendsFragment:

 class FriendsFragment : Fragment() {
    private  var recyclerView1: RecyclerView?=null
    private  var recyclerView2: RecyclerView?=null
    private  var mUsers:MutableList<Users>?=null
    private var friendAdapter:FriendAdapter?=null
    private lateinit var mAuth: FirebaseAuth
    private var currentState:String?=""
    private var firebaseUserId:String=""

    override fun onCreateView(
        inflater: LayoutInflater, container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View? {
        // Inflate the layout for this fragment
        val view= inflater.inflate(R.layout.fragment_friends, container, false)

        recyclerView1=view.findViewById(R.id.recycler_requests)
        recyclerView1?.setHasFixedSize(true)
        recyclerView1?.layoutManager=LinearLayoutManager(context)

        recyclerView2=view.findViewById(R.id.recycler_Friends)
        recyclerView2?.setHasFixedSize(true)
        recyclerView2?.layoutManager=LinearLayoutManager(context)
        mUsers=ArrayList()
        mAuth=FirebaseAuth.getInstance()
        firebaseUserId=mAuth.currentUser!!.uid
        val usersRef=FirebaseDatabase.getInstance("https://online-chat-541f3-default-rtdb.firebaseio.com").reference.child("Users")
        val requestRef =
            FirebaseDatabase.getInstance("https://online-chat-541f3-default-rtdb.firebaseio.com").reference.child(
                "Friends Requests"
            )

        usersRef.addValueEventListener(object:ValueEventListener{
            override fun onDataChange(p0: DataSnapshot) {
                mUsers?.clear()
                    for (snapshot in p0.children) {
                        val users: Users? = snapshot.getValue(Users::class.java)
                        if (!(users!!.getUid()).equals(firebaseUserId) amp;amp; users != null) {
                            if(p0.child(firebaseUserId).child(users.getUid().toString()).child("request_type").value=="received" amp;amp;
                                p0.child(users.getUid().toString()).child(firebaseUserId).child("request_type").value=="sent"
                                    ) {

                                mUsers?.add(users)
                                friendAdapter =
                                    context?.let {
                                        FriendAdapter(
                                            it,
                                            mUsers as ArrayList<Users>,
                                            false
                                        )
                                    }
                                friendAdapter?.notifyDataSetChanged()
                                recyclerView1!!.adapter = friendAdapter
                            }
                        }
                    }
            }

            override fun onCancelled(p0: DatabaseError) {
            }
        })

        return view
    }
}
 

Представление recycler для отображения запросов на добавление в друзья — recyclerView1.
Также это XML-код макета, прикрепленный к держателю представления:

 <?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    >

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        >

        <de.hdodenhof.circleimageview.CircleImageView
            android:id="@ id/friendsProfileResource"
            android:layout_width="60dp"
            android:layout_height="60dp"
            android:src="@drawable/username"
            >
        </de.hdodenhof.circleimageview.CircleImageView>

        <TextView
            android:id="@ id/usernameFriendsResource"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_toRightOf="@ id/friendsProfileResource"
            android:layout_marginTop="10dp"
            android:layout_marginStart="30dp"
            android:text="Username"
            android:textSize="18sp"
            android:textStyle="bold"
            android:textColor="@color/colorPrimaryDark"
            >
        </TextView>
        <ImageView
            android:id="@ id/online_status_img"
            android:layout_width="15dp"
            android:layout_height="15dp"
            android:src="@drawable/online"
            android:layout_below="@id/usernameFriendsResource"
            android:layout_marginLeft="40dp"
            android:layout_marginTop="10dp"
            android:visibility="invisible"
            >
        </ImageView>

        <TextView
            android:id="@ id/last_message_friends_ressource"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_below="@id/usernameFriendsResource"
            android:layout_toRightOf="@id/friendsProfileResource"
            android:layout_marginTop="5dp"
            android:layout_marginStart="30dp"
            android:text="last message"
            android:textSize="18sp"
            android:maxLines="1"
            android:textColor="@color/colorPrimary"
            >
        </TextView>

        <Button
            android:id="@ id/accept_friend_button"
            android:layout_width="90dp"
            android:layout_height="wrap_content"
            android:layout_toRightOf="@id/usernameFriendsResource"
            android:layout_marginStart="40dp"
            android:text="Accept"
            android:textSize="18sp"
            android:textStyle="bold"
            android:textColor="@color/colorPrimaryDark"
            android:background="@drawable/buttons2"
            android:textAllCaps="false"    
            >

        </Button>
        <Button
            android:id="@ id/cancel_friend_button"
            android:layout_width="90dp"
            android:layout_height="wrap_content"
            android:layout_toRightOf="@ id/accept_friend_button"
            android:layout_marginStart="10dp"
            android:text="Cancel"
            android:textSize="18sp"
            android:textStyle="bold"
            android:textColor="@color/colorPrimaryDark"
            android:background="@drawable/buttons2"
            android:textAllCaps="false"
            android:layout_marginEnd="10dp"
            >

        </Button>

    </RelativeLayout>

</LinearLayout>
 

Также это код класса friendsAdapter:

 package com.example.online_chat.Adapters

import android.content.Context
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import android.widget.Button
import android.widget.TextView
import androidx.recyclerview.widget.RecyclerView
import com.example.online_chat.Models.Users
import com.example.online_chat.R
import com.google.firebase.auth.FirebaseAuth
import com.google.firebase.database.DataSnapshot
import com.google.firebase.database.DatabaseError
import com.google.firebase.database.FirebaseDatabase
import com.google.firebase.database.ValueEventListener
import com.squareup.picasso.Picasso
import de.hdodenhof.circleimageview.CircleImageView

class FriendAdapter(private var mContext: Context,private var mUsers: List<Users>,private var isChatChecked:Boolean):RecyclerView.Adapter<FriendAdapter.ViewHolder?>() {

    private var currentState:String?=""
    private lateinit var mAuth:FirebaseAuth
    private var firebaseUserId:String=""

    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
        val view=LayoutInflater.from(mContext).inflate(R.layout.user_friends,parent,false)
        return ViewHolder(view)
    }

    override fun onBindViewHolder(holder: ViewHolder, position: Int) {
        val users=mUsers[position]
        holder.usernameFriend!!.text=users.getUsername()
        holder.fullNameFriend!!.text=users.getFullName()
        Picasso.get().load(users.getProfile()).into(holder.profileImageFriend)
        mAuth= FirebaseAuth.getInstance()
        firebaseUserId=mAuth.currentUser!!.uid

       
    }

    override fun getItemCount(): Int {
        return mUsers.size
    }

    class ViewHolder(itemView: View):RecyclerView.ViewHolder(itemView){

        var usernameFriend:TextView?=itemView.findViewById(R.id.usernameFriendsResource)
        var fullNameFriend:TextView?=itemView.findViewById(R.id.last_message_friends_ressource)
        var profileImageFriend:CircleImageView?=itemView.findViewById(R.id.friendsProfileResource)
        var acceptBtn: Button?=itemView.findViewById(R.id.accept_friend_button)
        var cancelBtn:Button?=itemView.findViewById(R.id.cancel_friend_button)

    }
}
 

Спасибо!

Комментарии:

1. Прежде всего, ваш код немного сложен для чтения, я уверен, что вы можете это улучшить. Я думаю, что вы не получаете запросы friends_requests из firebase, а просто пользователей. Поэтому ключ request_type отсутствует в ваших выбранных данных

2. Как я могу это сделать, чтобы получать для каждого пользователя запросы друзей я застрял в этой проблеме 2 дня, я благодарен, если вы могли бы мне помочь

3. я думаю, вам следует добавить больше информации в свою коллекцию запросов друзей, например, имя пользователя и все, что вы хотите показать в представлении recycler. Затем вы можете отфильтровать эту коллекцию для текущего пользователя и показать данные запроса друзей в списке. Скажите, нужен ли вам какой-нибудь код

4. Я добавляю его в прикрепленный XML-код макета в приведенном выше коде и прикрепляю его к классу адаптера, но основная проблема заключается во фрагменте друзей, когда я хочу получить все запросы друзей один за другим. может кто-нибудь проверить код фрагмента моих друзей, пожалуйста? спасибо!

5. я отредактировал его и добавил код адаптера FRIENDS, который вы можете проверить @javierCuervas

Ответ №1:

Вы уверены, что это условие работает?

если (p0.дочерний элемент (firebaseUserId).дочерний элемент(users.getUid().toString()).дочерний элемент («request_type»).значение== «получено») amp;amp; p0.дочерний элемент(users.getUid().toString()).дочерний элемент(firebaseUserId).дочерний элемент («request_type»).значение == «отправлено»)

Вы запросили сбор пользователей, но не запросили сбор друзей. Я думаю, что ваш список запросов друзей просто пуст, и ваш адаптер никогда не создается

Я думаю, это было бы что-то вроде этого, пожалуйста, обратите внимание, что есть некоторый псевдокод, поскольку вы используете kotlin, вы должны использовать сопрограммы для организации этой логики для лучшего понимания.

 FriendAdapter(it,mUsers as ArrayList<Users>,false)

 usersRef.addValueEventListener( DataSnapshot ->
    mUsers?.clear()
    for (snapshot in p0.children) {
      val user: Users? = snapshot.getValue(Users::class.java)
      // check that reference 
      val requestRef = FirebaseDatabase.getInstance("https://online-chat-541f3-default-rtdb.firebaseio.com").reference.child("Friends Requests/"   user.getId()) 
      // this is pseudo code
      requestRef.addValueEventListener( friendsdataSnapshot -> 
      for (friend if friendsDataSnapshot) {
          //addFriend to mUsersList 
       }
       friendAdapter = context?.let {
           FriendAdapter(it, mUsers as ArrayList<Users>, false)
       }
       friendAdapter?.notifyDataSetChanged()
       recyclerView1!!.adapter = friendAdapter
  )