Sunday, February 16, 2020

android kotlin ktx - ClickableSpan example

MainActivity.kt

package com.example.jetpack

import android.content.Context
import android.os.Bundle
import android.text.method.LinkMovementMethod
import android.text.style.ClickableSpan
import android.view.View
import android.widget.Toast
import androidx.appcompat.app.AppCompatActivity
import androidx.core.text.set
import androidx.core.text.toSpannable
import kotlinx.android.synthetic.main.activity_main.*


class MainActivity : AppCompatActivity() {

    private lateinit var context:Context

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

        context = this

        val text = ("Lorem Ipsum is simply dummy text of the printing and" +
                " typesetting industry. Lorem Ipsum has been the industry's" +
                " standard dummy text ever since the 1500s, when an unknown" +
                " printer took a galley of type and scrambled it" +
                " to make a type specimen book.").toSpannable()


        // Set clickable span
        text[0..5] = object: ClickableSpan(){
            override fun onClick(view: View) {
                Toast.makeText(context, "Clicked: Lorem", Toast.LENGTH_LONG).show()
            }
        }

        // Another clickable span
        text[text.length-5 until text.length] = object: ClickableSpan(){
            override fun onClick(view: View) {
                Toast.makeText(context, "Clicked: book", Toast.LENGTH_LONG).show()
            }
        }

        // Make the text view text clickable
        textView.movementMethod = LinkMovementMethod()

        textView.text = text
    }
}
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"
    tools:context=".MainActivity">
    <TextView
        android:id="@+id/textView"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginStart="8dp"
        android:layout_marginTop="16dp"
        android:layout_marginEnd="8dp"
        android:padding="8dp"
        android:text=""
        android:textAppearance="@style/TextAppearance.AppCompat.Large"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
build.gradle dependencies[add]

// android ktx
implementation 'androidx.core:core-ktx:1.2.0'
build.gradle [add]

android {
    kotlinOptions {
        jvmTarget = JavaVersion.VERSION_1_8.toString()
    }
}
More android examples