RecyclerView 错误? [英] RecyclerView Bugs?

查看:25
本文介绍了RecyclerView 错误?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个 Note-App.在 Main Activity 中,Notes 将与 RecyclerView 一起列出.要在数据库中应用更改,我使用 FirestoreRecyclerOptions.
但我有一个大问题.首先,一切正常.当 ListItems 更改一次或多次时,一切都会变得混乱.然后这些事情发生了:

I have a Note-App. In the Main Activity the Notes are going to be listed with a RecyclerView. To apply changes in the database I use FirestoreRecyclerOptions.
But I have a big problem. First, everything works fine. When the ListItems are changed once or more than one time everything gets confusing. Then these things happen:

  1. RecyclerViewItems 不可见(https://www.dropbox.com/s/76e0pi3bgmqdk4u/empty_list.mp4?dl=0)
  2. RecyclerViewItem 不显示(https://www.dropbox.com/s/5ai92ypev1509qg/dont_show.mp4?dl=0)
  3. RecyclerViewItem 不会删除 (https://www.dropbox.com/s/3k2k3ryecfwnqil/dosnt_remove.mp4?dl=0)
  1. RecyclerViewItems are invisible (https://www.dropbox.com/s/76e0pi3bgmqdk4u/empty_list.mp4?dl=0)
  2. RecyclerViewItem doesn't show (https://www.dropbox.com/s/5ai92ypev1509qg/dont_show.mp4?dl=0)
  3. RecyclerViewItem doesn't remove (https://www.dropbox.com/s/3k2k3ryecfwnqil/dosnt_remove.mp4?dl=0)

在视频中,您可以看到在回收者视图中滚动后所有项目都将正常工作.我不知道为什么?也许 recyclerview 比真正重新加载?

In the Videos, you can see all Items will work correctly after you scroll in the recycler view. I don't know why? Maybe the recyclerview than gets really reloaded?

这是我如何设置 RecyclerView 以及何时调用适配器(MainActivity 的片段):

Here is how I set up the RecyclerView and when I call the Adapter(Snippet of MainActivity):

public class MainActivity extends AppCompatActivity implements RecyclerItemTouchHelper.RecyclerItemTouchHelperListener {

private FirebaseFirestore db;
public NoteListAdapter adapter;
private RecyclerView recyclerView;
private RecyclerView.LayoutManager recyclerViewLayoutManager;

private ListenerRegistration firestoreListener;
private RecyclerItemTouchHelper.RecyclerItemTouchHelperListener listener;

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

    recyclerView = findViewById(R.id.rvNoteList);
    db = FirebaseFirestore.getInstance();

    setUpRecyclerView();
}

private void setUpRecyclerView() {
    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(response, 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);

    adapter.checkIflayoutMustImprove();
}


@Override
public void onSwiped(RecyclerView.ViewHolder viewHolder, int direction, int position) {
    adapter.removeItem(viewHolder.getAdapterPosition());
}

private void deleteNote(String id) {
    db.collection("users").document(firebase_user_uid).collection("notes")
            .document(id)
            .delete()
            .addOnCompleteListener(new OnCompleteListener<Void>() {
                @Override
                public void onComplete(@NonNull Task<Void> task) {
                    mFirebaseAnalytics.logEvent(NOTE_DELETED_EVENT, null);
                }
            });
    adapter.notifyDataSetChanged();
}

@Override
public void onStart() {
    super.onStart();
    adapter.startListening();
}

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

这是 ItemRecyclerTouchHelper:

Here is the ItemRecyclerTouchHelper:

public class RecyclerItemTouchHelper extends ItemTouchHelper.SimpleCallback {
private RecyclerItemTouchHelperListener listener;

public RecyclerItemTouchHelper(int dragDirs, int swipeDirs, RecyclerItemTouchHelperListener listener) {
    super(dragDirs, swipeDirs);
    this.listener = listener;
}

@Override
public boolean onMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, RecyclerView.ViewHolder target) {
    return true;
}

@Override
public void onSelectedChanged(RecyclerView.ViewHolder viewHolder, int actionState) {
    if (viewHolder != null) {
        final View foregroundView = ((NoteViewHolder) viewHolder).viewForeground;

        getDefaultUIUtil().onSelected(foregroundView);
    }
}

@Override
public void onChildDrawOver(Canvas c, RecyclerView recyclerView,
                            RecyclerView.ViewHolder viewHolder, float dX, float dY,
                            int actionState, boolean isCurrentlyActive) {
    final View foregroundView = ((NoteViewHolder) viewHolder).viewForeground;
    getDefaultUIUtil().onDrawOver(c, recyclerView, foregroundView, dX, dY,
            actionState, isCurrentlyActive);
}

@Override
public void clearView(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder) {
    final View foregroundView = ((NoteViewHolder) viewHolder).viewForeground;
    getDefaultUIUtil().clearView(foregroundView);
}

@Override
public void onChildDraw(Canvas c, RecyclerView recyclerView,
                        RecyclerView.ViewHolder viewHolder, float dX, float dY,
                        int actionState, boolean isCurrentlyActive) {
    final View foregroundView = ((NoteViewHolder) viewHolder).viewForeground;

    getDefaultUIUtil().onDraw(c, recyclerView, foregroundView, dX, dY,
            actionState, isCurrentlyActive);
}

@Override
public void onSwiped(RecyclerView.ViewHolder viewHolder, int direction) {
    listener.onSwiped(viewHolder, direction, viewHolder.getAdapterPosition());
}

@Override
public int convertToAbsoluteDirection(int flags, int layoutDirection) {
    return super.convertToAbsoluteDirection(flags, layoutDirection);
}

public interface RecyclerItemTouchHelperListener {
    void onSwiped(RecyclerView.ViewHolder viewHolder, int direction, int position);
}}  

我在这个问题上坐了两个星期,我真的需要帮助.我希望任何人都可以帮助我.我什至不知道是什么问题.问题是 RecyclerView 或 Firebase 还是一个简单的错误?当您需要任何其他文件时,请告诉我.谢谢你帮助我.

I am sitting at this problem for two weeks and I really need help. I hope anyone can help me. I even don't know what the problem is. Is the problem the RecyclerView or Firebase or a simple bug? When you need any other files let me know. Thanks for helping me.

编辑 NoteListAdapter

公共类 NoteListAdapter 扩展 FirestoreRecyclerAdapter{

public class NoteListAdapter extends FirestoreRecyclerAdapter{

private Context context;
private RelativeLayout no_data_layout;
private Animation fadeIn, fadeOut;

public NoteListAdapter(@NonNull FirestoreRecyclerOptions<Note> options, @NonNull Context context) {
    super(options);
    this.context = context;
}

@Override
protected void onBindViewHolder(@NonNull NoteViewHolder holder, int position, @NonNull Note note) {
    holder.bind(context, note, getSnapshots().getSnapshot(position).getId(), note.getNote_image_url());

    checkIflayoutMustImprove();

    //setAlarms
    if (note.getRemindeDate() != null) {
        if (note.getRemindeDate().before(new Date())) {
            note.setRemindeDate(null);
        }
        if (note.getRemindeDate() != null) {
            Intent i = new Intent(context, TodoNotificationService.class);
            i.putExtra(TodoNotificationService.TODOUUID, note.getId());
            i.putExtra(TodoNotificationService.TODOTEXT, note.getTitle());
            i.putExtra(TodoNotificationService.TODOCONTENT, note.getContent());
            MainActivity.createAlarm(context, i, getSnapshots().getSnapshot(position).getId().hashCode(), note.getRemindeDate().getTime());
        }
    }
    if (note.getRemindeDate() == null) {
        Intent i = new Intent(context, TodoNotificationService.class);
        int id = getSnapshots().getSnapshot(position).getId().hashCode();
        MainActivity.deleteAlarm(context, i, id);
    }
}

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

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

public void removeItem(int position) {
    getSnapshots().getSnapshot(position).getReference().delete();
    notifyItemRemoved(position);

    checkIflayoutMustImprove();
}}

推荐答案

非常感谢您的帮助,但没有人无法回答这个问题.我在我的应用程序中编写了一个 immersiveMode().即使有任何交互,他也将屏幕设置为全屏.我注意到当我删除了 immersiveMode() 方法时,我在 recyclerview 中遇到的所有错误都消失了.我说不出为什么,但现在它起作用了.但是谢谢大家.:)

So thanks for all your help, but no one couldn't answer this. I coded an immersiveMode() in my App. He sets the screen to fullscreen even with any interactions. I noticed that all bugs I ever had with recyclerview were gone as I removed the immersiveMode() methods. I couldn't say why, but now it works. But thanks to everyone. :)

这篇关于RecyclerView 错误?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆