Я экспериментировал с упрощением кода навигационного ящика, используя новый класс NavigationView
в библиотеке поддержки дизайна Android, Он отлично работает, если вам нужны только значки слева и текст справа, как в примере в документации, но что, если я хочу добавить одно настраиваемое представление в макет с android.support.v7.widget.SwitchCompat
, как в Google Play Фильмы (см. Снимок экрана ниже)?
Я попытался использовать атрибут actionLayout
, чтобы указать собственный файл макета, как в приведенном ниже примере кода, однако этот атрибут, как представляется, игнорируется, поскольку он не работает.
res/menu/navigation_drawer.xml
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<group android:id="@+id/group1"
android:checkableBehavior="single">
<item
android:id="@+id/nav_screen1"
android:icon="@drawable/ic_list_black_24dp"
android:title="Screen 1" />
<item
android:id="@+id/nav_screen2"
android:icon="@drawable/ic_search_black_24dp"
android:title="Screen2"/>
</group>
<group android:id="@+id/group2">
<item
android:id="@+id/nav_custom"
android:icon="@drawable/custom_icon_24dp"
app:actionLayout="@layout/nav_drawer_switch"
android:title="Custom item with switch"/>
<item
android:id="@+id/nav_settings"
android:icon="@drawable/ic_settings_black_24dp"
android:title="Settings"/>
</group>
</menu>
res/layout/nav_drawer_switch.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="horizontal" android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v7.widget.SwitchCompat
android:layout_width="fill_parent"
android:layout_height="match_parent"
android:text="Custom item with switch"/>
</LinearLayout>
Как я могу заставить это работать? В идеале я хотел бы добавить пользовательский вид, все еще используя мой макет меню, но если это невозможно без использования грубого взлома (например, при вводе существующего макета, созданного библиотекой поддержки), я хотел бы знать, решение с наименьшим количеством кода и которое все еще делает целесообразным переход на NavigationView
.