Skip to content

Latest commit

 

History

History
448 lines (350 loc) · 18.5 KB

README_EN.md

File metadata and controls

448 lines (350 loc) · 18.5 KB

CalenderView

An elegant, highly customized and high-performance Calendar Widget on Android is perfect for supporting WeekView, supporting tags, customizing colors, lunar calendar, etc., and multi-functional MonthView display. Canvas draw is fast, low in memory and simple in customization. It can achieve any custom layout and custom UI, and support shrink expansion. The performance is very efficient. This widget has obvious advantages of memory and efficiency, adapt to many scenes, and support multi colored calendar business. You really can't imagine that calendars can be so elegant. Please see more reference usage Demo, Demo achieved 4 exquisite custom effects.

Gradle

compile 'com.haibin:calendarview:3.4.0'
<dependency>
  <groupId>com.haibin</groupId>
  <artifactId>calendarview</artifactId>
  <version>3.4.0</version>
  <type>pom</type>
</dependency>

List some of the commonly used questions to support

  • Does it support the weekend colors alone? Support, you need to customize MonthView, WeekView, using Calendar.isWeekend() API to judge whether or not to use the corresponding brush for the weekend.
  • Does it support linkage with other widget? Support, if you like the quick date skip of other widget, you can also use similar widget by invoking API CalendarView.scrollToCalendar(), scrollPre() and scrollNext() etc..
  • Does it support the length of the date? Support, long click to the callback you can do something like sound, vibration effects, this widget does not provide, is not conducive to decoupling.
  • Does it support the use of pictures as a click effect? Support, but you need to be able to use api Canvas.drawBitmap().
  • Does it support grid display? Of course, it's supported. It depends on how you draw it.
  • Does it support custom week start?Yes,You can use mon、sun、sat for CalendarView by using week_start_with attr.
  • Does it support to callback WeekBar with date select? Support, you need to customize WeekBar, Override onDateSelected(Calendar calendar,int weekStart, Boolean isClick);
  • Therefore, as long as it is UI appearing in MonthView and WeekView, like pentagram, Bessel curve, picture and so on, are all supported, as long as you can draw, Weather it is beautiful or not, it depends on you.

proguard-rules

-keepclasseswithmembers class * {
    public <init>(android.content.Context);
}

or using this proguard-rules

-keep class your project path.MonthView {
    public <init>(android.content.Context);
}
-keep class your project path.WeekBar {
    public <init>(android.content.Context);
}
-keep class your project path.WeekView {
    public <init>(android.content.Context);
}

If you want to use the English version, it means you don't need to use the lunar calendar, customize MonthView and WeekView, and refer to Demo.

Effect preview

Function List

     

     

     

     

     

     

     

In particular, please replace with your custom path.

app:month_view="com.haibin.calendarviewproject.simple.SimpleCalendarCardView"
app:week_view="com.haibin.calendarviewproject.simple.SimpleWeekView"
app:week_bar_view="com.haibin.calendarviewproject.EnglishWeekBar"

usage

 <com.haibin.calendarview.CalendarLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        app:default_status="shrink"
        app:calendar_show_mode="only_week_view"
        app:calendar_content_view_id="@+id/recyclerView">

        <com.haibin.calendarview.CalendarView
             android:id="@+id/calendarView"
             android:layout_width="match_parent"
             android:layout_height="wrap_content"
             android:background="#fff"
             app:month_view="com.haibin.calendarviewproject.simple.SimpleCalendarCardView"
             app:week_view="com.haibin.calendarviewproject.simple.SimpleWeekView"
             app:week_bar_view="com.haibin.calendarviewproject.EnglishWeekBar"
             app:calendar_height="50dp"
             app:current_month_text_color="#333333"
             app:current_month_lunar_text_color="#CFCFCF"
             app:min_year="2004"
             app:other_month_text_color="#e1e1e1"
             app:scheme_text=""
             app:scheme_text_color="#333"
             app:scheme_theme_color="#333"
             app:selected_text_color="#fff"
             app:selected_theme_color="#333"
             app:week_background="#fff"
             app:month_view_show_mode="mode_only_current"
             app:week_text_color="#111" />

        <android.support.v7.widget.RecyclerView
            android:id="@+id/recyclerView"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:background="#d4d4d4" />
    </com.haibin.calendarview.CalendarLayout>

CalendarView attrs

<declare-styleable name="CalendarView">

        <attr name="calendar_padding" format="dimension" /><!--month and week view left and right padding-->

        <attr name="month_view" format="color" /> <!--Custom class MonthView path-->
        <attr name="week_view" format="string" /> <!--Custom WeekView path-->
        <attr name="week_bar_height" format="dimension" /> <!--WeekBar height-->
        <attr name="week_bar_view" format="color" /> <!--Custom class WeekBar path, invalid by custom week_text_color week_background XML settings, when still Java API settings can still be set-->

        <attr name="week_line_background" format="color" /><!--line color-->
        <attr name="week_background" format="color" /> <!--WeekBar background-->
        <attr name="week_text_color" format="color" /> <!--WeekBar textColor-->
              <attr name="week_text_size" format="dimension" /><!--WeekBar textSize-->

        <attr name="current_day_text_color" format="color" /> <!--today textColor-->
        <attr name="current_day_lunar_text_color" format="color" /><!--today lunarTextColo-->
  
        <attr name="calendar_height" format="string" /> <!--MonthView item height default 56dp-->
        <attr name="day_text_size" format="string" /> <!--day textSize-->
        <attr name="lunar_text_size" format="string" /> <!--lunar textSize-->

        <attr name="scheme_text" format="string" /> <!--scheme text-->
        <attr name="scheme_text_color" format="color" /> <!--scheme Color-->
        <attr name="scheme_month_text_color" format="color" /> <!--scheme calendar textColor-->
        <attr name="scheme_lunar_text_color" format="color" /> <!--scheme calendar lunarTextColor-->

        <attr name="scheme_theme_color" format="color" /> <!--scheme theme color-->

        <attr name="selected_theme_color" format="color" /> <!--selected theme color-->
        <attr name="selected_text_color" format="color" /> <!--selected textColor-->
        <attr name="selected_lunar_text_color" format="color" /> <!--selected lunarTextColor-->

        <attr name="current_month_text_color" format="color" /> <!--current month textColor-->
        <attr name="other_month_text_color" format="color" /> <!--other month textColor-->

        <attr name="current_month_lunar_text_color" format="color" /> <!--current month lunar textColor-->
        <attr name="other_month_lunar_text_color" format="color" /> <!--other month lunar textColor-->

        <!-- YearView attr -->
        <attr name="year_view_month_text_size" format="dimension" /> <!-- YearView month textSize-->
        <attr name="year_view_day_text_size" format="dimension" /> <!-- YearView day textSize -->
        <attr name="year_view_month_text_color" format="color" /> <!-- YearView month textColor -->
        <attr name="year_view_day_text_color" format="color" /> <!-- YearView day textColor -->
        <attr name="year_view_scheme_color" format="color" /> <!-- YearView scheme textColor -->

        <attr name="min_year" format="integer" />  <!--min year as 1900-->
        <attr name="max_year" format="integer" /> <!--max year as 2099-->
        <attr name="min_year_month" format="integer" /> <!--min month of min year-->
        <attr name="max_year_month" format="integer" /> <!--max month of max year-->
        
        <!--month_view_scrollable-->
        <attr name="month_view_scrollable" format="boolean" />
        <!--week_view_scrollable-->
        <attr name="week_view_scrollable" format="boolean" />
        <!--year_view_scrollable-->
        <attr name="year_view_scrollable" format="boolean" />

        <!--month_view_show_mode-->
        <attr name="month_view_show_mode">
             <enum name="mode_all" value="0" /> <!--show all month-->
             <enum name="mode_only_current" value="1" /> <!--show only current month-->
             <enum name="mode_fix" value="2" /> <!--auto fix,like mode_only_current,but auto filling-->
        </attr>

        <!-- week_start_with -->
        <attr name="week_start_with">
             <enum name="sun" value="1" />
             <enum name="mon" value="2" />
             <enum name="sat" value="7" />
        </attr>

        <!-- select_mode -->
        <attr name="select_mode">
              <enum name="default_mode" value="0" />
              <enum name="single_mode" value="1" />
        </attr>
</declare-styleable>

CalendarView api

public void setRange(int minYear, int minYearMonth, int maxYear, int maxYearMonth);//date range

public int getCurDay(); //get today
public int getCurMonth(); //get currentMonth
public int getCurYear(); //get currentYear

public boolean isYearSelectLayoutVisible();//is yearViewSelectedLayout visible?
public void closeYearSelectLayout();//close yearViewSelectedLayout
public void showYearSelectLayout(final int year); //show yearViewSelectedLayout

public void setOnMonthChangeListener(OnMonthChangeListener listener);//month change listener

public void setOnYearChangeListener(OnYearChangeListener listener);//year change listener

public void setOnDateSelectedListener(OnDateSelectedListener listener);//date selected listener

public void setOnDateLongClickListener(OnDateLongClickListener listener);//date long click listener


@Deprecated
public void setSchemeDate(List<Calendar> mSchemeDate);//mark dates

/**
  * mark dates
  * when mSchemeDatesMap.size()>10000?,use this
  * key=Calendar.toString();
  * best performance
  *
  * @param mSchemeDates mSchemeDatesMap 通过自己的需求转换即可
*/
public void setSchemeDate(Map<String, Calendar> mSchemeDates);//mark dates


public void update();//update change

public Calendar getSelectedCalendar(); //get current selected calendar

/**
 * In particular, if you need to customize or use other selectors, you can use the following methods to interact with the calendar.
 */
public void scrollToCurrent();

public void scrollToCurrent(boolean smoothScroll);

public void scrollToYear(int year);

public void scrollToYear(int year,boolean smoothScroll);

public void scrollToPre();

public void scrollToPre(boolean smoothScroll);

public void scrollToNext();

public void scrollToNext(boolean smoothScroll);

public void scrollToCalendar(int year, int month, int day);

public void scrollToCalendar(int year, int month, int day,boolean smoothScroll);

/**
  * setBackground
  *
  * @param yearLayoutBackground yearSelectLayout
  * @param weekBackground        WeekBar
  * @param lineBg                Line
 */
public void setBackground(int yearLayoutBackground, int weekBackground, int lineBg)

/**
  * setTextColor
  *
  * @param curMonthTextColor curMonthTextColor
  * @param otherMonthColor   otherMonthColor
  * @param lunarTextColor    lunarTextColor
 */
public void setTextColor(int curMonthTextColor,int otherMonthColor,int lunarTextColor)




/**
  * setWeeColor
  *
  * @param weekBackground 背景色
  * @param weekTextColor  字体颜色
 */
public void setWeeColor(int weekBackground, int weekTextColor)

CalendarLayout api

public void expand(); //expand

public void shrink(); //shrink

public boolean isExpand();//isExpand

CalendarLayout attrs

<!-- calendar_show_mode -->
<attr name="calendar_show_mode">
      <enum name="both_month_week_view" value="0" /><!-- default -->
      <enum name="only_week_view" value="1" /><!-- only week view -->
      <enum name="only_month_view" value="2" /><!-- only month view -->
</attr>

<attr name="default_status">
      <enum name="expand" value="0" /> <!--expand-->
      <enum name="shrink" value="1" /><!--shrink-->
</attr>
<attr name="calendar_content_view_id" format="integer" /><!--calendar_content_view_id-->

If you need to fully customize the UI, refer to the demo, a few steps can be done to draw the effect you need. The MonthView and WeekView need to be replaced at the same time to achieve UI consistency.

First draw the MonthView

public class SimpleCalendarCardView extends MonthView {

    private int mRadius;

    public SimpleCalendarCardView(Context context) {
        super(context);
    }

    @Override
    protected void onPreviewHook() {
        mRadius = Math.min(mItemWidth, mItemHeight) / 5 * 2;
        mSchemePaint.setStyle(Paint.Style.STROKE);
    }

    @Override
    protected void onLoopStart(int x, int y) {

    }

    @Override
    protected boolean onDrawSelected(Canvas canvas, Calendar calendar, int x, int y, boolean hasScheme) {
        int cx = x + mItemWidth / 2;
        int cy = y + mItemHeight / 2;
        canvas.drawCircle(cx, cy, mRadius, mSelectedPaint);
        return false;
    }

    @Override
    protected void onDrawScheme(Canvas canvas, Calendar calendar, int x, int y) {
        int cx = x + mItemWidth / 2;
        int cy = y + mItemHeight / 2;
        canvas.drawCircle(cx, cy, mRadius, mSchemePaint);
    }

    @Override
    protected void onDrawText(Canvas canvas, Calendar calendar, int x, int y, boolean hasScheme, boolean isSelected) {
        float baselineY = mTextBaseLine + y;
        int cx = x + mItemWidth / 2;
        if (hasScheme) {
            canvas.drawText(String.valueOf(calendar.getDay()),
                    cx,
                    baselineY,
                    calendar.isCurrentDay() ? mCurDayTextPaint :
                            calendar.isCurrentMonth() ? mSchemeTextPaint : mOtherMonthTextPaint);

        } else {
            canvas.drawText(String.valueOf(calendar.getDay()), cx, baselineY,
                    calendar.isCurrentDay() ? mCurDayTextPaint :
                            calendar.isCurrentMonth() ? mCurMonthTextPaint : mOtherMonthTextPaint);
        }
    }
}

Second, draw the WeekView, the WeekView is almost the same, the only difference is that you do not need y, only one line, so you can copy the code directly, and then make y=0.

public class SimpleWeekView extends WeekView{
    private int mRadius;


    public SimpleWeekView(Context context) {
        super(context);
    }

    @Override
    protected void onPreviewHook() {
        mRadius = Math.min(mItemWidth, mItemHeight) / 5 * 2;
        mSchemePaint.setStyle(Paint.Style.STROKE);
    }

    @Override
    protected boolean onDrawSelected(Canvas canvas, Calendar calendar, int x, boolean hasScheme) {
        int cx = x + mItemWidth / 2;
        int cy =  mItemHeight / 2;
        canvas.drawCircle(cx, cy, mRadius, mSelectedPaint);
        return false
    }

    @Override
    protected void onDrawScheme(Canvas canvas, Calendar calendar, int x) {
        int cx = x + mItemWidth / 2;
        int cy = mItemHeight / 2;
        canvas.drawCircle(cx, cy, mRadius, mSchemePaint);
    }

    @Override
    protected void onDrawText(Canvas canvas, Calendar calendar, int x, boolean hasScheme, boolean isSelected) {
        float baselineY = mTextBaseLine ;
        int cx = x + mItemWidth / 2;
        if (hasScheme) {
            canvas.drawText(String.valueOf(calendar.getDay()),
                    cx,
                    baselineY,
                    calendar.isCurrentDay() ? mCurDayTextPaint :
                            calendar.isCurrentMonth() ? mSchemeTextPaint : mSchemeTextPaint);

        } else {
            canvas.drawText(String.valueOf(calendar.getDay()), cx, baselineY,
                    calendar.isCurrentDay() ? mCurDayTextPaint :
                            calendar.isCurrentMonth() ? mCurMonthTextPaint : mCurMonthTextPaint);
        }
    }
}

Licenses

  • Copyright (C) 2013 huanghaibin_dev [email protected]

  • Licensed under the Apache License, Version 2.0 (the "License");

  • you may not use this file except in compliance with the License.

  • You may obtain a copy of the License at

  •     http://www.apache.org/licenses/LICENSE-2.0
    
  • Unless required by applicable law or agreed to in writing, software

  • distributed under the License is distributed on an "AS IS" BASIS,

  • WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.

  • See the License for the specific language governing permissions and limitations under the License.