NavigationView - 设置“app:itemBackground”会导致菜单项丢失开始填充
NavigationView - Setting `app:itemBackground` causes menu items to lose start padding
我在为 NavigationView 设置 app:itemBackground
时遇到了一个问题 运行。我正在尝试为所选菜单项创建自定义背景。自定义背景有效,但当我使用它时,它似乎杀死了菜单项的开始填充。
无背景(默认)
使用自定义背景
您可以看到设置 itemBackground
后菜单项与菜单左侧齐平。
这是相关的 xml...
布局
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/DrawerLayout"
android:fitsSystemWindows="false">
<!-- your content layout -->
<include
layout="@layout/MainLayout" />
<android.support.design.widget.NavigationView
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
android:background="@color/primary_color"
android:id="@+id/NavigationView"
app:itemTextColor="?android:textColorPrimary"
app:headerLayout="@layout/navigationheaderlayout"
app:itemBackground="@drawable/navigation_item_selector"
app:menu="@menu/navigation_menu" />
</android.support.v4.widget.DrawerLayout>
选择器
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/navigation_item_selected_background" android:state_selected="true" />
<item android:drawable="@drawable/navigation_item_selected_background" android:state_pressed="true" />
<item android:drawable="@drawable/navigation_item_selected_background" android:state_checked="true" />
<item android:drawable="@drawable/navigation_item_not_selected_background" />
</selector>
已选择背景
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<item
android:left="0dp"
android:right="2dp"
android:drawable="@color/accent_color" />
<item
android:left="2dp"
android:right="2dp"
android:drawable="@color/navigation_selected_item_color" />
</layer-list>
未选择背景
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<shape android:shape="rectangle">
<solid android:color="@android:color/transparent" />
</shape>
</item>
</layer-list>
有没有人运行以前遇到过类似的事情?
请注意以下解决方案适用于棒棒糖之前的版本。但会在棒棒糖及以上添加额外的填充。请为不同的版本应用不同的主题以避免这种情况。
设置app:theme后,解决了padding left问题。
<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="false"
android:background="@drawable/your_menu_bg"
app:itemBackground="@drawable/your_menu_item_bg"
app:headerLayout="@layout/nav_header_main"
app:menu="@menu/activity_main_drawer"
app:theme="@style/NavigationDrawerStyle"
app:itemIconTint="@color/your_color"
app:itemTextColor="@android:color/white"
app:itemTextAppearance="?android:attr/textAppearanceLarge"/>
这是我的自定义主题。
<style name="NavigationDrawerStyle">
<item name="android:paddingLeft">20dp</item>
</style>
如何为不同的版本应用不同的主题?检查下面的另一个 link。
Change theme according to android version
为 Android 4 版本在可绘制对象中图层列表的 end 添加一个填充。
像这样:
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<item
android:left="0dp"
android:right="2dp"
android:drawable="@color/accent_color" />
<item
android:left="2dp"
android:right="2dp"
android:drawable="@color/navigation_selected_item_color" />
<item>
<shape android:shape="rectangle" >
<padding android:left="12dp" android:right="12dp"/>
</shape>
</item>
</layer-list>
我在为 NavigationView 设置 app:itemBackground
时遇到了一个问题 运行。我正在尝试为所选菜单项创建自定义背景。自定义背景有效,但当我使用它时,它似乎杀死了菜单项的开始填充。
无背景(默认)
使用自定义背景
您可以看到设置 itemBackground
后菜单项与菜单左侧齐平。
这是相关的 xml...
布局
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/DrawerLayout"
android:fitsSystemWindows="false">
<!-- your content layout -->
<include
layout="@layout/MainLayout" />
<android.support.design.widget.NavigationView
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
android:background="@color/primary_color"
android:id="@+id/NavigationView"
app:itemTextColor="?android:textColorPrimary"
app:headerLayout="@layout/navigationheaderlayout"
app:itemBackground="@drawable/navigation_item_selector"
app:menu="@menu/navigation_menu" />
</android.support.v4.widget.DrawerLayout>
选择器
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/navigation_item_selected_background" android:state_selected="true" />
<item android:drawable="@drawable/navigation_item_selected_background" android:state_pressed="true" />
<item android:drawable="@drawable/navigation_item_selected_background" android:state_checked="true" />
<item android:drawable="@drawable/navigation_item_not_selected_background" />
</selector>
已选择背景
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<item
android:left="0dp"
android:right="2dp"
android:drawable="@color/accent_color" />
<item
android:left="2dp"
android:right="2dp"
android:drawable="@color/navigation_selected_item_color" />
</layer-list>
未选择背景
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<shape android:shape="rectangle">
<solid android:color="@android:color/transparent" />
</shape>
</item>
</layer-list>
有没有人运行以前遇到过类似的事情?
请注意以下解决方案适用于棒棒糖之前的版本。但会在棒棒糖及以上添加额外的填充。请为不同的版本应用不同的主题以避免这种情况。
设置app:theme后,解决了padding left问题。
<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="false"
android:background="@drawable/your_menu_bg"
app:itemBackground="@drawable/your_menu_item_bg"
app:headerLayout="@layout/nav_header_main"
app:menu="@menu/activity_main_drawer"
app:theme="@style/NavigationDrawerStyle"
app:itemIconTint="@color/your_color"
app:itemTextColor="@android:color/white"
app:itemTextAppearance="?android:attr/textAppearanceLarge"/>
这是我的自定义主题。
<style name="NavigationDrawerStyle">
<item name="android:paddingLeft">20dp</item>
</style>
如何为不同的版本应用不同的主题?检查下面的另一个 link。
Change theme according to android version
为 Android 4 版本在可绘制对象中图层列表的 end 添加一个填充。
像这样:
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<item
android:left="0dp"
android:right="2dp"
android:drawable="@color/accent_color" />
<item
android:left="2dp"
android:right="2dp"
android:drawable="@color/navigation_selected_item_color" />
<item>
<shape android:shape="rectangle" >
<padding android:left="12dp" android:right="12dp"/>
</shape>
</item>
</layer-list>