컴퓨터/이론: 안드로이드
[2018.07.08] 105. Viewstub 개념과 실습
heepie
2018. 7. 8. 14:32
도입
이번 포스팅에서는 Viewstub의 개념에 대해 정리하고 실습할 예정이다.
개념
(출처 - https://developer.android.com/reference/android/view/ViewStub)
"lazily inflate" 런타임에 layout inflate해 resource를 효율적으로 사용할 수 있다.
실습
Step1. Main Xml 설정
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" tools:context=".MainActivity"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Hello World" android:layout_gravity="center" android:padding="4dp" /> <ViewStub android:id="@+id/view_stub" android:layout="@layout/inflated_view" android:layout_width="match_parent" android:layout_height="match_parent" /> </LinearLayout> | cs |
Step2. inflate될 View Xml 설정
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | <?xml version="1.0" encoding="utf-8"?> <android.support.v7.widget.CardView xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" android:layout_height="wrap_content" android:layout_width="match_parent" android:layout_margin="4dp" app:cardElevation="10dp"> <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" app:srcCompat="@mipmap/ic_launcher_round" /> <TextView android:id="@+id/tv_real" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:text="This is inflated View" /> <Button android:id="@+id/btn_close" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:text="Close" /> </LinearLayout> </android.support.v7.widget.CardView> | cs |
Step3. MainActivity에서 inflate 및 다양한 설정
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | private fun initView() { val rootView = view_stub.inflate() // 여기서 rootView는 cardView // view_stub.visibility = View.VISIBLE // 이렇게 inflate가 가능하지만 그렇다면 rootView를 가져 올 수 없다. val lp = LinearLayout.LayoutParams( LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT ) lp.gravity = Gravity.CENTER rootView.layoutParams = lp rootView.btn_close.setOnClickListener { rootView.visibility = View.GONE } } | cs |
(view attribute 우선순위 - http://heepie.tistory.com/313)
여기서 추가적으로 알 수 있는 것은 LayoutParams 설정은 Code에서 가능하고 xml값이 code 설정값으로 대체 된다.
(사실 당연한 것이고 Code에서 값은 runtime에 적용되기 때문에 당연한 것이다.)
스크린 샷
#viewstub #viewstub 개념