티스토리 뷰

XML 레이아웃 파일 화면 표시 방법

  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);
            }
        });
    }
}

동적 화면 변경 (no XML) 실행 화면


동적 화면 변경 (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, XML inflater 사용) 실행 화면

 


동적 화면 변경 (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);
        });
    }
}

동적 화면 변경 (Layout XML, visibility 설정) 실행 화면

공지사항
링크