gpt4 book ai didi

安卓导航 View : reduce space between icon and text and `itemBackground` not working

转载 作者:塔克拉玛干 更新时间:2023-11-01 21:49:08 25 4
gpt4 key购买 nike

在使用菜单 xml 构建 NavigationView 时,有没有办法减少图标和文本之间的空间?

我尝试使用 app:itemTextAppearance 属性向 android:drawablePadding 发送文本,但这不起作用,我尝试设置填充和边距,但没有任何效果有效。

此外,当我设置 app:itemBackground 并设置选中状态时,整个菜单项没有突出显示,我得到如下图所示的内容。

enter image description here

用于创建 itemBackground 的 xml 是:

<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true" android:drawable="@color/white_alpha_10" />
<item android:state_checked="true" android:drawable="@color/white_alpha_10" />
<item android:state_focused="true" android:drawable="@color/white_alpha_10" />
<item android:state_activated="true" android:drawable="@color/white_alpha_10" />
<item android:drawable="@android:color/transparent" />
</selector>

知道会发生什么吗?很明显菜单项上有背景颜色,但是菜单 xml 是非常标准的。

NavigationView 背后的紫色背景是根据主题设置的:

<!--Activity xml -->
<android.support.design.widget.NavigationView
android:id="@+id/nav_view"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
android:layout_gravity="start"
app:theme="@style/AppTheme.NavigationView"
app:menu="@menu/menu_nav_drawer"
app:itemBackground="@drawable/nav_drawer_item"
app:headerLayout="@layout/nav_header"/>

<!-- styles.xml -->
<style name="AppTheme.NavigationView" parent="Widget.Design.NavigationView">
<item name="android:background">@color/charcoal_new</item>
<item name="itemIconTint">@color/nav_drawer_icon</item>
<item name="android:listDivider">@color/dusk_alpha_50</item>
<item name="itemTextAppearance">@style/NavigationViewTextAppearance</item>
</style>

<style name="NavigationViewTextAppearance" parent="TextAppearance.Body.Regular">
<item name="android:textColor">@color/white</item>
<item name="android:padding">0dp</item>
<item name="android:layout_margin">0dp</item>
</style>

我正在使用 Android 支持/设计库 23.2.1。

最佳答案

在挖掘源代码之后。我发现您可以覆盖维度资源来解决此问题。

<dimen tools:override="true" name="design_navigation_icon_padding">16dp</dimen>

请注意,这会改变所有地方的维度资源!您也可以复制布局文件并覆盖它 design_navigation_menu.xml

至于不同颜色的边,我设置app:itemBackground="@android:color/transparent"然后在 NavigationView 集的主题中:

<item name="selectableItemBackground">@drawable/nav_drawer_item_selector</item>

您可以在 NavigationView 的主题中处理这两个问题,如下所示:

    <item name="selectableItemBackground">@drawable/nav_drawer_item_selector</item>
<item name="itemBackground">@color/transparent</item>

nav_drawer_item_selector.xml 看起来像这样:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true" android:drawable="@color/white_alpha_10" />
<item android:state_checked="true" android:drawable="@color/white_alpha_10" />
<item android:state_focused="true" android:drawable="@color/white_alpha_10" />
<item android:state_activated="true" android:drawable="@color/white_alpha_10" />
<item android:drawable="@color/transparent" />
</selector>

关于安卓导航 View : reduce space between icon and text and `itemBackground` not working,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36397268/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com