android - 具有 Firebase 数据的 Recycler View 仅在滚动时加载

标签 android firebase android-recyclerview firebase-realtime-database

我正在使用 Firebase 并使用 android.support.v7.widget.RecyclerView。问题是 onStart View 加载为空,数据仅在滚动后填充。知道为什么吗?

代码:

RecyclerView(我在开始时设置了一个空适配器以避免“RecyclerView:没有附加适配器;跳过布局”):

 mLayoutManager = new LinearLayoutManager(getActivity());
 mLayoutManager.setReverseLayout(true);
 mLayoutManager.setStackFromEnd(true);
 mRecyclerView.setLayoutManager(mLayoutManager);
 mRecyclerView.setHasFixedSize(true);

 mRecyclerView.getRecycledViewPool().setMaxRecycledViews(1,0);                                     
 mRecyclerView.setAdapter(new RecyclerView.Adapter() {
        @Override
        public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
            return null;
        }

        @Override
        public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {

        }

        @Override
        public int getItemCount() {
            return 0;
        }
    });

Firebase 数据获取:

databaseReference.child("/News").orderByChild("createdAt").addValueEventListener(new ValueEventListener() {
    @Override
    public void onDataChange(final DataSnapshot dataSnapshot) {

        for (DataSnapshot postSnapshot : dataSnapshot.getChildren()) {

            final News news = postSnapshot.getValue(News.class);
            final PostListClass postListClass = new PostListClass();
            //add fac id admin
            if (news.getFaculteId().equals(userFaculteId) || news.getFaculteId().equals("Admin")) {
                postListClass.setPostId(postSnapshot.getKey());
                postListClass.setPostTitle(news.getHeadlines());
                postListClass.setPostDescription(news.getDetails());

                databaseReference.child("/users").child(news.getAuthor()).addListenerForSingleValueEvent(new ValueEventListener() {
                    @Override
                    public void onDataChange(DataSnapshot usersSnapShot) {
                        User user = usersSnapShot.getValue(User.class);

                        postListClass.setPostOwnerId(usersSnapShot.getKey());
                        postListClass.setPostOwnerName(user.getPrenom() + " " + user.getNom());
                        postListClass.setPostOwnerPromo(user.getPromotion());

                        try {
                            Calendar cal = Calendar.getInstance(Locale.ENGLISH);
                            cal.setTimeInMillis(news.getCreatedAt() * 1000);
                            SimpleDateFormat sdf = new SimpleDateFormat("dd-MM-yyyy");
                            Date date = sdf.parse(DateFormat.format("dd-MM-yyyy", cal).toString());
                            String day = (String) android.text.format.DateFormat.format("dd", date);
                            String month = (String) android.text.format.DateFormat.format("MMM", date);
                            postListClass.setPostDate(day + " " + month);
                        } catch (java.text.ParseException e) {
                            e.printStackTrace();
                        }
                        storageRef.child("users/" + news.getAuthor() + ".jpg").getDownloadUrl().addOnSuccessListener(new OnSuccessListener<Uri>() {
                            @Override
                            public void onSuccess(Uri uri) {
                                postListClass.setPostOwnerImageUrl(String.valueOf(uri));
                            }
                        }).addOnFailureListener(new OnFailureListener() {
                            @Override
                            public void onFailure(@NonNull Exception exception) {
                                // Handle any errors

                                if (exception.getClass().isInstance(StorageException.class)) {
                                    postListClass.setPostOwnerImageUrl("NullImage");

                                }

                            }
                        });

                    }

                    @Override
                    public void onCancelled(DatabaseError databaseError) {
                    }
                });

                databaseReference.child("/News").child(postSnapshot.getKey()).child("/Comments").addValueEventListener(new ValueEventListener() {
                    @Override
                    public void onDataChange(DataSnapshot dataSnapshot) {
                        postListClass.setPostComments(String.valueOf(dataSnapshot.getChildrenCount()));

                    }

                    @Override
                    public void onCancelled(DatabaseError databaseError) {

                    }
                });

                storageRef.child("News/" + postSnapshot.getKey() + ".png").getDownloadUrl().addOnSuccessListener(new OnSuccessListener<Uri>() {
                    @Override
                    public void onSuccess(Uri uri) {
                        postListClass.setPostImageUrl(String.valueOf(uri));

                    }
                }).addOnFailureListener(new OnFailureListener() {
                    @Override
                    public void onFailure(@NonNull Exception exception) {

                        postListClass.setPostImageUrl("NullImage");

                    }
                });

                postListClasses.add(postListClass);


            }

        }

       postsAdapter = new PostsAdapter(getContext(), postListClasses);
        mRecyclerView.setAdapter(postsAdapter);

    }


    @Override
    public void onCancelled(DatabaseError databaseError) {

    }
});

所以这是应用程序启动时的结果(三个字段缺少数据):

enter image description here

滚动后(缺失的数据被填充):

enter image description here

最佳答案

数据是从 Firebase 异步加载的。因此,当您将适配器附加到列表时,还没有数据。

一旦数据从服务器传来,您需要提醒列表。您可以通过调用 adapter.notifyDataSetChanged() 来完成此操作。

关于android - 具有 Firebase 数据的 Recycler View 仅在滚动时加载,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40016852/

相关文章:

android - 如何在cardview中水平和垂直放置相等的空间

android - E/libEGL : validate_display:255 error 3008 (EGL_BAD_DISPLAY) on Nexus 9 + Android 6

android - fcm 刷新 token 何时创建

java - 如何以正确的方式将java对象写入firebase?

swift - 如何更新存储节点 firebase swift

android - 在recyclerview android中添加两个部分

java - 使用 recyclerView 项目的一些 `put extra` onClick 返回到上一个 Activity

java - 使用 Sprite 创建菜单按钮

android - 400 : An internal consistency error has occurred: 406: No access token: cannot retrieve account

android - RecyclerView 使用基于 Realm 的 Adapter 进行拖放