circle-menu
This is a view group in which you can pass list of menu items and those items will be drawn under circular path.
Sample Apk
https://github.com/alokverma/circle-menu/blob/main/app/apk/app-debug.apk
Demo
How to Use
To get a Git project into your build:
Step 1. Add the JitPack repository to your build file
gradle
Add it in your root build.gradle at the end of repositories:
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
Step 2. Add the dependency
dependencies {
implementation 'com.github.alokverma:circle-menu:1.1'
}
Code
<com.akki.circlemenu.CircleMenu
android:id="@+id/circle_menu"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:menu_background_color="@array/menu_back_colors"
app:menu_close_duration="300"
app:menu_icons="@array/menus"
app:menu_open_duration="400"
app:menu_orientation="circle"
app:menu_radius="100dp">
Attributes that you can use to customize this view group
app:menu_icons = arrays of vector/png menu items
app:menu_background_color = array of background tint for those menus
app:menu_open_duration = open animation duration of circle
app:menu_close_duration = close animation duration of circle
app:menu_radius= radius of circle
app:menu_orientation="circle|vertical"
In your activity/fragment, you can pass setOnMenuItemClickListener and you can get all menu item click event in onMenuItemClicked function.
CircleMenu.setOnMenuItemClickListener(this)
override fun onMenuItemClicked(id: Int) {
when (id) {
R.drawable.ic_baseline_delete_forever_24 -> showToast("Delete Button clicked")
R.drawable.ic_baseline_person_search_24 -> showToast("Person Button clicked")
R.drawable.ic_baseline_settings_24 -> showToast("Setting Button clicked")
R.drawable.ic_baseline_edit_location_24 -> showToast("Location Button clicked")
}
}