我正在构建像记事本应用程序之类的东西。其中一项功能是允许用户选择多个笔记并使用longclick一次删除它们以启动选择过程。到目前为止,一切运作良好,但没有选定项目的物理指示(背景颜色)。使用如下所示的getChildAt(position)
方法可以帮助我实现这一目标,但问题是当我向下滚动以显示初始屏幕中未包含的项目时(取决于显示的音符数量),颜色分配错位。例如,如果我向下滚动以在选择项目时显示屏幕中未包含的两个项目,如果我点击一个音符,它会被选中但背景颜色被设置为其下方两个位置的音符。如果我滚动显示3个音符等同样的情况,它们下方的音符(取决于滚动期间显示的音符数量)会获得颜色,而不是选定的音符。
任何帮助都会受到如此多的赞赏。我刚刚在我大学的当年读到Java之后就开始研究android平台了。我非常确定必须使用自定义适配器才能正常工作,但我试图尽可能简化这一点。 Beneath是我项目中的一个片段。
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_list_entries);
//SOME CODES HERE
final ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, theNamesOfFiles);
entriesView = (ListView) findViewById(R.id.listEntriesView);
entriesView.setAdapter(adapter);
entriesView.setOnItemClickListener(this);
entriesView.setChoiceMode(ListView.CHOICE_MODE_MULTIPLE_MODAL);
entriesView.setMultiChoiceModeListener(new AbsListView.MultiChoiceModeListener() {
@Override
public boolean onCreateActionMode(ActionMode mode, Menu menu) {
MenuInflater inflater = mode.getMenuInflater();
inflater.inflate(R.menu.context_menu, menu);
return true;
}
@Override
public void onItemCheckedStateChanged(ActionMode mode, int position, long id, boolean checked) {
String a = entriesView.getItemAtPosition(position).toString();
//This if statement is necessary because should the user de-selects an item, the system should remove it from the arraylist so they don't get passed to the delete method
if (selectedMenuItems.contains(a)) {
int b = selectedMenuItems.indexOf(a);
selectedMenuItems.remove(b);
itemSelectedCount = selectedMenuItems.size();
mode.setTitle(itemSelectedCount + " Item(s) Selected");
View view = entriesView.getChildAt(position);
view.setBackgroundColor(Color.TRANSPARENT);
}
else {
selectedMenuItems.add(entriesView.getItemAtPosition(position).toString());
itemSelectedCount = selectedMenuItems.size();
mode.setTitle(itemSelectedCount + " Item(s) Selected");
// entriesView.getChildAt(position).setBackgroundColor(Color.LTGRAY);
View view = entriesView.getChildAt(position);
view.setBackgroundColor(Color.LTGRAY);
}
mode.invalidate();
}
@Override
public boolean onActionItemClicked(ActionMode mode, MenuItem item) {
int id = item.getItemId();
switch (id) {
case(R.id.delete_menu_button):
deleteMethod();
selectedMenuItems.clear();
mode.finish();
break;
case(R.id.edit_menu_button1):
callEditActiity();
selectedMenuItems.clear();
mode.finish();
break;
default:
return false;
}
return true;
}
@Override
public boolean onPrepareActionMode(ActionMode mode, Menu menu) {
if (itemSelectedCount == 1){
MenuItem item = menu.findItem(R.id.edit_menu_button1);
item.setVisible(true);
return true;
} else {
MenuItem item = menu.findItem(R.id.edit_menu_button1);
item.setVisible(false);
return true;
}
}
@Override
public void onDestroyActionMode(ActionMode mode) {
selectedMenuItems.clear();
}
});
}
活动的XML文件
<ListView
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:id="@+id/listEntriesView">
</ListView>
答案 0 :(得分:0)
您需要制作自定义适配器并在项目中记住已选中的状态。或者,您可以使用SparseBooleanArray来记住已检查项目的位置,当您为视图充气时,检查是否已选中该项目/位置并根据此设置背景。
请参阅我的其他帖子here以获得类似的解决方案。