NavigationView:使用APP:ActionLayout自定义项目布局如何?
根据最近Ian Lake的帖子
如果你最近没有看过NavigationView,它实际上是 版本23.1.0[1]中有相当大的更新,增加了 App:ActionLayout支持自定义视图。
如何在NavigationView中使用app:actionLayout
?
使用
<group android:checkableBehavior="single">
<item
android:id="@+id/navigation_drawer_item_1"
android:icon="@drawable/ic_menu_1"
android:title="@string/navigation_drawer_item_1"
app:actionLayout="@layout/menu_test_1"
/>
<item
android:id="@+id/navigation_drawer_item_2"
android:icon="@drawable/ic_menu_2"
android:title="@string/navigation_drawer_item_2"
app:actionLayout="@layout/menu_test_1"
/>
</group>
与
<android.support.design.widget.NavigationView android:id="@+id/nav_view"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
android:fitsSystemWindows="true"
app:headerLayout="@layout/nav_header_main"
app:menu="@menu/activity_main_drawer">
它不起作用。
它在项目的右侧显示了action Layout。
同时删除android:icon
和android:title
似乎不起作用。
我如何修复它?
谢谢 问候
解决方案
我通过删除android:TITLE中的所有文本解决了此问题。
NavigationView:
<android.support.design.widget.NavigationView
android:id="@+id/nav_view"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
android:fitsSystemWindows="true"
app:headerLayout="@layout/nav_header_main"
app:menu="@menu/activity_main_drawer" />
菜单编码(ACTIVATION_MAIN_DRAUER):
<?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="single">
<item android:id="@+id/nav_item1"
app:showAsAction="always"
android:title=""
app:actionLayout="@layout/menu_item_layout" />
</group>
</menu>
Menu_Item_Layout:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView android:id="@+id/item_text"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center_vertical"
android:text="Item text" />
</RelativeLayout>
相关文章