Nesse tutorial vou descrever Como utilizar o CalendarView em Kotlin para pegar uma data logo após ter clicado nela e imprimi-la em uma nova activity.
Então para começar vamos criar um projeto vazio(Empty) e depois vamos criar mais uma activity com seu respectivo layout, vou chamar esta activity de RespActivity.
Logo após criar a activity vamos começar a programar, deixe os códigos como o seguinte.
Então em nossa activity_main vamos colocar o CalendarView como descrito no código a seguir.
<?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">
<CalendarView
android:id="@+id/calendar"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintEnd_toEndOf="parent"/>
</androidx.constraintlayout.widget.ConstraintLayout>
Então essa é a parte onde podemos pegar a data quando é modificada, para isso foi utilizado um setOnDateChangeListener que serve para esperar a data ser modificada e assim envia as variáveis da mudança para a função que faz com que abra uma nova activity enviando os dados do dia, mês e ano que foi clicado.
package br.com.uware.calendarview
import android.content.Intent
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import kotlinx.android.synthetic.main.activity_main.*
import android.widget.CalendarView
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
calendar.setOnDateChangeListener(CalendarView.OnDateChangeListener { view, year, month, dayOfMonth ->
val intent = Intent(this, RespActivity::class.java)
intent.putExtra("dia",dayOfMonth)
intent.putExtra("mes",month)
intent.putExtra("ano",year)
startActivity(intent)
})
}
}
Em nossa RespActivity vai conter apenas um TextView para que assim possamos receber o valor passado por nossa MainActivity e vamos imprimir este valor na tela com os seguintes códigos.
package br.com.uware.calendarview
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import kotlinx.android.synthetic.main.activity_resp.*
class RespActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_resp)
val dia = intent.getIntExtra("dia", 0)
val mes = intent.getIntExtra("mes", 0)
val ano = intent.getIntExtra("ano",0)
tvResp.text = dia.toString()+"/"+mes.toString()+"/"+ano.toString()
}
}
<?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=".RespActivity">
<TextView
android:id="@+id/tvResp"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Teste"
android:textSize="28sp"
android:gravity="center"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintBottom_toBottomOf="parent"/>
</androidx.constraintlayout.widget.ConstraintLayout>
Assim espero ter ajudado a utilizar o CalendarView.
Veja também Como utilizar uma WebView com Kotlin.
Visite nosso canal no YouTube e nos siga para assim ajudar o canal a crescer.
Tags:
CalendarView Kotlin TutorialPosts relacionados: