【问题标题】:Ripple effect using itemBackground on NavigationView在 NavigationView 上使用 itemBackground 的波纹效果
【发布时间】:2015-06-10 14:04:13
【问题描述】:

我想知道是否有人在使用app:itemBackground" 重新定义 NavigationView 上的项目背景时遇到问题?我得到了屏幕截图中显示的行为,无论我按什么项目,最后一个项目都会显示波纹。

这是我的drawer_menu.xml

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">

    <group android:checkableBehavior="single" android:id="@+id/first_group">
        <item
            android:id="@+id/nav_home"
            android:icon="@drawable/ic_home"
            android:title="@string/nav_home" />
    </group>

    <group android:id="@+id/second_group">
        <item
            android:id="@+id/nav_settings"
            android:title="@string/nav_settings" />
        <item
            android:id="@+id/nav_about"
            android:title="@string/nav_about" />
        <item
            android:id="@+id/nav_logout"
            android:title="@string/nav_logout" />
    </group>

</menu>

我的my_ripple.xml

<ripple xmlns:android="http://schemas.android.com/apk/res/android"
        android:color="#ffff0000">
    <item
        android:id="@android:id/mask"
        android:drawable="@android:color/white" />
</ripple>

我的导航视图:

<android.support.design.widget.NavigationView
    android:id="@+id/navigation_view"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:layout_gravity="start"
    android:background="@android:color/white"
    app:headerLayout="@layout/drawer_header"
    app:itemBackground="@drawable/my_ripple"
    app:itemIconTint="@color/drawer_item"
    app:itemTextColor="@color/drawer_item"
    app:menu="@menu/drawer_menu" />

【问题讨论】:

  • 你能发布你的“菜单”文件吗?
  • @Javier 你有没有为 NavigationView 找到涟漪效果的解决方案?
  • 是的,现在可以正常使用 com.android.support:design:23.4.0
  • 您找到解决方案了吗?使用 com.android.support:design:23.4.0 问题依然存在...

标签: android navigation-drawer navigationview


【解决方案1】:

目前可能的解决方法 - 仅供寻找和以防万一的人使用....

在 onCreate 中为导航视图添加 addOnGlobalLayoutListener 并在每个菜单项上应用 Drawable。

/**
 * Contains the {@link MenuItem} views in the {@link NavigationView}
 */
private final ArrayList<View> mMenuItems = new ArrayList<>(5);

    // Grab the NavigationView Menu
    final Menu navMenu = mNavigationView.getMenu();
    mNavigationView.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
        @Override
        public void onGlobalLayout() {
            // Remember to remove the installed OnGlobalLayoutListener
            mNavigationView.getViewTreeObserver().removeOnGlobalLayoutListener(this);
            // Loop through and find each MenuItem View
            for (int i = 0, length = 5; i < length; i++) {
                final MenuItem item = navMenu.getItem(i);
                mNavigationView.findViewsWithText(mMenuItems, item.getTitle(), View.FIND_VIEWS_WITH_TEXT);
            }
            // Loop through each MenuItem View and apply your custom Typeface
            for (final View menuItem : mMenuItems) {
              //Create RippleDrawable called myRipple 
                ((TextView) menuItem).setBackground(myRipple);
            }
        }
    });

【讨论】:

  • 你从哪里得到'mMenuItems'?
【解决方案2】:

Ripple 可绘制对象应该像这个示例一样定义:

 <!-- A red ripple masked against an opaque rectangle. -->
 <ripple android:color="#ffff0000">
   <item android:id="@android:id/mask"
         android:drawable="@android:color/white" />
 </ripple>

阅读更多

https://developer.android.com/reference/android/graphics/drawable/RippleDrawable.html

【讨论】:

  • 糟糕,对不起!那正是我的代码,我复制错了,编辑了问题。
【解决方案3】:

itemBackground 属性应用于menu 而不是NavigationView。然后,波纹将保留在处理触摸事件的菜单项中。

【讨论】:

  • 在哪里应用它
  • @user3138859 - 将itemBackground 属性直接添加到menu 资源定义中。在示例中,此资源在 drawer_menu.xml 中定义。
猜你喜欢
  • 1970-01-01
  • 2017-05-12
  • 1970-01-01
  • 1970-01-01
  • 2016-01-23
  • 1970-01-01
  • 1970-01-01
  • 2015-01-12
  • 1970-01-01
相关资源
最近更新 更多