微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

禁用日期的不同颜色CalendarView

如何解决禁用日期的不同颜色CalendarView

我创建了一个自定义CalendarView,如下所示:

enter image description here

我希望过去的所有日子都保持不同的颜色。

我的XML是:

<CalendarView
    android:id="@+id/cv_Calendar"
    android:layout_width="match_parent"
    android:layout_height="300dp"
    android:layout_marginStart="16dp"
    android:layout_marginEnd="16dp"
    android:background="@drawable/cv_background"
    android:dateTextAppearance="@style/CalenderViewDateCustomText"
    android:theme="@style/CalenderViewCustom"
    android:weekDayTextAppearance="@style/CalenderViewWeekCustomText"
    app:layout_constraintTop_toBottomOf="@+id/tv_With" />

我的风格是:

<style name="CalenderViewCustom" parent="Theme.AppCompat">
    <item name="colorAccent">@color/colorLightGray</item>
    <item name="colorPrimary">@color/colorLightPurple</item>
    <item name="android:textColorPrimary">@color/colorGrayText</item>
</style>

<style name="CalenderViewDateCustomText" parent="android:TextAppearance.Holo.Small">
    <item name="android:textColor">@color/colorLightPurple</item>
    <item name="android:weekNumberColor">@color/colorLightPurple</item>
</style>

<style name="CalenderViewWeekCustomText" parent="android:TextAppearance.DeviceDefault.Small">
    <item name="android:textColor">@color/colorLightPurple</item>
</style>

我以编程方式设置了最小日期:

calendarView = findViewById( R.id.cv_Calendar );
calendarView.setMinDate( System.currentTimeMillis() );
calendarView.setonDatechangelistener( (arg0,year,month,date) -> {
    GregorianCalendar cal = new GregorianCalendar( year,date );
    dateInMillis = cal.getTimeInMillis();
} );

有什么办法改变颜色吗?

谢谢

解决方法

我不确定您是否还需要回答这个问题,但如果其他人遇到这个问题,请按以下方法操作:

基本上,您需要更改用于引用选择器的 textColor 属性,该属性应如下所示:

selectorDateTextColor.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
        
    <!-- The color used by the disabled dates (i.e. everything outside the range you set with minDate and maxDate) -->
    <item android:color="@color/gray" android:state_enabled="false" />
    
    <!-- The color used by everything else -->
    <item android:color="@color/colorLightPurple" />
</selector>

你的风格是:

<style name="CalenderViewDateCustomText" parent="android:TextAppearance.Holo.Small">
    <item name="android:textColor">@color/selectorDateTextColor</item>
    <item name="android:weekNumberColor">@color/colorLightPurple</item>
</style>

您还可以添加更多状态,例如 android:state_activated="true" 以更改用户所选日期的文本颜色。

如果您想更改所选日期周围圆圈的颜色,您应该将 <item name="colorControlActivated">@color/blue</item> 添加到您的 CalendarView 使用的主题中。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。