NavigationView 的默认行为是一次选择一个项目;例如,这通常会在抽屉布局中选择一个片段。
正如 Mike M 在 cmets 中指出的那样;使项目可检查并不意味着它是CheckBox。
因此,您必须在菜单项中添加一个CheckBox,并且有两个选项可以做到这一点:
将CheckBox 用作app:actionViewClass:
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<group android:checkableBehavior="all">
<item
android:id="@+id/itemFoo1"
android:checkable="true"
app:actionViewClass="android.widget.CheckBox"
android:title="Foo1" />
<item
android:id="@+id/itemFoo2"
android:checkable="true"
app:actionViewClass="android.widget.CheckBox"
android:title="Foo2" />
</group>
</menu>
点击复选框将切换其状态,但点击项目文本不会;这可以通过获取 menuItem ActionView 并使用 setChecked() 切换 CheckBox 以编程方式解决:
private final NavigationView.OnNavigationItemSelectedListener navViewlistener = new NavigationView.OnNavigationItemSelectedListener() {
@Override
public boolean onNavigationItemSelected(MenuItem item) {
int id = item.getItemId();
if (id == R.id.itemFoo1 || id == R.id.itemFoo2) {
CheckBox actionView = (CheckBox) item.getActionView();
actionView.setChecked(!actionView.isChecked()); // Toggle the CheckBox
}
return true;
}
};
navView.setNavigationItemSelectedListener(navViewlistener);
更新
我用了一段时间 app:actionViewClass="android.widget.CheckBox"。主要问题是复选框独立于项目。单击它不会触发NavigationItemSelectedListener。这就是我寻找新方法的主要原因。
这是对的;我们可以通过在选中/取消选中持有 CheckBox 时触发 MenuItem 点击事件以编程方式解决此问题。
但主要问题是,它可能导致无限循环;当我们选中/取消选中 onNavigationItemSelected 中的 CheckBox 时;这将触发另一个MenuItem 点击等等。
所以,这里是 mIsCheckBoxClick 布尔值,并且在调用 setChecked() 之前停止 CheckBox 侦听器,然后重新附加它们;所有这些都是为了避免循环:
private boolean mIsCheckBoxClick;
@Override
protected void onCreate(Bundle savedInstanceState) {
// ....... add your code
// Enable CheckBox listeners at the NavView menu items by default
addFooListeners(navView, true);
}
private void addFooListeners(final NavigationView navView, boolean enabled) {
adjustNavViewItemListener(navView.getMenu().findItem(R.id.itemFoo1), navView, enabled);
adjustNavViewItemListener(navView.getMenu().findItem(R.id.itemFoo2), navView, enabled);
}
private void adjustNavViewItemListener(final MenuItem item, final NavigationView navView, boolean enabled) {
final CheckBox fooChBox = (CheckBox) item.getActionView();
CompoundButton.OnCheckedChangeListener listener = new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
mIsCheckBoxClick = true;
navView.getMenu().performIdentifierAction(item.getItemId(), 0); // perform a click on MenuItem to trigger OnNavigationItemSelectedListener
}
};
fooChBox.setOnCheckedChangeListener(enabled ? listener : null);
}
private final NavigationView.OnNavigationItemSelectedListener navViewlistener = new NavigationView.OnNavigationItemSelectedListener() {
@Override
public boolean onNavigationItemSelected(MenuItem item) {
int id = item.getItemId();
if (id == R.id.itemFoo1 || id == R.id.itemFoo2) {
// Loop prevention check
if (!mIsCheckBoxClick) {
CheckBox actionView = (CheckBox) item.getActionView();
// Stop the CheckBox listeners
addFooListeners(navView, false);
actionView.setChecked(!actionView.isChecked());
// Reattach the CheckBox listeners
addFooListeners(navView, true);
}
mIsCheckBoxClick = false;
}
return true;
}
};