我有一个活动,在创建时,我创建了五个文件,然后读取这些文件并添加到我的recyclerview中。我还在我的recyclerview中添加了滑动功能。当一个项目被滑动时,它删除了recycler视图中该位置的单元格,同时也删除了我创建的文件。我面临的问题是,假设在我的recyclerview中有5个项目1、2、3、4和5,我滑动鼠标删除1,包含1的文件被删除,但在我的recyclerview中,当我滑动鼠标1时,5又被添加。同样的事情也发生在2,3和4上。当一个单元格被滑动时,5会不断地被添加。
以下是我的代码
public class MyRecordingsActivity extends AppCompatActivity {
private RecyclerView recyclerView;
private RecordingsAdapter recordingsAdapter;
private ArrayList<Recording> recordingArrayList;
private File userRecordingFile;
private static final String USER_MIX_DIR = "UserMix";
private ArrayList<String> arrayList;
ItemTouchHelper.SimpleCallback simpleItemTouchCallback = new ItemTouchHelper.SimpleCallback(0,
ItemTouchHelper.LEFT | ItemTouchHelper.RIGHT) {
@Override
public boolean onMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, RecyclerView.ViewHolder target) {
return false;
}
@Override
public void onSwiped(RecyclerView.ViewHolder viewHolder, int swipeDir) {
Toast.makeText(getApplicationContext(),"Removed"+viewHolder.getAdapterPosition(),Toast.LENGTH_LONG).show();
final int position = viewHolder.getAdapterPosition();
recordingsAdapter.notifyItemRemoved(position);
File file= new File(getExternalCacheDir() +"/"+ USER_MIX_DIR);
file=new File(file.getAbsolutePath(),"/Recording" + String.valueOf(position-1) + ".txt");
file.delete();
}
};
ItemTouchHelper itemTouchHelper = new ItemTouchHelper(simpleItemTouchCallback);
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_my_recordings);
for(int i=0;i<5;i++){
try{
userRecordingFile = new File(createRecordingFiles(), "Recording"+i+".txt");
FileWriter writer = new FileWriter(userRecordingFile);
writer.append("DEF"+i+"__HIJ "+i+"__\n");
// writer.append("R.drawable.ic_launcher\nDEF"+i+"\nHIJ "+i);
writer.flush();
writer.close();
}
catch (Exception e){
e.printStackTrace();
}
}
getSupportActionBar().hide();
recordingArrayList=new ArrayList<>();
recyclerView=findViewById(R.id.recyclerView);
recyclerView.setLayoutManager(new LinearLayoutManager(getApplicationContext()));
recyclerView.setHasFixedSize(true);
itemTouchHelper.attachToRecyclerView(recyclerView);
readFiles();
recordingArrayList.clear();
// if(arrayList.get(0)!=null && arrayList.get(1)!=null){
recordingArrayList.add(new Recording(R.drawable.ic_launcher,arrayList.get(0),arrayList.get(1)));
//}
// if(arrayList.get(2)!=null && arrayList.get(3)!=null){
recordingArrayList.add(new Recording(R.drawable.ic_launcher,arrayList.get(2),arrayList.get(3)));
// }
// if(arrayList.get(4)!=null && arrayList.get(5)!=null){
recordingArrayList.add(new Recording(R.drawable.ic_launcher,arrayList.get(4),arrayList.get(5)));
//}
//if(arrayList.get(6)!=null && arrayList.get(7)!=null){
recordingArrayList.add(new Recording(R.drawable.ic_launcher,arrayList.get(6),arrayList.get(7)));
//}
//if(arrayList.get(8)!=null && arrayList.get(9)!=null){
recordingArrayList.add(new Recording(R.drawable.ic_launcher,arrayList.get(8),arrayList.get(9)));
//}
recordingsAdapter=new RecordingsAdapter(recordingArrayList);
recyclerView.setAdapter(recordingsAdapter);
}
public File createRecordingFiles() {
File dirRoot = getExternalCacheDir();
File workDir = new File(dirRoot, USER_MIX_DIR);
Log.i("Hello", "createRecordingFiles: "+workDir);
if (!workDir.exists()) {
workDir.mkdirs();
}
return workDir;
}
public void readFiles(){
StringBuilder text = new StringBuilder();
BufferedReader br=null;
try {
File dirRoot = getExternalCacheDir();
File workDir = new File(dirRoot, USER_MIX_DIR);
for(int i=0;i<5;i++){
File file = new File(workDir,"Recording"+i+".txt");
br = new BufferedReader(new FileReader(file));
String line;
while ((line = br.readLine()) != null) {
text.append(line);
// text.append('\n');
arrayList=new ArrayList<>(Arrays.asList(text.toString().split("__")));
// Toast.makeText(this, ""+arrayList.size(), Toast.LENGTH_SHORT).show();
}
}
br.close() ;
}catch (IOException e) {
e.printStackTrace();
}
}
}
任何帮助都将不胜感激。
如果您不从附加到适配器的列表中删除该项目,调用Adapter.notifyItemRemoved(x)
将不会执行任何操作。
final int position = viewHolder.getAdapterPosition();
recordingArrayList.remove(position);
recordingsAdapter.notifyItemRemoved(position);
我有一个recyclerview,我用itemtouchhelper类给它添加了swipe,它工作得很好,在布局中有两个视图,前台视图在bacjground层上滑动,问题是我希望前台视图在滑动后获得上一个位置,就像在三星手机中进行呼叫的滑动效果一样。我可以在刷卡后拨打notifyitemchanged来实现这一点。但我只工作了一次,如果我再次在该项上滑动,视图不会恢复,这是我的itemtouchh
我有一个RecyclerView,这些物品应该在刷卡后移除。我用ItemTouchHelper类解决了这个问题。在onchildraw方法中,我设置了一个红色背景,在列表项后面滑动时出现。最重要的是,在正确的网站上有一个垃圾图标。它工作正常,但是如果你开始刷卡,但不刷卡到底,然后又刷卡回到正常位置,垃圾桶的图标不会消失。但是,它只有在我滑动所选项目时才会消失,而不是在普通项目上。 下面是ItemT
我有一个显示位图的水平循环视图。它的实现方式是在它下面有一个Imageview和一个recyclerview。当前选定的项目将显示在图像视图上。为选定的图像视图提供蓝色背景,以指示其已选定。我可以从“多媒体资料”中选择图像,每次选择新图像时,我都希望滚动到最后一个位置并选中该项目。 图像列表保存在数组列表中,每次添加新图像时,我都会将图像添加到列表并notifyDataChanged()。 当前,
删除项目后,“我的回收器”视图未更新。此recyclerView位于片段内部。我试过各种方法,但都不管用。 片段类中的适配器声明 回收服务适配器: } 调试项目时,我可以看到该项实际上正在从ArrayList中删除。但不在循环视图中更新。 删除后,如果滚动回收站视图,则从回收站视图中删除已删除的项。但不是没有滚动。
是否有一种方法可以在一次刷卡中实现一次只刷一张卡来解除颤振动作?
这是不是意味着我没有刷新我的适配器还是什么? @重写公共void onDeleteClick(int position){FoodInfo selectedItem; 食物适配器 } 这是我删除项目后的删除方法,它仍然存在于我的回收视图中,并在firebase中消失 我必须离开这个页面并再次访问,然后它只显示与firebase完全相同的项目 有人帮忙吗?