Events Calendar
![]() | ![]() | ![]() |
| Single Selection Mode | Range Selection Mode | Multiple Selection Mode |
What is Events Calendar?
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!
What is Events
Calendar?
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!
Implementation
[1] In your app module gradle file
dependencies {
implementation 'com.github.tizisdeepan:eventscalendar:1.6.1'
}
[2] In your project level gradle file
allprojects {
repositories {
maven { url 'https://jitpack.io' }
}
}
[3] Use EventsCalendar in your layout.xml
<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:datesTextSize="16sp"
app:eventDotColor="#ff0000"
app:isBoldTextOnSelectionEnabled="true"
app:monthTitleColor="#ffffff"
app:monthTitleTextSize="16sp"
app:primaryTextColor="#c4c4c4"
app:secondaryTextColor="#666666"
app:selectedTextColor="#000000"
app:selectionColor="#ffe600"
app:weekHeaderColor="#c6c6c6"
app:rangeSelectionColor="#ffe600"
app:rangeSelectionStartColor="#c1ae01"
app:rangeSelectionEndColor="#c1ae01"
app:weekHeaderTextSize="16sp" />
[4] Implement EventCalendar.Callback on your
Activity/ Fragment
class MainActivity : AppCompatActivity(), EventsCalendar.Callback {
...
override fun onDayLongPressed(selectedDate: Calendar?) {
Log.e("LONG", "CLICKED")
}
override fun onMonthChanged(monthStartDate: Calendar?) {
Log.e("MON", "CHANGED")
}
override fun onDaySelected(selectedDate: Calendar?) {
Log.e("SHORT", "CLICKED")
}
}
[5] Create instances and set default values
for the EventsCalendar in your Activity/ Fragment
eventsCalendar.setSelectionMode(eventsCalendar.MULTIPLE_SELECTION) //set mode of Calendar
.setToday(today) //set today's date [today: Calendar]
.setMonthRange(start, end) //set starting month [start: Calendar] and ending
month [end: Calendar]
.setWeekStartDay(Calendar.SUNDAY, false) //set start day of the week as you wish [startday: Int, doReset:
Boolean]
.setCurrentSelectedDate(today) //set current date and scrolls the calendar to the
corresponding month of the selected date [today: Calendar]
.setDatesTypeface(typeface) //set font for dates
.setDateTextFontSize(16f) //set font size for dates
.setMonthTitleTypeface(typeface)
//set font
for title of the calendar
.setMonthTitleFontSize(16f) //set font size for title of the calendar
.setWeekHeaderTypeface(typeface) //set font for week names
.setWeekHeaderFontSize(16f) //set font size for week names
.setCallback(this) //set the callback for EventsCalendar
.addEvent(c)
//set
events on the EventsCalendar [c: Calendar]
.disableDate(dc) //disable a specific day on the EventsCalendar [c: Calendar]
.disableDaysInWeek(Calendar.SATURDAY, Calendar.SUNDAY) //disable days in a week on the whole EventsCalendar [varargs
days: Int]
.build()
[6] You can change selection mode of the
calendar as you wish
eventsCalendar.setSelectionMode(eventsCalendar.SINGLE_SELECTION)
Available
Selection modes are,
- SINGLE_SELECTION -> can select single day at a time
- RANGE_SELECTION -> can select range of days at a time
- MULTIPLE_SELECTION -> can select multiple days at a time (not
necessary that the selected days be consequtive)
Documentation
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:rangeSelectionColor
|
setRangeSelectionColor(color:
Int)
|
Color for the Selection
Background
|
app:rangeSelectionStartColor
|
setRangeSelectionStartColor(color:
Int)
|
Color for the Range Start
Selection Background
|
app:rangeSelectionEndColor
|
setRangeSelectionEndColor(color:
Int)
|
Color for the Range End
Selection Background
|
app:weekHeaderColor
|
setWeekHeaderColor(color:
Int)
|
Text color for the Week
Header labels
|
app:weekHeaderTextSize
|
setWeekHeaderFontSize(size:
Float)
|
Text size for the Week
Header labels
|
app:datesTextSize
|
setDateTextFontSize(size:
Float)
|
Text size for the Date labels
|
app:monthTitleColor
|
setMonthTitleColor(color:
Int)
|
Text color for the Month
Title in the calendar view
|
app:monthTitleTextSize
|
setMonthTitleFontSize(size:
Float)
|
Text size 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!
Developed By
- Deepan Elango - tizisdeepan@gmail.com


