Как поместить RecyclerView во фрагмент? - PullRequest
0 голосов
/ 03 мая 2019

Я все еще новичок в разработке для Android. В настоящее время я пытаюсь показать RecyclerView внутри фрагмента. Я пытался показать RecyclerView без использования Fragment, и он работал нормально. Но когда дело доходит до использования фрагмента, ничего не отображается.

ScreenShot

Вот MainActivity, содержащий фрагмент:

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //ButterKnife.bind(this);
        BottomNavigationView navView = findViewById(R.id.nav_view);

        navView.setOnNavigationItemSelectedListener(mOnNavigationItemSelectedListener);

        mViewModel = ViewModelProviders.of(this).get(MainActivityViewModel.class);

        mFragmentManager = getSupportFragmentManager();
        mFragmentTransaction = mFragmentManager.beginTransaction();
        mFragmentTransaction.add(R.id.fragment_container, missionListFragment).addToBackStack(null).commit();
    }

И метод фрагмента onCreateView:

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // Inflate the layout for this fragment

        View rootView = inflater.inflate(R.layout.fragment_mission_list, container, false);
        //ButterKnife.bind(rootview);
        mRecycler = (RecyclerView) rootView.findViewById(R.id.recycler);

        mFirestore = FirebaseFirestore.getInstance();
        mQuery = mFirestore.collection("COLLECTION_NAME").limit(LIMIT);

        if (mQuery == null) {
            Log.w(TAG, "No query, not initializing RecyclerView. Created data on server.");
        }

        mAdapter = new RecyclerViewAdapter(mQuery, this) {

            @Override
            protected void onDataChanged() {

            }

            @Override
            protected void onError(FirebaseFirestoreException e) {
                // Show a snackbar on errors
                Snackbar.make(getActivity().findViewById(android.R.id.content),
                        "Error: check logs for info.", Snackbar.LENGTH_LONG).show();
            }
        };
        mRecycler.setLayoutManager(new LinearLayoutManager(getActivity()));
        mRecycler.setAdapter(mAdapter);

        return rootView;
    }

С RecyclerViewAdapter:

public class RecyclerViewAdapter extends FirestoreAdapter<RecyclerViewAdapter.ViewHolder> {

    private static final int UNAVAILABLE = 0, AVAILABLE = 1;

    public interface OnItemSelectedListener {

        void onItemSelected(DocumentSnapshot item);

    }

    private OnItemSelectedListener mListener;

    public RecyclerViewAdapter(Query query, OnItemSelectedListener listener) {
        super(query);
        mListener = listener;
    }

    @Override
    public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        LayoutInflater inflater = LayoutInflater.from(parent.getContext());
        return new ViewHolder(inflater.inflate(R.layout.item, parent, false));
    }

    @Override
    public void onBindViewHolder(ViewHolder holder, int position) {
        holder.bind(getSnapshot(position), mListener);
    }

    static class ViewHolder extends RecyclerView.ViewHolder {

        @BindView(R.id.view1)
        TextView view1;

        @BindView(R.id.view2)
        TextView view2;

        @BindView(R.id.view3)
        TextView view3;

        @BindView(R.id.view4)
        TextView view4;

        public ViewHolder(View itemView) {
            super(itemView);
            ButterKnife.bind(this, itemView);
        }

        public void bind(final DocumentSnapshot snapshot,
                         final OnItemSelectedListener listener) {

            Item item = snapshot.toObject(Item.class);
            Resources resources = itemView.getResources();

            view1.setText(item.getfield1());
            view2.setText(Integer.toString(item.getfield2()));
            if(item.getfield3() == AVAILABLE)
                view3.setText("Available");
            else
                view3.setText("Unavailable");
            view4.setText(item.getfield4().toString());

            // Click listener
            itemView.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    if (listener != null) {
                        listener.onItemSelected(snapshot);
                    }
                }
            });
        }

    }
}

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

1 Ответ

0 голосов
/ 06 мая 2019

Может случиться так, что данные из firebase не будут извлечены, следовательно, нет никакого контента, который бы мог просматривать просмотрщик. Проверьте, нормально ли работает ваше firebase-соединение, и вы что-то извлекаете из него

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