티스토리 뷰
카테고리 없음
[Android Studio] XML 레이아웃 파일 화면 표시 방법(XML layout resource ID / XML inflation)
그뇨 2024. 12. 15. 04:42XML 레이아웃 파일 화면 표시 방법
XML layout resource ID | XML inflation | |
역할 | · Activity의 기본 화면 레이아웃을 설정하는 데 사용. | · XML 레이아웃을 View 객체로 변환하여 View를 동적으로 추가하거나 수정 가능. |
용도 | · Activity의 화면 구성을 설정할 때 사용. 보통 Activity의 onCreate() 메서드에서 호출. |
· 특정 XML 레이아웃을 View로 만들어 필요한 위치에 추가하거나, View의 세부적인 설정을 변경할 때 사용. · Activity, Fragment, Adapter 등 다양한 곳에서 사용 |
특징 | · Activity에서 호출해야 함. · 레이아웃 전체를 설정하므로, View의 계층 구조를 변경하거나 세부적인 제어는 어려움. |
· 특정 레이아웃을 동적으로 생성. · View를 커스터마이징하거나 재사용 가능. · Fragment나 RecyclerView Adapter와 같은 경우에 유용. |
XML 레이아웃 파일 화면 표시
1. XML layout resource ID
- Activity 전체 레이아웃을 설정하는 메서드.
setContentView(R.layout.activity_main);
2. XML inflation
- 특정 레이아웃을 View로 변환하는 메서드.
LayoutInflater i = (LayoutInflater)getSystemService(LAYOUT_INFLATER_SERVICE);
View v = i.inflate(R.layout.activity_main, null); // null: 부모 뷰 없음
setContentView(v);
LayoutInflater i = LayoutInflater.from(this);
View v = i.inflate(R.layout.activity_main, null); // null: 부모 뷰 없음
setContentView(v);
LayoutInflater i = getLayoutInflater();
View v = i.inflate(R.layout.activity_main, null); // null: 부모 뷰 없음
setContentView(v);
setContentView(getLayoutInflater().inflate(R.layout.activity_main, null));
동적 화면 변경 (no XML)
MainActivity.java
package com.example.test;
import android.os.Bundle;
import android.widget.CheckBox;
import android.widget.CompoundButton;
import android.widget.LinearLayout;
import android.widget.RadioButton;
import android.widget.RadioGroup;
import androidx.appcompat.app.AppCompatActivity;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
LinearLayout l = new LinearLayout(this);
l.setOrientation(LinearLayout.VERTICAL);
l.setPadding(50,50,50,50);
CheckBox c = new CheckBox(this);
c.setText("정보 수집 동의");
l.addView(c);
setContentView(l);
RadioGroup r = new RadioGroup(this);
r.setOrientation(LinearLayout.HORIZONTAL);
RadioButton r1 = new RadioButton(this);
RadioButton r2 = new RadioButton(this);
r1.setText("한번만"); r2.setText("항상");
r.addView(r1); r.addView(r2);
r1.setChecked(true);
c.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton compoundButton, boolean b) {
if(c.isChecked()) l.addView(r);
else l.removeView(r);
}
});
}
}
동적 화면 변경 (Layout XML, XML inflater 사용)
activity_main.xml
<?xml version="1.0" encoding="utf-8" ?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/l"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:padding="30dp">
<CheckBox
android:id="@+id/c"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="정보 수집 동의" />
</LinearLayout>
activity_second.xml
<?xml version="1.0" encoding="utf-8" ?>
<RadioGroup xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/r"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal">
<RadioButton
android:id="@+id/r1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="한번만" />
<RadioButton
android:id="@+id/r2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="항상" />
</RadioGroup>
MainActivity.java
package com.example.test;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.widget.CheckBox;
import android.widget.LinearLayout;
import android.widget.RadioButton;
import android.widget.RadioGroup;
import androidx.appcompat.app.AppCompatActivity;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
LinearLayout l = findViewById(R.id.l);
LayoutInflater i = getLayoutInflater();
RadioGroup r = (RadioGroup)i.inflate(R.layout.activity_second, null);
RadioButton r1 = r.findViewById(R.id.r1);
CheckBox c = findViewById(R.id.c);
c.setOnCheckedChangeListener((a, b) -> {
if(c.isChecked()) l.addView(r);
else l.removeView(r);
});
}
}
동적 화면 변경 (Layout XML, visibility 설정)
activity_main.xml
- visibility 설정 가능 값:
- invisible: 공간은 차지하고 있으나 보이지 않음.
- gone: 공간을 차지하지 않으면서 보이지도 않음.
- visible: 보이게 설정
<?xml version="1.0" encoding="utf-8" ?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/l"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:padding="30dp">
<CheckBox
android:id="@+id/c"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="정보 수집 동의" />
<RadioGroup
android:id="@+id/r"
android:visibility="invisible"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal">
<RadioButton
android:id="@+id/r1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="한번만" />
<RadioButton
android:id="@+id/r2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="항상" />
</RadioGroup>
</LinearLayout>
MainActivity.java
package com.example.test;
import android.os.Bundle;
import android.view.View;
import android.widget.CheckBox;
import android.widget.RadioButton;
import android.widget.RadioGroup;
import androidx.appcompat.app.AppCompatActivity;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
RadioGroup r = findViewById(R.id.r);
RadioButton r1 = findViewById(R.id.r1);
r1.setChecked(true);
CheckBox c = findViewById(R.id.c);
c.setOnCheckedChangeListener((a, b)-> {
if(c.isChecked()) r.setVisibility(View.VISIBLE);
else r.setVisibility(View.GONE);
});
}
}
공지사항
링크