У меня есть фрагмент рециркуляции на фрагменте моего дома. который извлекает данные из пожарного магазина Firebase. так что, если я обновлю что-нибудь в моем пожарном магазине, это произойдет в режиме реального времени. но проблема в том, что я установил прослушиватель по щелчку в представлении перезапуска, которое открывает действие. в этой деятельности данные не извлекаются в режиме реального времени. Например, я нахожусь на этой активности и обновляю что-то в firestore, поэтому, чтобы увидеть эти изменения, мне нужно вернуться к фрагменту, а затем снова приступить к активности, чтобы увидеть эти изменения. Как это решить. что, когда я в это время на работе, только изменения данных извлекаются из пожарного депо.
Класс адаптера:
public class PinnedPostAdapter extends RecyclerView.Adapter<PinnedPostAdapter.ViewHolder> {
public List<PinnedPost> pinnedPostList;
private Context context;
private OnItemClicked onClick;
public PinnedPostAdapter (Context context, List<PinnedPost> pinnedPostList) {
this.pinnedPostList = pinnedPostList;
this.context = context;
}
@NonNull
@Override
public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.pinned_post_layout, parent, false);
return new ViewHolder(view);
}
@Override
public void onBindViewHolder(@NonNull final ViewHolder holder, final int position) {
if (TextUtils.isEmpty(pinnedPostList.get(position).getPinned_post_title())) {
holder.pinnedPosttitle.setText("Not Available");
} else {
holder.pinnedPosttitle.setText(pinnedPostList.get(position).getPinned_post_title());
}
holder.read_more.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
onClick.onItemCl(position, pinnedPostList.get(position));
}
});
}
@Override
public int getItemCount() {
return pinnedPostList.size();
}
public void setOnClick(PinnedPostAdapter.OnItemClicked onClick) {
this.onClick = onClick;
}
public interface OnItemClicked {
void onItemCl(int position, PinnedPost passData);
}
public class ViewHolder extends RecyclerView.ViewHolder {
public TextView pinnedPosttitle;
public Button read_more;
View mView;
public ViewHolder(View itemView) {
super(itemView);
mView = itemView;
pinnedPosttitle = (TextView) mView.findViewById(R.id.pinned_post_title);
pinnedPosttitle.setSelected(true);
pinnedPosttitle.setSingleLine(true);
read_more = (Button) mView.findViewById(R.id.pinned_post_read_more);
}
}
}
Домашний фрагмент:
public class HomeFragment extends Fragment implements PinnedPostAdapter.OnItemClicked {
private static final String Pinned_Post = "PINNED_POST";
private RecyclerView recyclerViewPinnedPosts;
private PinnedPostAdapter pinnedPostAdapter;
private List<PinnedPost> pinnedPostList;
pinnedPostList = new ArrayList<>();
pinnedPostAdapter = new PinnedPostAdapter(getActivity(), pinnedPostList);
recyclerViewPinnedPosts = (RecyclerView) view.findViewById(R.id.pinned_post);
recyclerViewPinnedPosts.setHasFixedSize(true);
recyclerViewPinnedPosts.setLayoutManager(new LinearLayoutManager(getActivity(), LinearLayoutManager.HORIZONTAL, false));
recyclerViewPinnedPosts.setAdapter(pinnedPostAdapter);
pinnedPostAdapter.setOnClick(this);
mFirestore.collection("pinned_post").orderBy("priority", Query.Direction.DESCENDING).addSnapshotListener(new EventListener<QuerySnapshot>() {
@Override
public void onEvent(@javax.annotation.Nullable QuerySnapshot documentSnapshots, @javax.annotation.Nullable FirebaseFirestoreException e) {
if (e != null) {
Log.d(TAG, "Error : " + e.getMessage());
}
assert documentSnapshots != null;
for (DocumentChange doc : documentSnapshots.getDocumentChanges()) {
if (doc.getType() == DocumentChange.Type.ADDED) {
String doc_id = doc.getDocument().getId();
PinnedPost pinnedPost = doc.getDocument().toObject(PinnedPost.class).withDocId(doc_id);
pinnedPostList.add(doc.getNewIndex(), pinnedPost);
pinnedPostAdapter.notifyDataSetChanged();
} else if (doc.getType() == DocumentChange.Type.MODIFIED) {
String docID = doc.getDocument().getId();
PinnedPost changedModel = doc.getDocument().toObject(PinnedPost.class).withDocId(docID);
if (doc.getOldIndex() == doc.getNewIndex()) {
// Item changed but remained in same position
pinnedPostList.set(doc.getOldIndex(), changedModel);
pinnedPostAdapter.notifyItemChanged(doc.getOldIndex());
} else {
// Item changed and changed position
pinnedPostList.remove(doc.getOldIndex());
pinnedPostList.add(doc.getNewIndex(), changedModel);
pinnedPostAdapter.notifyItemMoved(doc.getOldIndex(), doc.getNewIndex());
}
} else if (doc.getType() == DocumentChange.Type.REMOVED) {
// remove
pinnedPostList.remove(doc.getOldIndex());
pinnedPostAdapter.notifyItemRemoved(doc.getOldIndex());
}
}
}
});
@Override
public void onItemCl(int position, PinnedPost passData) {
Intent intent = new Intent(getActivity(), Pinned_Post_Clcik.class);
Bundle args = new Bundle();
args.putSerializable(Pinned_Post, passData);
intent.putExtras(args);
startActivity(intent);
}
Активность, на которую я иду, когда нажимаю на пункт просмотра переработчика. здесь, в этом упражнении, данные не выбираются в режиме реального времени при любых изменениях данных в хранилище. я должен вернуться к фрагменту и снова приступить к этой деятельности, чтобы увидеть эти изменения.
public class Pinned_Post_Clcik extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_pinned_post);
list = (PinnedPost) getIntent().getExtras().getSerializable(Pinned_Post);
mTitle = (TextView) findViewById(R.id.m_PP_title);
if (TextUtils.isEmpty(list.getPinned_post_title())) {
mTitle.setText("Not Available");
} else {
mTitle.setText(list.getPinned_post_title());
}
mDescription = (TextView) findViewById(R.id.m_PP_Description);
if (TextUtils.isEmpty(list.getPinned_post_desc())) {
mDescription.setText("Not Available");
} else {
mDescription.setText(list.getPinned_post_desc());
}
Spanned result;
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
result = Html.fromHtml(list.getPinned_post_desc(), Html.FROM_HTML_MODE_LEGACY);
} else {
result = Html.fromHtml(list.getPinned_post_desc());
}
mDescription.setText(result);
mDescription.setMovementMethod(LinkMovementMethod.getInstance());
mImageView = (ImageView) findViewById(R.id.mPinnedPostImg);
mProgressBar = (ProgressBar) findViewById(R.id.pb);
FailedImg = (ImageView) findViewById(R.id.ef_failed_image);
if (TextUtils.isEmpty(list.getmImagePinnedPost())) {
mImageView.setImageResource(R.drawable.failed_to_load_img);
mProgressBar.setVisibility(View.GONE);
} else {
Picasso.with(getApplicationContext())
.load(list.getmImagePinnedPost())
.into(mImageView, new Callback() {
@Override
public void onSuccess() {
mProgressBar.setVisibility(View.GONE);
FailedImg.setVisibility(View.GONE);
}
@Override
public void onError() {
mImageView.setImageResource(R.drawable.app_logo);
mProgressBar.setVisibility(View.GONE);
}
});
bottomView = (BottomNavigationView) findViewById(R.id.pinned_post_bottom);
bottomView.setOnNavigationItemSelectedListener(new BottomNavigationView.OnNavigationItemSelectedListener() {
@Override
public boolean onNavigationItemSelected(@NonNull MenuItem item) {
int id = item.getItemId();
switch (id) {
case R.id.bottom_home:
onBackPressed();
finish();
}
return false;
}
});
}
}
}