note

메뉴 Menu 본문

Android/기본

메뉴 Menu

투한 2012. 1. 11. 11:21
<?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:id="@+id/selection"
		android:layout_width="fill_parent"
		android:layout_height="wrap_content"
	/>
	<ListView
		android:id="@android:id/list"
		android:layout_width="fill_parent" 
		android:layout_height="fill_parent"
		android:drawSelectorOnTop="false"
		/>
</LinearLayout>

package com.commonsware.android.menus;

import android.app.ListActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.SubMenu;
import android.view.View;
import android.widget.TextView;
import android.widget.ListView;
import android.widget.ArrayAdapter;

public class MenuDemo extends ListActivity {
	TextView selection;
	String[] items = { "lorem", "ipsum", "dolor", "sit", "amet",
			"consectueuer", "adipiscing", "elit", "morbi", "vel", "ligula",
			"vitae", "arcu", "aliquet", "mollis", "etiam", "vel", "erat",
			"placerat", "ante", "porttitor", "길다", "많다", "너무 많다", "너무 길다", };

	@Override
	public void onCreate(Bundle savedInstanceState) {
		//안드로이드에서 부모클래스의 메소드를 재정의해서 사용할때
		//부모클래스의 원래 메소드를 초기화 한후 메소드에 수행문을 명시해야함
		//일반적으로 Activity의  생명 주기와 관련된 메소드들은 재정의할때 꼭 원래 메소드를 호출해서 초기화 해야 하지만
		//다른 클래스의 경우는 생략 가능
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);

		//ListView에 ArrayAdapter를 이용해 데이터 바인딩
		setListAdapter(new ArrayAdapter(this,
				android.R.layout.simple_list_item_1, items));
		selection = (TextView) findViewById(R.id.selection);
	}

	//이벤트 핸들러
	public void OnListItemClick(ListView parent, View v, int position, long id) {
		selection.setText(items[position]);
	}

	// 옵션 메뉴 호출
	@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		super.onCreateOptionsMenu(menu);

		/*
		 * groupid : 메뉴 아이템 그룹 지정, 미지정시 Menu.NONE=0 
		 * itemid : 메뉴 아이템에 부여된 ID
		 * order : 메뉴 아이템이 표시될 순서, 미지정시 Menu.NONE=0 
		 * title : 메뉴 아이템에 표시될 text
		 */
		menu.add(Menu.NONE, 1, Menu.NONE, "16 픽셀").setIcon(
				R.drawable.ic_launcher);
		menu.add(Menu.NONE, 1, Menu.NONE, "24 픽셀").setIcon(
				R.drawable.ic_launcher);
		SubMenu sub = menu.addSubMenu("기타");
		//서브 메뉴 생성(클릭시 팝업)
		sub.add(Menu.NONE, 3, Menu.NONE, "32픽셀");
		sub.add(Menu.NONE, 4, Menu.NONE, "40픽셀");

		return true;
	}
	
	//메뉴를 선택했을 때 동작하는 이벤트 핸들러
	public boolean onOptionsItemSeleted(MenuItem item) {
				//등록한 메뉴의 고유 id를 반환
		switch (item.getItemId()) {
		//getListView() : 현재 사용중인 ListView 객체 반환
		case 1:
			getListView().setDividerHeight(16);
			return true;
		case 2:
			getListView().setDividerHeight(24);
			return true;
		case 3:
			getListView().setDividerHeight(32);
			return true;
		case 4:
			getListView().setDividerHeight(40);
			return true;
		}
		return false;
	}
}