Events Calendar is a user-friendly library that helps you achieve a cool Calendar UI with events mapping. You can customise every pixel of the calendar as per your wish and still achieve in implementing all the functionalities of the native android calendar in addition with adding dots to the calendar which represents the presence of an event on the respective dates. Events Calendar also has multi-lingual support. You are just a few steps away from implementing your own badass looking Calendar for your very own project!
dependencies {
implementation 'com.github.tizisdeepan:eventscalendar:1.1.1'
}
allprojects {
repositories {
maven { url 'https://jitpack.io' }
}
}
<com.events.calendar.views.EventsCalendar
android:id="@+id/eventsCalendar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="#000000"
android:overScrollMode="never"
app:eventDotColor="#ff0000"
app:isBoldTextOnSelectionEnabled="true"
app:monthTitleColor="#ffffff"
app:primaryTextColor="#c4c4c4"
app:secondaryTextColor="#666666"
app:selectedTextColor="#000000"
app:selectionColor="#ffe600"
app:weekHeaderColor="#c6c6c6" />
class MainActivity : AppCompatActivity(), EventsCalendar.Callback {
...
override fun onMonthChanged(monthStartDate: Calendar?) {
Log.e("MON", "CHANGED")
}
override fun onDaySelected(selectedDate: Calendar?) {
Log.e("DAY", "SELECTED")
}
}
//set today's date [today: Calendar]
eventsCalendar.setToday(today)
//set starting month [start: Calendar] and ending month [end: Calendar]
eventsCalendar.setMonthRange(start, end)
//set start day of the week as you wish [startday: Int, doReset: Boolean]
eventsCalendar.setWeekStartDay(Calendar.SUNDAY, false)
//set current date and scrolls the calendar to the corresponding month of the selected date [today: Calendar]
eventsCalendar.setCurrentSelectedDate(today)
//set font for dates
eventsCalendar.setDatesTypeface(typeface)
//set font for title of the calendar
eventsCalendar.setMonthTitleTypeface(typeface)
//set font for week names
eventsCalendar.setWeekHeaderTypeface(typeface)
//set the callback for EventsCalendar
eventsCalendar.setCallback(this)
//set events on the EventsCalendar [c: Calendar]
eventsCalendar.addEvent(c)
//disable a specific day on the EventsCalendar [c: Calendar]
eventsCalendar.disableDate(dc)
//disable days in a week on the whole EventsCalendar [varargs days: Int]
eventsCalendar.disableDaysInWeek(Calendar.SATURDAY, Calendar.SUNDAY)
XML | Kotlin/Java | Description |
---|---|---|
app:primaryTextColor |
setPrimaryTextColor(color: Int) |
Primary Text color of the calendar (selectable dates) |
app:secondaryTextColor |
setSecondaryTextColor(color: Int) |
Secondary Text color of the calendar (disabled dates) |
app:selectedTextColor |
setSelectedTextColor(color: Int) |
Text color of the Selected date |
app:selectionColor |
setSelectionColor(color: Int) |
Color for the Selection Circle |
app:weekHeaderColor |
setWeekHeaderColor(color: Int) |
Text color for the Week Header labels |
app:monthTitleColor |
setMonthTitleColor(color: Int) |
Text color for the Month Title in the calendar view |
app:eventDotColor |
setEventDotColor(color: Int) |
Color for the Event Dots marked in the calendar view |
app:isBoldTextOnSelectionEnabled |
setIsBoldTextOnSelectionEnabled(isEnabled: Boolean) |
Sets whether the dates should be highlighted or not |
Voila! You have implemented an awesome Events Calendar for your Android Project now!