Предметы из реселлера становятся невидимыми после возобновления Активности

Похоже, что никто другой не имеет этой проблемы, потому что я не нашел никакого ответа на это. Моя проблема в том, что просмотрщик не показывает свои предметы после возобновления активности во второй раз. Чтобы вернуть предметы обратно видимым, я должен щелкнуть или прокрутить в любом месте окна просмотра. Я действительно не знаю, являются ли элементы невидимыми, пустой список заметок или есть другие проблемы. Может быть, это только структура. Я не уверен. Вот фрагмент моего кода:
Основная деятельность:

public class MainActivity extends AppCompatActivity implements RecyclerItemTouchHelper.RecyclerItemTouchHelperListener, NoteListAdapter.NotesAdapterListener {

private FirebaseAnalytics mFirebaseAnalytics;
private FirebaseAuth mFirebaseAuth;
public FirebaseUser mFirebaseUser;
private FirebaseFirestore db;

private RecyclerView recyclerView;
private RecyclerView.LayoutManager recyclerViewLayoutManager;
public NoteListAdapter adapter;
private List<Note> notesList;

private ListenerRegistration firestoreListener;
private RecyclerItemTouchHelper.RecyclerItemTouchHelperListener listener;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    mFirebaseAnalytics = FirebaseAnalytics.getInstance(this);
    mFirebaseAuth = FirebaseAuth.getInstance();
    mFirebaseUser = mFirebaseAuth.getInstance().getCurrentUser();
    db = FirebaseFirestore.getInstance();

    recyclerView = findViewById(R.id.rvNoteList);
}

@Override
public void onStop() {
    super.onStop();
    adapter.stopListening();
}

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

    notesList = new ArrayList<>();

    FirebaseFirestoreSettings settings = new FirebaseFirestoreSettings.Builder().setPersistenceEnabled(true).build();
    db.setFirestoreSettings(settings);

    Query query = db.collection("users").document(firebase_user_uid).collection("notes");
    FirestoreRecyclerOptions<Note> response = new FirestoreRecyclerOptions.Builder<Note>().setQuery(query, Note.class).build();
    adapter = new NoteListAdapter(notesList, response, MainActivity.this, MainActivity.this);

    recyclerViewLayoutManager = new LinearLayoutManager(MainActivity.this, LinearLayoutManager.VERTICAL, false);
    recyclerView.setLayoutManager(recyclerViewLayoutManager);
    recyclerView.setItemAnimator(new DefaultItemAnimator());
    recyclerView.addItemDecoration(new CustomRecyclerViewDivider(this, LinearLayoutManager.VERTICAL, 16));

    recyclerView.setAdapter(adapter);

    ItemTouchHelper.SimpleCallback itemTouchHelperCallback = new RecyclerItemTouchHelper(0, ItemTouchHelper.LEFT, MainActivity.this);
    new ItemTouchHelper(itemTouchHelperCallback).attachToRecyclerView(recyclerView);

    firestoreListener = db.collection("users").document(firebase_user_uid).collection("notes")
            .addSnapshotListener(new EventListener<QuerySnapshot>() {
                @Override
                public void onEvent(QuerySnapshot documentSnapshots, FirebaseFirestoreException e) {
                    if (e != null) {
                        Log.e("LOL", "Listen failed!", e);
                        return;
                    }

                    for (DocumentSnapshot doc : documentSnapshots) {
                        Note note = doc.toObject(Note.class);
                        note.setId(doc.getId());
                        notesList.add(note);
                    }
                }
            });

    recyclerView.addOnItemTouchListener(new RecyclerViewTouchListener(getApplicationContext(), recyclerView, new RecyclerViewTouchListener.ClickListener() {
        @Override
        public void onClick(View view, int position) {
            if (notesList != null || notesList.size() <= 0) {
                Note note = notesList.get(position);
                updateNote(note);
            }
        }

        @Override
        public void onLongClick(View view, int position) {

        }
    }));

    adapter.startListening();
    setAlarms();

    invalidateOptionsMenu();

    NavigationView navigationView = (NavigationView) findViewById(R.id.nav_view);

    View headerView = navigationView.getHeaderView(0);
    navUsername = (TextView) headerView.findViewById(R.id.displayname);
    navEmail = (TextView) headerView.findViewById(R.id.email);

    username  = sharedPreferences.getString("display_name", "");
    email = sharedPreferences.getString("email", "");

    if (username == null || email == null  || username.isEmpty() || email.isEmpty()) {
        email = mFirebaseUser.getEmail().toString();
        sharedPreferences.edit().putString("email", email).apply();
    }

    navUsername.setText(username);
    navEmail.setText(email);
}}  

1 ответ

Решение

Попробуйте следующие коды. Место recyclerView.setAdapter(adapter); (а также notifyDataSetChanged() после) внутри runOnUiThread() (Или где вы обновляете-меняете или делаете что-то на Adapter):

runOnUiThread(new Runnable() {
    @Override
    public void run() {
        //Do something on UiThread

        recyclerView.setAdapter(adapter);
        notifyDataSetChanged();
    }
});

Поскольку это влияет на интерфейс пользователя, я смог показать это следующим образом: runOnUiThread() метод.

Другие вопросы по тегам