迁移到Androidx后SwitchCompat是白色的

问题描述 投票:0回答:1

我已经将我的项目迁移到

AndroidX
。我的
MainActivity
延伸
FragmentActivity
我的第一个
SwitchCompat
看起来全是白色的,当我第一次来到那个屏幕时它根本没有任何颜色。 SwitchCompat is white。它下面的所有其他 SwitchCompact 都具有正确的颜色。如果我按回键并再次回到那个屏幕,我的第一个
SwitchCompact
收到正确的颜色并且看起来很好。

如果我改变我的

MainActivty
扩展
AppCompactActivity
,那么当我第一次到达那个屏幕时一切正常。有谁知道这里的问题在哪里,因为在迁移之前我的
MainActivity
也扩展了
FragmentActivity
并且一切都很好。 我的
xml
代码在这两种情况下都是相同的:

    <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".BlankFragment">

    <androidx.appcompat.widget.SwitchCompat
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />

    <androidx.appcompat.widget.SwitchCompat
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
</LinearLayout>
android androidx switchcompat
1个回答
1
投票

我没有深究扩展FragmentActivity时为什么会出现这个问题。但是要在“SwitchCompat”的动作事件上显示适当的颜色可以通过使用自定义轨道和拇指来实现。

你的开关按钮

<androidx.appcompat.widget.SwitchCompat
            android:id="@+id/sw_autoplay"
            android:layout_width="44dp"
            android:layout_height="25dp"
            android:layout_alignParentEnd="true"
            android:layout_alignParentRight="true"
            android:layout_centerVertical="true"
            android:layout_marginEnd="10dp"
            android:layout_marginRight="10dp"
            android:paddingStart="4dp"
            android:paddingEnd="4dp"
            android:textOff=""
            android:textOn=""
            android:theme="@style/SwitchButtonTheme"
            android:thumb="@drawable/thumb"
            app:track="@drawable/track" />

拇指

<?xml version="1.0" encoding="utf-8"?>
 <selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_checked="false">
    <shape android:shape="oval">
        <solid android:color="#ffffff" />
        <size android:width="20dp" android:height="20dp" />
        <stroke android:width=".5dp" android:color="#A4A0A0" />
    </shape>
</item>
<item android:state_checked="true">
    <shape android:shape="oval">
        <solid android:color="#ffffff" />
        <size android:width="20dp" android:height="20dp" />
        <stroke android:width=".5dp" android:color="#57F47F" />
    </shape>
</item>
</selector>

轨道

<?xml version="1.0" encoding="utf-8"?>
 <selector xmlns:android="http://schemas.android.com/apk/res/android">
  <item android:state_checked="false">
    <shape android:shape="rectangle">
        <corners android:radius="20dp" />
        <solid android:color="#ffffff" />
        <stroke android:width=".3dp" android:color="#A4A0A0" />
        <size android:height="20dp" />
    </shape>
</item>
<item android:state_checked="true">
    <shape android:shape="rectangle">
        <corners android:radius="20dp" />
        <solid android:color="#57F47F" />
        <stroke android:width=".3dp" android:color="#A4A0A0" />
        <size android:height="20dp" />
    </shape>
</item>
</selector>

它只是为了当你想要你使用

FragmentActivity
.

© www.soinside.com 2019 - 2024. All rights reserved.