Создание chatapp с помощью FirebaseRecyclerPagination - PullRequest
0 голосов
/ 24 мая 2019

Я пытаюсь создать приложение чата, используя Firebase в качестве базы данных. Я хочу реализовать FirebaseRecyclerPagination, потому что я не хочу загружать весь чат сразу, я хочу, чтобы он загружался на определенное число только за обновление. Я следую этому уроку [Образец приложения с использованием библиотеки разбивки на страницы Firebase Recycler] (https://firebaseopensource.com/projects/patilshreyas/firebaserecyclerpagination/app/readme.md). Но все равно не получается желаемый результат.

Вот мой текущий код

public class ChatTestActivity extends AppCompatActivity {

    private RecyclerView mRecyclerView;
    private DatabaseReference mDatabase;

    private SwipeRefreshLayout mSwipeRefreshLayout;
    RecyclerView.LayoutManager layoutManager;

    FirebaseRecyclerPagingAdapter<ChatMessage, PostViewHolder> mAdapter;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_chat_test);


        mSwipeRefreshLayout = findViewById(R.id.swipe_refresh_layout);

        //Initialize RecyclerView
        mRecyclerView = findViewById(R.id.recycler_view);
        mRecyclerView.setHasFixedSize(true);

        LinearLayoutManager mManager = new LinearLayoutManager(this);
        mRecyclerView.setLayoutManager(mManager);

        //Initialize Database
        mDatabase = FirebaseDatabase.getInstance().getReference().child("conversations").child("message");

        final PagedList.Config config = new PagedList.Config.Builder()
                .setEnablePlaceholders(false)
                .setInitialLoadSizeHint(2)
                .setPrefetchDistance(2)
                .setPageSize(2)
                .build();

        final DatabasePagingOptions<ChatMessage> options = new DatabasePagingOptions.Builder<ChatMessage>()
                .setLifecycleOwner(this)
                .setQuery(mDatabase, config, ChatMessage.class)
                .build();

        mAdapter = new FirebaseRecyclerPagingAdapter<ChatMessage, PostViewHolder>(options) {
            @NonNull
            @Override
            public PostViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {


                return new PostViewHolder(LayoutInflater.from(parent.getContext()).inflate(R.layout.layout_message, parent, false));
            }

            @Override
            protected void onBindViewHolder(@NonNull PostViewHolder holder,
                                            int position,
                                            @NonNull ChatMessage model) {

                holder.setItem(model);

            }

            @Override
            protected void onLoadingStateChanged(@NonNull LoadingState state) {
                switch (state) {
                    case LOADING_INITIAL:
                    case LOADING_MORE:
                        // Do your loading animation
                       mSwipeRefreshLayout.setRefreshing(true);

                        break;

                    case LOADED:
                        // Stop Animation
                        mSwipeRefreshLayout.setRefreshing(false);
                        break;

                    case FINISHED:
                        //Reached end of Data set
                        mSwipeRefreshLayout.setRefreshing(false);
                        break;

                    case ERROR:
                        retry();
                        break;
                }
            }

            @Override
            protected void onError(@NonNull DatabaseError databaseError) {
                super.onError(databaseError);
                mSwipeRefreshLayout.setRefreshing(false);
                databaseError.toException().printStackTrace();
            }
    };
        mSwipeRefreshLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
            @Override
            public void onRefresh() {
                mAdapter.refresh();
            }
        });



        mRecyclerView.setAdapter(mAdapter);
    }

    //Start Listening Adapter
    @Override
    protected void onStart() {
        super.onStart();
        mAdapter.startListening();
    }

    //Stop Listening Adapter
    @Override
    protected void onStop() {
        super.onStop();
        mAdapter.stopListening();
    }

    public class PostViewHolder extends RecyclerView.ViewHolder {
        public final View mView;
        public final TextView msgMessage;
        public final TextView user;
        TextView mAuthor;
        TextView mDate;
        public ChatMessage mItem;

        public PostViewHolder(View view) {
            super(view);
            mView = view;
            msgMessage = (TextView) view.findViewById(R.id.msgMessage);
            user = (TextView) view.findViewById(R.id.user);

        }

        public void setItem(ChatMessage chatMessage){
            msgMessage.setText(chatMessage.messageText);
            user.setText(chatMessage.messageUser);

        }

        public TextView getMsgMessage() {
            return msgMessage;
        }

        @Override
        public String toString() {
            return super.toString() + " '" + user.getText() + "'";
        }
    }


}

Вот мой activity_chat_test.xml файл

<?xml version="1.0" encoding="utf-8"?>
<androidx.swiperefreshlayout.widget.SwipeRefreshLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/swipe_refresh_layout"
    tools:context=".ChatTestActivity">


    <androidx.recyclerview.widget.RecyclerView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/recycler_view">

    </androidx.recyclerview.widget.RecyclerView>

</androidx.swiperefreshlayout.widget.SwipeRefreshLayout>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...