레이아웃 중첩이란 말 그대로 레이아웃 안에 레이아웃을 넣는 방법을 말한다. 앞서 말했듯이 꼭 써야하는 경우에는 써야하지만 최대한 레이아웃은 최소화 하는것이 프로그램 퍼포먼스 상승에 도움이 된다는 것을 잊지말자.

 이제까지 배운 레이아웃들을 한데 모아 버튼을 누를때마다 페이지가바뀌는 프로그램을 만들어보자. 물론 진정한 의미로의 새로운 창을 메모리에 올리는 개념이 아니라(이 부분은 나중에 ACTIVITY 클래스에대해 자세히 배우게 될것이다.) 모든 레이아웃을 처음에 메모리에 올리지만 하나의 레이아웃만 Visibility를 "visible"로 고 나머지는 "invisible"로 설정하여 화면에만 안나타나게 하는 것이다. 이를 위해서 앞에서 FrameLayout에 대해 알아 보았었다. 

▧ 레이아웃이 정의된 frame.xml을 살펴보자. 

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:orientation="vertical"
  android:layout_width="fill_parent" android:layout_height="fill_parent">
<LinearLayout  xmlns:android="http://schemas.android.com/apk/res/android"
  android:orientation="horizontal"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content">
    <Button android:text="Page1" android:id="@+id/btnp1" 
    android:layout_width="wrap_content" android:layout_height="wrap_content" />
    <Button android:text="Page2" android:id="@+id/btnp2" 
    android:layout_width="wrap_content" android:layout_height="wrap_content" />
    <Button android:text="Page3" android:id="@+id/btnp3" 
    android:layout_width="wrap_content" android:layout_height="wrap_content" />
</LinearLayout>  

<FrameLayout android:layout_width="fill_parent" android:layout_height="fill_parent" >
<LinearLayout android:id="@+id/page1" android:layout_width="fill_parent" 
			  android:layout_height="fill_parent" 
	  		  android:background="#00ff00" android:orientation="vertical"	>
	<TextView  android:layout_width="fill_parent"  android:layout_height="wrap_content"
			   android:textColor="#000000" android:text="기본 아이콘이요~!" />
	<ImageView android:layout_height="wrap_content" android:src="@drawable/icon" 
			   android:id="@+id/img" android:layout_width="wrap_content"/>
</LinearLayout>

<RelativeLayout android:id="@+id/page2" android:visibility="invisible"
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="fill_parent" android:padding="5px"
  android:background="#ffffff"
  android:layout_height="wrap_content">
  
    <ImageView android:layout_height="wrap_content" android:src="@drawable/icon" 
    android:id="@+id/picture" android:layout_width="wrap_content"
    android:layout_alignParentLeft="true" android:layout_marginRight="5px" />
    
    <Button android:text="Del" android:id="@+id/button1" android:layout_below="@id/picture"
    android:layout_width="wrap_content" android:layout_height="wrap_content" />
    
    <TextView android:text="아폴로딸기맛" android:id="@+id/name" android:textColor="#000000"
    android:textSize="12pt" android:layout_alignParentTop="true" 
    android:layout_toRightOf="@id/picture" android:layout_width="wrap_content" 
    android:layout_height="wrap_content" />
    
    <TextView android:text="123-456-7890" android:id="@+id/call" android:textColor="#0000ff"
    android:textSize="6pt"  android:layout_alignParentRight="true"
    android:layout_alignBaseline="@id/name" android:layout_width="wrap_content"
    android:layout_height="wrap_content" />
     
    <TextView android:text="아폴로 딸기맛은 맛있다. 원래 몸에 안좋은게 맛있는거다." 
    android:id="@+id/description" android:textColor="#000000" 
    android:textSize="6pt" android:layout_below="@id/name"
    android:layout_alignLeft="@id/name" android:layout_width="wrap_content" 
    android:layout_height="wrap_content" />
</RelativeLayout>

<TableLayout android:id="@+id/page3"   android:orientation="vertical"
    android:layout_width="fill_parent" android:layout_height="fill_parent" 
    android:visibility="invisible" android:stretchColumns="1"
    >
    <TableRow>
    	<TextView android:text="국어" android:padding="3dip" />
    	<TextView android:text="영어" android:padding="3dip" 
    			  android:background="#fff"/>
    	<TextView android:text="수학" android:padding="3dip" />
    </TableRow>
    <TableRow>
    	<TextView android:text="90" android:padding="3dip" />
    	<TextView android:text="91" android:padding="3dip" />
    	<TextView android:text="92" android:padding="3dip" />
    </TableRow>
</TableLayout>
</FrameLayout>
</LinearLayout>

 위의 코드에서 역시 중요한 개념은 FrameLayout 내부의 View 객체들은 모두 왼쪽 상단에 겹쳐서 그려지기 때문에 Visibility가 모두 visible인 상태에서는 가장 먼저 생성된 3페이지만 보이게 될 것이다.(물론 페이지 객체 모두가 한 화면을 가득 채울정도로 크다면, 아니면 샌드위치를 위에서 처다본 것 처럼 될것이다.)

▧ 다음으로 자바 코드는 특별할게 없다. (역시 안드로이드를 하려면 어느정도 자바가 선행 되어야 할 것같다. ) 버튼에 대한 클릭 이벤트 처리만 해주면된다. 

package com.example.MultiPageAndroid;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;

public class MultiPageAndroid extends Activity {
	View mPage1, mPage2, mPage3;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.frame);
        mPage1 = findViewById(R.id.page1);
        mPage2 = findViewById(R.id.page2);
        mPage3 = findViewById(R.id.page3);
        findViewById(R.id.btnp1).setOnClickListener(mClickListener);
        findViewById(R.id.btnp2).setOnClickListener(mClickListener);
        findViewById(R.id.btnp3).setOnClickListener(mClickListener);
    }
    //anonymous class 선언.
    Button.OnClickListener mClickListener = new Button.OnClickListener(){
		@Override
		public void onClick(View v) {
			mPage1.setVisibility(View.INVISIBLE);
			mPage2.setVisibility(View.INVISIBLE);
			mPage3.setVisibility(View.INVISIBLE);
			
			switch(v.getId()){
			case R.id.btnp1 : mPage1.setVisibility(View.VISIBLE); break;
			case R.id.btnp2 : mPage2.setVisibility(View.VISIBLE); break;
			case R.id.btnp3 : mPage3.setVisibility(View.VISIBLE); break;
			}
		}
    };
}

 위의 코드에서 유심히 볼 것은 xml내부의 속성을 자바 코드로도 접근할 수 있다는 것이다. 다음 시간에 더 자세히 알아 보기로 하고, 출력 결과를 살펴보자. 
  1. 정상적인 출력결과.
    1페이지 2페이지 3페이지

     

     

      
  2. 위에서 잠깐 언급했는데 모든 페이지의 속성을 visible로 주었을 때 출력결과를 살펴보았다.


  3. 정말로 샌드위치가 되어서 출력되었다. 1page는 2page에 가려서 배경색만 나오고있고, 3page는 배경색이 없는 부분은 2page의 내용과 겹쳐서보이고 배경색이있는 영어 부분으로 3page가 가장 위에있다는 것을 확인 할 수 있다.


  이상 Multipage 예제로 android의 layout에 대해 알아보았다.

'Programming > ANDROID' 카테고리의 다른 글

eclipse (Helios)에서 android 개발 코딩 속도 버그 수정  (2) 2011.04.06
setContentView 에 대한 고찰..  (6) 2011.03.30
ViewGroup - RelativeLayout  (2) 2011.03.29
ViewGroup - TableLayout  (1) 2011.03.29
ViewGroup - FrameLayout  (1) 2011.03.28
  1. LinearLayout은 수직(vertical)방향과 수평(horizontal)방향으로 뷰 객체들을 나열하는 레이아웃이다.
    android:orientation="vertical android:orientation="horizontal
     

     

     
    여기서 중요한것은 한 방향으로 계속 객체들을 추가하여 화면을 벗어나게 될 경우 자동으로 다음줄에 나온다거나 하지않고 그저 화면밖에 그려지기 때문에 실행 했을 때 역시 화면에 나오지 않게된다. 
     
  2. 위에서 뷰 객체를 버튼을 사용하였는데 객체마다 가지고있는 속성에대해서도 간단히 알아보자.
    <TextView android:text="딸기맛" 
    android:textSize="20pt" android:textStyle="bold"
    android:textColor="#ff0000" android:background="#ffffff"
    android:id="@+id/textView1" android:layout_width="fill_parent" 
    android:layout_height="wrap_content"></TextView>

    위에서 중요것은 android:layout_width="fill_parent"로 상위 View의 크기에 맞게 자신의 크기를 설정한다는것이다. 보통은 자신이 가지고있는 내용물의 크기아 맞게 크기를 설정하는 wrap_content를 사용한다.


  3. 다음으로 알아 볼 것은 레이아웃 내부의 객체들의 정렬위치를 설정할 수 있는 Gravity이다. 리니어 레이아웃의 Default값은 "left|top"으로 좌측 상단부터 정렬된다. Gravity로 지정할 수 있는 방향은 다음과 같다.
     top  컨테이너 위에 위치
     bottom  컨테이너 아래 위치
     left  컨테이너 왼쪽에 위치
     right  컨터이너 오른쪽에 위치
     center_vertical  컨테이너의 수직방향의 중앙에 위치
     center_horizontal  컨테이너의 수평방향의 중앙에 위치
     fill_vertical  수직방향을 컨테이너의 사이즈로 확대하여 배열
     fill_horizontal  수평방향을 컨테이너의 사이즈로 확대하여 배열
     center  컨테이너의 수평/수직방향의 중앙에 위치
     fill  수평/수직 모두 컨테이너의 사이즈에 확대하여 위치
    예를들어 레이아웃내에서 가운데 정렬되는 TextView를 하나 선언 해 보면 아래와 같다.

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent" 
        android:gravity="center"
        android:orientation="vertical">
        <TextView android:text="가운데 정렬" 
        android:id="@+id/textView1" 
        android:layout_width="wrap_content" 
        android:layout_height="wrap_content"></TextView>
    </LinearLayout>



'Programming > ANDROID' 카테고리의 다른 글

ViewGroup - TableLayout  (1) 2011.03.29
ViewGroup - FrameLayout  (1) 2011.03.28
뷰 그룹(View Group) - Layout  (1) 2011.03.28
안드로이드 한글 키보드 설정  (4) 2011.03.27
안드로이드 레이아웃-XML (Layout-XML)  (1) 2011.03.24

  1. View group은 View들을 담을수 있는 컨테이너 역할을 한다고 앞서 설명했다. View클래스로부터 파생된 ViewGroup의 서브클래스들은 다음과 같다.

  2. 위의 다양한 View들 중에서 자주 사용하여 앞으로 실습까지 해 볼 것들을 미리 간단히 정리해보자.
    • LinearLayout : 수직(vertical)방향이나 수평(horizontal)방향으로 객체들을 배치하는 가장 기본적인 레이아웃이다.
    • FrameLayout : 왼쪽 상단을 기준으로 각각 객체들을 겹치게 표현한다. 이것을 이용 해 카드게임과 같이 맨 위의 카드와 아래의 카드를 순서대로 볼 수 있게 설정할 수 있다.
    • TableLayout : 행과 열을 가지는 표 형태의 레이아웃으로 가장 큰 요소의 크기로 셀을 설정하며 셀 테두리는 보이지 않는다.
    • AbsoluteLayout : 뷰 객체의 위치를 좌표형식으로 설정하는 방식으로 실무에서는 거의 사용되지않는다.
    • RelativeLayout : 뷰 객체들간의 상대적인 위치를 지정하는 레이아웃으로 1번의 왼쪽 2번의 아래쪽 이런 방식으로 상대적인 위치를 설정하게된다.
    • Gallery : 스마트폰의 사진 스크롤화면처럼 이미지들을 터치로 끌어서 볼수있도록 해준다.
    • GridVIew : 격자 모양으로 보여주는 클래스.
    • ListView : 스크롤되는 하나의 컬럼 리스트를 보여주는 클래스
    • ScrollView : 수직으로 구성요소의 열을 스크롤링하게 하는 클래스
    • Spinner : 콤보박스 역할을 하는 클래스
    • SurfaceView : Low level 그리기를 지원하는 클래스 (쓰레드를 이용한다)
       
  3. 자 그럼 이제 가장 기본적인 LinearLayout부터 알아보도록하자!

  4.  

1. 안드로이드에서는 기존의 자바처럼 코드상에서 화면을 구성하며 데이터를 정의하고 사용할 수 있지만 XML 문서를 이용하는 방법을 새롭게 지원하고있다.


2. XML 레이아웃의 장점

 - 코드와 데이터가 완벽하게 분리되므로 개발자와 디자이너의 분담 작업이 용이하다.

 - 조건에 따라 레이아웃을 통째로 교체할 수 있으므로 호환성 확보국제화에 유리하다.

 - 레이아웃만 수정할 때는 컴파일하지 않아도 되므로 개발 속도가 빨라진다.

 - 구조와 속성을 함축적으로 기술할 수 있으며 레이아웃 재활용도 가능하다.


3. 실무에서는 코드 레이아웃과 XML 레이아웃을 둘 다 사용하며 동시에 적용하기도한다. 디자인에 관련된 정적인 레이아웃은 주로 XML코드로, 런타임과 연관있는 레이아웃은 자바 코드를 사용하는것이 보통이다.

4. 가장 기본적으로 생성되는 메인.xml을 살펴보자.
main.xml  

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
<TextView  
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:text="@string/hello"
    />
</LinearLayout>
가장 위에 xmlns에서 안드로이드 애트리뷰트를 사용하겠다는 네임스페이스를 선언하는것이고 이 애트리뷰트 형식은 android:속성명="속성값" 이다. 각 속성명들과 속성값은 매우 다양하고 많기 때문에 예제를 통해서 하나씩 알아가는 것이 좋겠다.

5. 문자의 경우 Strings.xml에 마찬가지로 xml 형태로 관리되어 사용 할 수 있으며 아래와 같이 직접 문자열을 쓸 수 도 있다.
<TextView
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:text="문자를 직접 입력합니다" />
6. AndroidMenifest.xml
 - 안드로이드 프로젝트 생성시 자동으로 생성되는 파일로 현재 프로젝트에 대한 뼈대를 구성하고있는 파일이다. 패키지 이름, 버전, 설치경로, SDK버전, Activity 등록 등에 대한 정보를 가지고있다.  

+ Recent posts