Friday, September 25, 2020

android kotlin - NumberPicker text color

MainActivity.kt

package com.example.jetpack

import android.graphics.Color
import android.graphics.Paint
import android.os.Bundle
import android.util.Log
import android.widget.EditText
import android.widget.NumberPicker
import androidx.appcompat.app.AppCompatActivity
import kotlinx.android.synthetic.main.activity_main.*


class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        // set number picker minimum and maximum value
        numberPicker.minValue = 0
        numberPicker.maxValue = 10

        // set number picker text color to red
        if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.Q) {
            numberPicker.textColor = Color.RED
        }else{
            numberPicker.changeTextColor(Color.RED)
        }
    }
}


// extension function to set number picker text color
fun NumberPicker.changeTextColor(color: Int) {
    try {
        val selectorWheelPaintField = javaClass
            .getDeclaredField("mSelectorWheelPaint")
        selectorWheelPaintField.isAccessible = true
        (selectorWheelPaintField[this] as Paint).color = color
    } catch (e: NoSuchFieldException) {
        Log.d("exception", e.message.toString())
    } catch (e: IllegalAccessException) {
        Log.d("exception", e.message.toString())
    } catch (e: IllegalArgumentException) {
        Log.d("exception", e.message.toString())
    }
    val count = childCount
    for (i in 0 until count) {
        val child = getChildAt(i)
        if (child is EditText) child.setTextColor(color)
    }
    invalidate()
}
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:id="@+id/constraintLayout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#FEFEFA"
    tools:context=".MainActivity">

    <NumberPicker
        android:id="@+id/numberPicker"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="32dp"
        android:descendantFocusability="blocksDescendants"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

</androidx.constraintlayout.widget.ConstraintLayout>