Я пытался использовать Fragments
в качестве моих RecyclerView
детей, но безрезультатно.
Я пытаюсь загрузить ArrayList
пользовательских POJO
классов.из моего Firebase Database
, и каждый из этих элементов имеет содержимое, которое будет отображаться в качестве заголовка, и основное содержимое.
Для этого я создал Складной макет , где пользователь впервые видит заголовокмакет и при щелчке по нужному дочернему элементу в макете они отображаются с основным содержимым.
Макет заголовка - это простой ConstraintLayout
, поэтому нет проблем с привязкой данных к представлениям.Но мой макет содержимого представляет собой ViewPager
в сочетании с TabLayout
для размещения трех Fragments
, чьи данные поступают из ArrayList
, извлеченного из Firebase
.
Моя проблема заключается вгде только Fragments
первого ребенка показывает данные в событии onClick
, а остальные нет.
Это мой RecyclerView Adapter
:
public class OrdersAdapter extends RecyclerView.Adapter<OrdersAdapter.viewHolder> {
public static boolean canScroll;
public static String image;
public static String message;
private static boolean isUser;
private static int scrollTo;
private static List<Order> beanOrders;
private FragmentManager fragmentManager;
public OrdersAdapter(List<Order> beanOrders, FragmentManager fragmentManager) {
OrdersAdapter.beanOrders = beanOrders;
this.fragmentManager = fragmentManager;
}
@NonNull
@Override
public viewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
return new viewHolder(new FoldableLayout(parent.getContext()));
}
@Override
public void onBindViewHolder(@NonNull final viewHolder holder, int i) {
ArrayList<String> location = beanOrders.get(i).getLocation();
String county = location.get(0);
String consti = location.get(1);
String ward = location.get(2);
String estate = location.get(3);
String apartm = location.get(4);
if (beanOrders.get(i).isTaken()) {
holder.flHolder.setBackground(holder.itemView.getContext().getResources().getDrawable(R.drawable.vector_free));
} else if (beanOrders.get(i).isDelivered()) {
holder.flHolder.setBackground(holder.itemView.getContext().getResources().getDrawable(R.drawable.vector_delid));
}
holder.tvWorth.setText(String.format("Ksh %s", beanOrders.get(i).getsWorth()));
holder.tvNumber.setText(beanOrders.get(i).getsPhone());
holder.tvUserName.setText(beanOrders.get(i).getsName());
holder.tvCouConWard.setText(String.format("%s , %s , %s", county, consti, ward));
holder.tvEstApart.setText(String.format("%s , %s", estate, apartm));
}
@Override
public int getItemCount() {
return (null != beanOrders ? beanOrders.size() : 0);
}
private void setUpData(viewHolder holder, String image, String message) {
setUpViewPager(holder.vpAdmin, image, message, fragmentManager);
holder.tbAdmin.setupWithViewPager(holder.vpAdmin);
holder.vpAdmin.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
@Override
public void onPageScrolled(int i, float v, int i1) {
}
@Override
public void onPageSelected(int i) {
isUser = i == 2;
if (i == 2) {
holder.fabClose.setImageResource(R.drawable.vector_eraser);
} else holder.fabClose.setImageResource(R.drawable.vector_fold);
}
@Override
public void onPageScrollStateChanged(int i) {
}
});
}
private void setUpViewPager(HViewPager viewPager, String image, String message, FragmentManager fragmentManager) {
FragmentsAdapter fragmentsAdapter = new FragmentsAdapter(fragmentManager);
Image fragmentImage = Image.newInstance(image);
Message fragmentMessage = Message.newInstance(message);
fragmentsAdapter.addFragment(new Image(), "Image");
fragmentsAdapter.addFragment(new Message(), "Confirmation");
fragmentsAdapter.addFragment(new Delivery(), "Delivery");
viewPager.setAdapter(fragmentsAdapter);
viewPager.setPagingEnabled(false);
}
class viewHolder extends RecyclerView.ViewHolder implements View.OnClickListener, View.OnLongClickListener {
FoldableLayout flAdmin;
@BindView(R.id.tbAdmin)
TabLayout tbAdmin;
@BindView(R.id.vpAdmin)
HViewPager vpAdmin;
@BindView(R.id.fabClose)
FloatingActionButton fabClose;
@BindView(R.id.tvUserName)
AppCompatTextView tvUserName;
@BindView(R.id.tvNumber)
AppCompatTextView tvNumber;
@BindView(R.id.tvWorth)
AppCompatTextView tvWorth;
@BindView(R.id.tvCouConWard)
AppCompatTextView tvCouConWard;
@BindView(R.id.tvEstApart)
AppCompatTextView tvEstApart;
@BindView(R.id.tvLoyalty)
AppCompatTextView tvLoyalty;
@BindView(R.id.tvPoints)
AppCompatTextView tvPoints;
@BindView(R.id.flHolder)
FrameLayout flHolder;
viewHolder(FoldableLayout foldableLayout) {
super(foldableLayout);
flAdmin = foldableLayout;
foldableLayout.setupViews(R.layout.layout_c_header, R.layout.layout_c_content, R.dimen.cover_height, itemView.getContext());
ButterKnife.bind(this, foldableLayout);
vpAdmin.setPagingEnabled(false);
canScroll = true;
fabClose.setOnClickListener(this);
flAdmin.setOnClickListener((View v) -> {
image = beanOrders.get(getLayoutPosition()).getsImage();
message = beanOrders.get(getLayoutPosition()).getsMessage();
setUpData(this, image, message);
tbAdmin.setupWithViewPager(vpAdmin);
//Toast.makeText(itemView.getContext(), beanOrders.get(getLayoutPosition()).getsMessage(), Toast.LENGTH_SHORT).show();
new Handler().postDelayed(() -> canScroll = false, 1000);
Intent intent = new Intent(ConstHelper.START_SCROLL);
intent.putExtra(ConstHelper.SMOOTH_SCROLL, true);
intent.putExtra(ConstHelper.SCROLL_TO, getLayoutPosition());
LocalBroadcastManager.getInstance(itemView.getContext()).sendBroadcast(intent);
if (flAdmin.isFolded()) {
flAdmin.unfoldWithAnimation();
} else {
flAdmin.foldWithAnimation();
}
});
flAdmin.setOnLongClickListener(view -> {
canScroll = true;
return true;
});
}
@Override
public void onClick(View view) {
canScroll = true;
if (isUser) {
canScroll = false;
Intent intent = new Intent(ConstHelper.SIGNATURE_CALL);
intent.putExtra(ConstHelper.CLEAR_CUSTOMER, true);
LocalBroadcastManager.getInstance(viewHolder.this.itemView.getContext()).sendBroadcast(intent);
} else {
if (!flAdmin.isFolded()) {
flAdmin.foldWithAnimation();
}
}
}
@Override
public boolean onLongClick(View view) {
//TODO send report that order has been received
return true;
}
}}
Фрагменты просты идва следуют этой схеме:
public class Message extends Fragment {
@BindView(R.id.tvConfirmation)
AppCompatTextView tvConfirmation;
Unbinder unbinder;
public Message() {
}
public static Message newInstance(String message) {
Bundle bundle = new Bundle();
bundle.putString("Message", message);
Message fragmentMessage = new Message();
fragmentMessage.setArguments(bundle);
return fragmentMessage;
}
private void readBundle(Bundle bundle) {
if (bundle != null) {
//message = bundle.getString("Message");
}
}
@Nullable
@Override
public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.layout_f_message, container, false);
unbinder = ButterKnife.bind(this, view);
return view;
}
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
}
@Override
public void onActivityCreated(@Nullable Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
tvConfirmation.setText(OrdersAdapter.message);
Toast.makeText(getActivity(), OrdersAdapter.message, Toast.LENGTH_SHORT).show();
//readBundle(getArguments());
}
@Override
public void onDestroyView() {
super.onDestroyView();
unbinder.unbind();
}}
Другой просто загружает изображение, а последний не связан с данными, которые я получаю.
Что я пробовал
- Использование
Bundles
для доставки данных в Fragment
. - Переключение с места загрузки моего
Fragments
из ViewHolder
класса в onBindViewHolder
метод.
Первое, похоже, работает из-за моей отладки, но проблема все равно преобладает, несмотря ни на что.
Это изображение описанной выше ситуации:
Буду признателен за любую помощь.