MainActivity.kt
package com.cfsuman.kotlintutorials
import android.app.Activity
import android.content.res.Resources
import android.graphics.Color
import android.graphics.drawable.ColorDrawable
import android.os.Bundle
import android.widget.NumberPicker
class MainActivity : Activity() {
private lateinit var numberPicker:NumberPicker
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
// get the widgets reference from XML layout
numberPicker = findViewById(R.id.numberPicker)
// set number picker minimum and maximum value
numberPicker.minValue = 0
numberPicker.maxValue = 10
// set number picker divider color for api level up to 28
if (android.os.Build.VERSION.SDK_INT <
android.os.Build.VERSION_CODES.Q) {
numberPicker.setDividerColor(Color.RED)
}
}
}
// extension function to set number picker
// divider color for api level up to 28
fun NumberPicker.setDividerColor(color: Int) {
val pickerFields = NumberPicker::class.java.declaredFields
for (pf in pickerFields) {
if (pf.name == "mSelectionDivider") {
pf.isAccessible = true
try {
val colorDrawable = ColorDrawable(color)
pf[this] = colorDrawable
} catch (e: java.lang.IllegalArgumentException) {
e.printStackTrace()
} catch (e: Resources.NotFoundException) {
e.printStackTrace()
} catch (e: IllegalAccessException) {
e.printStackTrace()
}
break
}
}
}
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#DCDCDC"
android:padding="32dp">
<!--
NumberPicker divider color for api level 29 and up
android:theme="@style/NumberPickerTheme"
-->
<NumberPicker
android:id="@+id/numberPicker"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="32dp"
android:descendantFocusability="blocksDescendants"
android:theme="@style/NumberPickerTheme"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
res/values/styles.xml
<resources>
<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.MaterialComponents.Light">
<!-- Customize your theme here. -->
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
</style>
<style name="NumberPickerTheme" parent="AppTheme">
<!-- NumberPicker divider color -->
<item name="colorControlNormal">#ff0000</item>
</style>
</resources>
- android kotlin - Volley image request
- android kotlin - Volley string request
- android kotlin - Chip center text
- android kotlin - Chip checked color programmatically
- android kotlin - ChipGroup get selected chips
- android kotlin - ChipGroup add chip programmatically
- android kotlin - ChipGroup single selection
- android kotlin - NumberPicker string values
- android kotlin - NumberPicker divider height
- android kotlin - NumberPicker remove divider
- android kotlin - Get screen size programmatically
- android kotlin - RecyclerView animation
- android kotlin - RecyclerView smooth scroll
- android kotlin - TextView get width height programmatically
- android kotlin - TextView html formatted text