大家好。 我已经使用ItemTouchHelper.SimpleCallback实现了一次轻扫来消除我的recyclerview上的行为,这种方法非常有效,直到我从firebase数据库中删除当前的卡信息。 如果在onSwiped覆盖的方法中,我只是从列表中删除卡片项目,行为是正常的,这一切都很好:
item1
item2
item3
但是,如果我从Firebase数据库中删除卡信息,请执行以下操作:
item1
item2
item1
item2
从firebase数据库中删除数据,卡从列表中删除,但是,在当前删除的元素之后,在删除的元素下添加没有当前元素的列表。我真的不明白为什么会发生如果我从firebase删除项目,但如果我不从firebase删除一切都是正常的
更好地理解,如果我有lis
public void addDismissBehavior(){
ItemTouchHelper.Callback callback = new CardSwipeItemTouchHelper(adapter);
ItemTouchHelper helper = new ItemTouchHelper(callback);
helper.attachToRecyclerView(rents);
}
我删除了第3项,屏幕上显示的列表将是
public class CardSwipeItemTouchHelper extends ItemTouchHelper.SimpleCallback {
private RentAnnounceAdapter rentAnnounceAdapter;
private static final String REF_RENT = "rent-announces";
private static final String REF_RENT_IMAGES = "rent-images";
public CardSwipeItemTouchHelper(RentAnnounceAdapter adapter){
super(0, ItemTouchHelper.LEFT | ItemTouchHelper.RIGHT);
this.rentAnnounceAdapter = adapter;
}
@Override
public boolean onMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, RecyclerView.ViewHolder target) {
rentAnnounceAdapter.swap(viewHolder.getAdapterPosition(), target.getAdapterPosition());
return true;
}
@Override
public void onSwiped(RecyclerView.ViewHolder viewHolder, int direction) {
final int poz = viewHolder.getAdapterPosition();
String ID = rentAnnounceAdapter.getList()
.get(poz)
.getAnnounceID();
DatabaseReference dbRef = FirebaseDatabase.getInstance()
.getReference();
dbRef.child(REF_RENT)
.child(ID)
.removeValue();
StorageReference ref = FirebaseStorage.getInstance()
.getReference();
ref.child(REF_RENT_IMAGES)
.child(ID)
.delete().addOnSuccessListener(new OnSuccessListener<Void>() {
@Override
public void onSuccess(Void aVoid) {
rentAnnounceAdapter.remove(poz);
}
});
}
@Override
public void onSwiped(RecyclerView.ViewHolder viewHolder, int direction) {
final int poz = viewHolder.getAdapterPosition();
rentAnnounceAdapter.remove(poz);
}
或另一个例子,如果我删除item2,将是 ITEM1 项目3 ITEM1 项目3
在我的片段中,我将ItemTouchHelper附加到recyclerview,如下所示:
public void remove(int position){
cardRentAnnounceArrayList.remove(position);
notifyItemRemoved(position);
}
public void swap(int fPoz, int secPoz){
Collections.swap(cardRentAnnounceArrayList, fPoz, secPoz);
notifyItemMoved(fPoz, secPoz);
}
CardSwipeItemTouchHelper类:
{{1}}
}
从适配器中删除和交换方法,其余部分是基本的适配器方法
{{1}}
如果有人对这里发生的事情有所了解,请告诉我。 感谢。
经过一个小时的调试后,我仍然没有发现问题。 如果有人知道答案......我在等它
答案 0 :(得分:0)
我已经解决了这个问题。
问题是,当打开片段并使用firebase中的项目列表填充适配器时,我使用def print_time( threadName, delay):
来监听数据库上的每个更改,并在需要时重新更改数据。因此,在删除之后,它会以某种方式在当前列表中添加其余的声明。
while 1:
time.sleep(delay)
print "%s: %s" % ( threadName, time.ctime(time.time()) )
execute code here
try:
thread.start_new_thread( print_time, ("Thread", 120, ) )
except:
print "Error: unable to start thread"
while 1:
pass
使用reference.addValueEventListener( ... )
下载列表解决了我的问题,因为不需要在每次删除后重新下载并设置列表,因为它在本地和在线数据库同步删除。