替换导航视图项波纹效果

Bry*_*yan 3 android android-drawable navigation-drawer android-navigationview android-jetpack

我试图替换我认为是NavigationView. 所以我创建了一个 drawable 来替换背景并使用itemBackground属性应用它。

background_navigation_view_item.xml

<ripple xmlns:android="http://schemas.android.com/apk/res/android"
    android:color="@color/navigation_item_background_tint">
    <item android:id="@android:id/mask" android:top="4dp" android:bottom="4dp" android:left="8dp" android:right="8dp">
        <shape android:shape="rectangle">
            <solid android:color="@android:color/white"/>
            <corners android:radius="3dp"/>
        </shape>
    </item>
    <item android:top="4dp" android:bottom="4dp" android:left="8dp" android:right="8dp">
        <selector>
            <item android:state_checked="true">
                <shape android:shape="rectangle">
                    <solid android:color="@color/navigation_item_background_tint"/>
                    <corners android:radius="3dp"/>
                </shape>
            </item>
            <item>
                <shape android:shape="rectangle">
                    <solid android:color="@android:color/transparent"/>
                    <corners android:radius="3dp"/>
                </shape>
            </item>
        </selector>
    </item>
</ripple>
Run Code Online (Sandbox Code Playgroud)

当项目被选中时,项目背景可绘制看起来很棒(“选择控件”是下图中的选定项目)。但被点击该项目时(“进度指标”下文)看来该默认波纹绘制两者所述background_navigation_view_item.xml可绘制正在使用(仅一个圆角矩形应该显示,而不是周围的矩形)。

导航视图波纹效果

我还测试了 drawable 作为可检查视图的背景,它的工作方式符合我的预期。因此,如果我的可绘制对象的代码中没有错误,为什么不替换原始背景可绘制对象?

小智 5

我已经在这里回答了这个问题

注意: 此代码只是去除了背景默认波纹的不透明度

无论如何,我会在这里再次回答。

假设您的 NavigationView 代码是:

<com.google.android.material.navigation.NavigationView
android:id="@+id/navigation_view"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="start"
app:menu="@menu/your_menu"
app:itemBackground="@drawable/background_navigation_view_item.xml"/>
Run Code Online (Sandbox Code Playgroud)

我所做的是,向 NavigationView 添加如下主题属性:

android:theme="@style/NavigationItemNoRipple"
Run Code Online (Sandbox Code Playgroud)

styles.xml中:

<style name="NavigationItemNoRipple">
    <item name="android:colorControlHighlight">@android:color/transparent</item>
</style>
Run Code Online (Sandbox Code Playgroud)