#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
)