Как я могу установить круглую форму ряби у TabLayout? - PullRequest
0 голосов
/ 19 апреля 2020

Я собираюсь установить круглую форму пульсации для вкладки tablayout. TabLayout связан с viewpager. Я попытался определить селектор XML и установить атрибут tabbackground tablayout с помощью селектора xml. Таким образом, это было установлено вокруг. Но проблема в том, что он работает после того, как я нажму на него первым. Так что это означает, что пульсация каждой вкладки не работает с первого клика. В чем причина? Спасибо.

Это мой код.

<com.google.android.material.tabs.TabLayout
        android:id="@+id/unit_categories"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginStart="16dp"
        android:layout_marginEnd="16dp"
        android:theme="@style/Theme.AppCompat.Light.NoActionBar"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:tabBackground="@drawable/unit_category_selector_tab_background"
        app:tabGravity="center"
        app:tabIndicator="@drawable/unit_category_tab_indicator"
        app:tabIndicatorFullWidth="true"
        app:tabIndicatorGravity="center"
        app:tabIndicatorHeight="40dp"
        app:tabMode="scrollable"
        app:tabRippleColor="@android:color/transparent"
        app:tabUnboundedRipple="false" />

Это unit_category_selector_tab_background. xml

<?xml version="1.0" encoding="utf-8"?>
<item android:state_pressed="true" android:state_selected="false" android:drawable="@drawable/unit_category_tab_ripple"/>
</selector>

Это unit_category_tab_ripple. xml

<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
    android:color="#9BB3B1">
    <item>
        <shape
            android:shape="rectangle"
            >
            <solid android:color="#FFFEFE" />
            <corners
                android:radius="40dp" />
        </shape>
    </item>
</ripple>
...