У меня есть фрагмент, который включает в себя другой макет.У меня нет проблем с доступом к любому из других представлений в этом макете (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.
Любая помощь будет принята с благодарностью..
Редактировать: обновлены результаты метода отладки, предложенного пользователем.предоставлены обновленные сведения о фрагменте и свойствах дочернего фрагмента.