我的问题可能最好用视觉方式询问 - 我想要一个SwitchCompat
开关来查看他们在Android设置应用中的行为:
关闭:
这是:
但出于某种原因,我的SwitchCompat
开关在关闭时看起来像这样:
没有灰色"轨道"延伸到右侧。但是,当打开时,它看起来像预期的那样:
如您所见,我已将自定义色调应用于我的应用程序。我的自定义色调应用如下:
<activity
android:name=".editor.MySettingsEditor"
android:theme="@style/Theme.MyCustomTheme" />
然后,在styles.xml中:
<style name="Theme.MyCustomTheme" parent="Theme.AppCompat">
<item name="colorAccent">@color/myColorAccent</item>
<item name="colorPrimary">@color/myColorPrimary</item>
<item name="colorPrimaryDark">@color/myColorPrimaryDark</item>
<item name="alertDialogTheme">@style/AppCompatAlertDialogStyle</item>
</style>
为确保不是我的自定义样式导致此问题,我通过执行以下操作将其删除:
<activity
android:name=".editor.MySettingsEditor"
android:theme="@style/Theme.AppCompat" />
但是,&#34; off&#34;轨迹不显示,但色调颜色现在变为Android默认蓝绿色。
为什么我的SwitchCompat
开关在处于关闭状态时会丢失灰色轨道?
描述SwitchCompat的XML非常简单:
<android.support.v7.widget.SwitchCompat
android:id="@+id/checkbox"
android:layout_width="wrap_content"
android:layout_height="fill_parent"
android:layout_weight="1"/>
谢谢!
答案 0 :(得分:5)
您可以通过为活动颜色设置colorControlActivated
而为非活动颜色设置colorSwitchThumbNormal
来应用自定义色调。如果您想更改曲目颜色,则可以设置android:colorForeground
<style name="CustomSwitch" parent="Theme.AppCompat">
<!-- active thumb-->
<item name="colorControlActivated">@color/active_switch_color</item>
<!-- inactive thumb-->
<item name="colorSwitchThumbNormal">@color/inactive_switch_color</item>
<!-- inactive track color -->
<item name="android:colorForeground">@color/inactive_track_color</item>
</style>
如果您想直接在视图中设置自定义主题:
<android.support.v7.widget.SwitchCompat
android:id="@+id/checkbox"
android:layout_width="wrap_content"
android:layout_height="fill_parent"
android:layout_weight="1"
android:theme="@style/CustomSwitch"/>
答案 1 :(得分:1)
@esilver如果你想动态处理它们,也许是更好的方法
试试这个...我已经测试过,它的工作非常好
public class MainActivity extends AppCompatActivity {
int[][] states = new int[][] {
new int[] {-android.R.attr.state_checked},
new int[] {android.R.attr.state_checked},
};
int[] thumbColors = new int[] {
Color.BLACK,
Color.RED,
};
int[] trackColors = new int[] {
Color.GREEN,
Color.BLUE,
};
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
SwitchCompat switchCompat = (SwitchCompat) findViewById(R.id.switch);
DrawableCompat.setTintList(DrawableCompat.wrap(switchCompat.getThumbDrawable()), new ColorStateList(states, thumbColors));
DrawableCompat.setTintList(DrawableCompat.wrap(switchCompat.getTrackDrawable()), new ColorStateList(states, trackColors));
}
}
您只需要更新&#34; trackColors&#34;和#34; thumbColor&#34;根据您的要求/需求。