Android/Kotlin
[Kotlin] DataBinding
혀가 길지 않은 개발자
2020. 7. 9. 00:00
build.gradle (Module: app)
android {
dataBinding {
enabled = true
}
}
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<layout>
<data>
<variable
name="mainActivity"
type="com.jwsoft.kotlinproject.MainActivity" />
</data>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:gravity="center"
tools:context=".MainActivity">
<TextView
android:id="@+id/txtView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@{mainActivity.str}"
android:textSize="30dp"
android:textStyle="bold"
android:textAlignment="center"
android:hint="버튼 클릭 전" />
<Button
android:id="@+id/btnRed"
android:layout_width="150dp"
android:layout_height="wrap_content"
android:text="Red"
android:textSize="20dp"
android:textAllCaps="false" />
<Button
android:id="@+id/btnGreen"
android:layout_width="150dp"
android:layout_height="wrap_content"
android:text="Green"
android:textSize="20dp"
android:textAllCaps="false" />
</LinearLayout>
</layout>
MainActivity.kt
package com.jwsoft.kotlinproject
import android.graphics.Color
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import androidx.databinding.DataBindingUtil
import com.jwsoft.kotlinproject.databinding.ActivityMainBinding
class MainActivity : AppCompatActivity() {
private lateinit var binding: ActivityMainBinding
var str: String = "혀가 길지 않은 개발자"
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
binding = DataBindingUtil.setContentView(this, R.layout.activity_main)
binding.mainActivity = this
binding.lifecycleOwner = this
binding.btnRed.setOnClickListener {
binding.txtView.setTextColor(Color.parseColor("#FFBBBB"))
binding.invalidateAll()
}
binding.btnGreen.setOnClickListener {
binding.txtView.setTextColor(Color.parseColor("#BBFFBB"))
binding.invalidateAll()
}
}
}