Кажется, что управление выполнением не входит в onCreateViewHolder; данные не отображаются на экране.
Похоже, вызывается onStart и onBindViewHolder, но не onCreateViewHolder.
Я много чего пробовал, пытался найти решение 2 дня. Я имею:
1. Удаление setHasFixdSize (true), не работает
Добавление setHasFixedSize (false), тоже не сработало
Преобразование относительной компоновки в компоновку кадра и наоборот.
Унижение всех зависимостей firebase и использование метода populateview. тоже не работал
- Удаление всех данных из firebase также не сработало.
- Раньше у меня был адаптер внутри OnStart, теперь он у меня в OnCreate
- Повторил весь мой код, с надеждой, что это сработает, но не сработало.
UsersActivity.java
Важные декларации:
private RecyclerView usersList;
private DatabaseReference mUsersDatabase;
private FirebaseRecyclerAdapter<Users, UserHolders> firebaseRecyclerAdapter;
inCreate:
usersList = (RecyclerView) findViewById(R.id.user_list);
usersList.setHasFixedSize(false);
usersList.setLayoutManager(new LinearLayoutManager(this));
DatabaseReference userRef = FirebaseDatabase.getInstance().getReference().child("Users");
FirebaseRecyclerOptions<Users> options = new FirebaseRecyclerOptions.Builder<Users>()
.setQuery(userRef, Users.class)
.build();
firebaseRecyclerAdapter = new FirebaseRecyclerAdapter<Users, UserHolders>(options) {
@Override
protected void onBindViewHolder(UserHolders holder, int position, Users model) {
holder.userName.setText(model.getName());
holder.userStatus.setText(model.getImage());
Picasso.get().load(model.getImage()).into(holder.userProfile);
Toast.makeText(UsersActivity.this, "working onBind", Toast.LENGTH_SHORT).show();
}
@Override
public UserHolders onCreateViewHolder(ViewGroup viewGroup, int i) {
View view = LayoutInflater.from(viewGroup.getContext()).inflate(R.layout.users_single_layout, viewGroup, false);
UserHolders userHolders = new UserHolders(view);
Toast.makeText(UsersActivity.this, "working onCreate", Toast.LENGTH_SHORT).show();
return userHolders;
}
};
usersList.setAdapter(firebaseRecyclerAdapter);
в onStart ()
super.onStart();
Toast.makeText(this, "onStart being called", Toast.LENGTH_SHORT).show();
firebaseRecyclerAdapter.startListening();
inStop ()
super.onStop();
firebaseRecyclerAdapter.stopListening();
Класс ViewHolder:
public static class UserHolders extends RecyclerView.ViewHolder {
TextView userName, userStatus;
CircleImageView userProfile;
public UserHolders(@NonNull View itemView) {
super(itemView);
userName = itemView.findViewById(R.id.user_single_name);
userProfile = itemView.findViewById(R.id.user_single_image);
userStatus = itemView.findViewById(R.id.user_single_status);
}
}
Модель класса
public class Users {
public String name;
public String image;
public String status;
public Users(){}
public Users(String name, String image, String status) {
this.name = name;
this.image = image;
this.status = status;}
public String getName() {return name;}
public void setName(String name) {this.name = name;}
public String getImage() {return image;}
public void setImage(String image) {this.image = image;}
public String getStatus() {return status;}
public void setStatus(String status) {this.status = status;}
}
Зависимости Firebase:
implementation 'com.google.firebase:firebase-database:16.1.0'
implementation 'com.google.firebase:firebase-storage:16.1.0'
implementation 'com.google.firebase:firebase-auth:16.1.0'
implementation 'com.firebaseui:firebase-ui-database:4.3.2'
Так что я ожидал, что все тосты будут работать нормально, указывая, что полный код действительно компилируется.
Тосты внутри onBindViewHolder и onStart вызываются, но не внутри onCreateViewHolder.
Итак, структура данных выглядит следующим образом
teteatete-c08f9
-Users
-FxFcc..............
.- image
.- name
.- status
.- thumb_image
Я проверил, что переменные класса модели имеют то же имя, что и эти поля