ссылка на recyclerView из дочернего макета, включенная <include /> в родительский макет - PullRequest
2 голосов
/ 01 апреля 2019

У меня есть фрагмент, который включает в себя другой макет.У меня нет проблем с доступом к любому из других представлений в этом макете (TextViews, ImageViews, CardViews), за исключением RecyclervView, в частности.

Этот пост -> Как правильно использовать recyclerview с включенным макетом? <- устраняет аналогичную ситуацию, когда пользователь получал ошибку во время выполнения.Я могу скомпилировать и запустить приложение без каких-либо ошибок во время выполнения.Проблема, которую я получаю, состоит в том, что RecyclerView не отображает какую-либо информацию от адаптера, который я сделал.Я проверил адаптер отдельно, чтобы увидеть, была ли это проблема, и это не так, поскольку он прекрасно работал при реализации отдельно в родительском макете без тега.Я мог бы легко просто закодировать фактический макет в основной фрагмент, но мне нужно многократно использовать этот конкретный макет в приложении, поэтому необходимо включить его с помощью тега. </p>

Я предоставил макет xml,класс фрагмента, класс SetViewHolder, а также вид адаптера ниже.

примечание: мой adapterView использует класс SetViewHolder из recyclerView.

XML Layout

<VideoView
    android:layout_width="match_parent"
    android:layout_height="250dp"
    app:layout_anchorGravity="top|center"
    android:id="@+id/vvLive"/>

<androidx.core.widget.NestedScrollView
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:scrollbars="vertical"
    android:id="@+id/bottomSheet"
    android:background="@color/lightGray"
    app:layout_behavior="@string/bottom_sheet_behavior"
    app:behavior_peekHeight="375dp">


    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        android:padding="10dp">

        <include
            layout="@layout/home_intro_category"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="center" />

        <include
            android:id="@+id/slide_show1"
            layout="@layout/image_slide_show_card_holder"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:layout_marginTop="20dp" />


    </LinearLayout>



</androidx.core.widget.NestedScrollView>

Класс фрагмента

public class HomeFrag extends Fragment {

private BottomSheetBehavior bottomSheetBehavior;
private HomeViewModel viewModel;
private TextView tvHeaderCS1, tvSubCS1;
private SlideAdapter adapter;
RecyclerView rvSlide1;

@Nullable
@Override
public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
    ViewGroup viewGroup = (ViewGroup) inflater.inflate(R.layout.home_frag, container, false);
    viewModel = ViewModelProviders.of(this).get(HomeViewModel.class);

    return viewGroup;
}

@Override
public void onViewCreated(@NonNull View view, @Nullable Bundle savedInstanceState) {
    super.onViewCreated(view, savedInstanceState);
    //initialize views
    View bottomSheet = view.findViewById(R.id.bottomSheet);
    bottomSheetBehavior = BottomSheetBehavior.from(bottomSheet);
    bottomSheetBehavior.setState(BottomSheetBehavior.STATE_HALF_EXPANDED);
    CardView cvSlide1 = view.findViewById(R.id.slide_show1);
    rvSlide1 = cvSlide1.findViewById(R.id.rvItems);
    tvHeaderCS1 = cvSlide1.findViewById(R.id.hdMain);
    tvSubCS1 = cvSlide1.findViewById(R.id.hdSub);

}

@Override
public void onResume() {
    super.onResume();

    viewModel.populateList().observe(this, new Observer<String>() {
        @Override
        public void onChanged(String s) {
            try {
                GsonBuilder builder = new GsonBuilder();
                Gson gson = builder.create();
                List<Item> itemsList = new ArrayList<>();
                JSONArray array = new JSONArray(s);

                for(int i=0;i<array.length();i++){
                    Item item = gson.fromJson(array.getString(i), Item.class);
                    itemsList.add(item);
                }

                LinearLayoutManager linearLayout = new LinearLayoutManager(getContext(), LinearLayoutManager.HORIZONTAL, false);
                adapter = new SlideAdapter(getActivity(), itemsList);
                rvSlide1.setLayoutManager(linearLayout);
                rvSlide1.setAdapter(adapter); //no problem with adapter, but not showing anything****


                //slide shows headers and subs
                tvHeaderCS1.setText("Items Recently On Air");
                tvSubCS1.setText("");

            } catch (JSONException e) {
                e.printStackTrace();
            }

        }
    });

}

Класс адаптера

public class SlideAdapter extends RecyclerView.Adapter<SetViewHolder> {

private Activity activity;
List<Item> items;

public SlideAdapter(Activity activity, List<Item> items) {
    this.activity = activity;
    this.items = items;
}

@NonNull
@Override
public SetViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
    View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.slideshow_card_item, parent, false);
    return new SetViewHolder(view);
}

@Override
public void onBindViewHolder(@NonNull SetViewHolder holder, int position) {
    holder.tvProductNameSlide.setText(items.get(position).getItemName());
    holder.tvPreviousPriceSlide.setText(String.valueOf(items.get(position).getItemPreviousPrice()));
    holder.tvSalePriceSlide.setText(String.valueOf(items.get(position).getItemSalePrice()));
    Glide.with(activity).load(items.get(position).getItemURL())
            .centerCrop()
            .into(holder.ivProductSlideShow);
}

@Override
public int getItemCount() {
    return items.size();
}
}

Класс SetViewHolder Открытый класс SetViewHolder расширяет RecyclerView.ViewHolder {

public TextView tvProductNameSlide, tvPreviousPriceSlide, tvSalePriceSlide;
public ImageView ivProductSlideShow;

public SetViewHolder(@NonNull View itemView) {
    super(itemView);


    tvProductNameSlide = itemView.findViewById(R.id.tvProductName);
    tvPreviousPriceSlide = itemView.findViewById(R.id.tvPreviousPrice);
    tvSalePriceSlide = itemView.findViewById(R.id.tvSalePrice);
    ivProductSlideShow = itemView.findViewById(R.id.ivProduct);

}

}

Моя цель состоит в том, чтобы заполнить recyclerView объектами (имя, элемент, изображение) с другим макетом (cardView).Я проверил адаптер самостоятельно, внедрив RecyclerView непосредственно в HomeFrag.class (основной фрагмент, где я использую тег), и адаптер работает отлично.

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

Любая помощь будет принята с благодарностью..

Редактировать: обновлены результаты метода отладки, предложенного пользователем.предоставлены обновленные сведения о фрагменте и свойствах дочернего фрагмента.

1 Ответ

0 голосов
/ 01 апреля 2019

На (включенном) макете, где Вы используете RecyclerView, добавьте app:layout_behavior

<android.support.v7.widget.RecyclerView
    android:id="@+id/conversation"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" />

Также попробуйте сделать еще одну вещь: позвоните setNestedScrollingEnabled(false) перед вызовом setAdapter():

recyclerView.setNestedScrollingEnabled(false);
...