상세 컨텐츠

본문 제목

[안드로이드 코틀린] LiveData 만드는 방법 part2 - 레이아웃에 ViewModel 직접 적용

안드로이드

by aries574 2022. 6. 5. 11:11

본문


이번 시간에는 이전 포스팅에 이어서 레이아웃에 직접 LiveData을 적용하는 방법에 대하여 알아보겠습니다.

이전 포스팅은 아래 링크를 들어가시면 됩니다. 

2022.06.04 - [안드로이드] - [안드로이드 코틀린] LiveData 만드는 방법 part1 - 실시간 데이터 변경

 

[안드로이드 코틀린] LiveData 만드는 방법 part1 - 실시간 데이터 변경

이번 시간에는 이전 포스팅에 이어서 데이터 변경 시 동적으로 화면의 값도 변경되는 방법에 대하여 알아보겠습니다. 이전 포스팅은 아래 링크를 들어가시면 됩니다. 2022.06.03 - [안드로이드] - [

aries574.tistory.com


목차

1. 실행 화면
2. 메인 화면 수정 activity_main.xml
3. 메인 코드 수정 MainActivity.kt


1. 실행 화면


2. 메인 화면 수정 activity_main.xml

 - 설명 - 

 1. data태그로 감싼 variable 태그를 통해 변수를 선언합니다.

 2. 텍스트뷰에는 score변수를 연결

 3. 버튼에는 각 함수를 연결합니다. 

<?xml version="1.0" encoding="utf-8"?>
<layout 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">

    <data>
        <variable
            name="myVar"
            type="com.kwon.kotlintutorial.MainViewModel" />
    </data>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        tools:context=".MainActivity">

        <Button
            android:id="@+id/plus_btn"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1"
            android:text="더하기"
            android:onClick="@{()->myVar.scorePlus()}"
            android:textSize="25sp"/>

        <TextView
            android:id="@+id/score_text"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="8"
            android:gravity="center"
            android:text="@{myVar.score.toString()}"
            android:textSize="150sp"/>

        <Button
            android:id="@+id/minus_btn"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1"
            android:text="빼기"
            android:onClick="@{()->myVar.scoreMinus()}"
            android:textSize="25sp"/>

    </LinearLayout>
</layout>

 


3. 메인 코드 수정 MainActivity.kt

 - 설명 - 

 1. binding.lifecycleOwner = this

 생명주기 소유자 지정을 해야

  LiveData가 작동합니다.

2.  binding.myVar = mainViewModel

  레이아웃에 선언한 변수에 viewModel

  적용합니다.

3. 레이아웃에 직접 LiveData를 적용했기

 때문에 버튼 이벤트는 필요 없어졌습니다. 

class MainActivity : AppCompatActivity() {

    private lateinit var binding: ActivityMainBinding

    //뷰모델 선언
    private lateinit var mainViewModel: MainViewModel

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

        //binding 초기화
        binding = DataBindingUtil.setContentView(this, R.layout.activity_main)

        //뷰모델 초기화
        mainViewModel = ViewModelProvider(this).get(MainViewModel:: class.java)

        //생명주기 셋팅
        binding.lifecycleOwner = this

        //변수에 viewModel 초기화
        binding.myVar = mainViewModel
    }
}

2022.05.19 - [안드로이드] - [안드로이드 코틀린] 변수 생성 및 변수 타입 만드는 방법

 

[안드로이드 코틀린] 변수 생성 및 변수 타입 만드는 방법

 이번 시간에는 코틀린에서 변수 생성 및 변수 만드는 방법에 대하여 알아보겠습니다. 목차 1. 실행 화면 2. 메인 화면 구성 activity_main.xml 3. 메인 코드 구현 MainActivity.java 1. 실행 화면..

aries574.tistory.com

2022.05.20 - [안드로이드] - [안드로이드 코틀린] 배열 쉽게 만드는 방법

 

[안드로이드 코틀린] 배열 쉽게 만드는 방법

 이번 시간에는 코틀린에서 배열 만드는 방법에 대하여 알아보겠습니다. ​목차 1. 실행 화면 2. 메인 화면 구성 activity_main.xml 3. 메인 코드 구현 MainActivity.java 1. 실행 화면 2. 메인 ..

aries574.tistory.com

2022.05.21 - [안드로이드] - [안드로이드 코틀린] 반복문 For 만드는 다양한 방법

 

[안드로이드 코틀린] 반복문 For 만드는 다양한 방법

 이번 시간에는 코틀린에서 반복문으로 쓰이는 For문을 다양하게 만드는 방법에 대하여 알아보겠습니다. 목차 1. 실행 화면 2. 메인 화면 구성 activity_main.xml 3. 메인 코드 구현 MainActivity.jav

aries574.tistory.com

 

반응형

관련글 더보기

댓글 영역