'menu'에 해당되는 글 1건

  1. 2012.07.31 안드로이드 메뉴

안드로이드 메뉴

Android 2012. 7. 31. 21:58
728x90

안드로이드에서 사용하는 메뉴는 크게 3가지로 나뉜다.

 

1.옵션 메뉴

사용자가 메뉴버튼을 누르면 화면에 나타난다. 최대 6개의 항목을 가질수 있으며 6개가 넘으면 5개까지 나타나고 6번째는 More항목이 나타나고 나머지는 숨겨지게 된다.

More항목을 클릭하면 숨겨진 나머지 메뉴들이 확장메뉴 형태로 나타난다.

아이콘으로 꾸미기는 가능하나, 체크박스, 라디오 그룹을 사용할 수는 없다.

 

2.컨텍스트 메뉴

화면을 꾹 누르고 있으면 나타나는 메뉴이다. 화면의 중앙에 나타난다.

아이콘을 추가 할수는 없지만 체크박스나 라디오 그룹을 사용할 수 있다.


3.서브 메뉴

옵션메뉴나 컨텍스트 메뉴에 추가적인 항목을 넣을때 사용되며 서브메뉴에 서브메뉴 추가는 불가능.

 


1.옵션메뉴

 

옵션메뉴를 생성하기 위해서는 아래 3가지 메소드를 재정의 해야한다.

 

public boolean onCreateOptionsMenu (Menu menu)

 - 메뉴 버튼을 눌렀을때 시스템에 의하여 자동적으로 호출되는 메소드

    매개변수로 빈 메뉴객체인 menu에다가 원하는 항목을 추가 하면 된다.


public boolean onPrepareOptionsMenu (Menu menu)
 - 메뉴가 열릴 때마다 호출되는 메소드, 동적으로 메뉴를 추가하거나 삭제가 가능.
   사용하는 메뉴가 고정된 형태라면 굳이 사용할 필요는 없다.


public boolean onOptionsItemSelected (MenuItem item)

 - 메뉴항목을 선택했을때 호출되는 메소드

   매개변수로 넘어온 item은 사용자가 선택한 메뉴 항목이다

 

MenuTestActivity.java

main.xml

 

Menu, 클래스에 대해서.


MenuItem add(int groupId, int itemId, int order, ChatSequence title)


MenuItem addSubMenu(int groupId, int itemId, int order, int title)


위의 2개의 메소드가 주로 사용되며 이름에서 알수 있듯이 메뉴아이템을 추가하거나 서브메뉴를 추가할때 사용되는 메소드
- groupId : 항목에 그룹을 지정할때 사용하는 그룹번호

- itemId : 해당 아이템의 고유한 식별자

- order : 배치되는 순서 (동일한 값을 넣으면 순서대로 추가된다.)

- title : 항목에 보여지는 문자열. 리소스 형태로 넣을수도 있고 문자열 형태로 넣을수도 있다.

 

MenuItem 클래스에 대해서.


MenuItem setChecked(boolean checked) - 체크여부를 결정

MenuItem setEnabled(boolean enabled) - 항목의 사용가능 여부 결정

MenuItem setIcon(int iconRes) - 항목의 아이콘을 설정

MenuItem setNumericShortcut(char numericChar) - 숫자 단축기 지정

MenuItem setShortcut(char numericChar, char alphaChar) - 문자나 숫자 단축키 지정

MenuItem setTitle(CharSequence title) - 항목의 문자열을 지정

MenuItem setVisible(boolean visible) - 항목의 보여짐 상태를 설정


메소드들을 보면 모두 MenuItem을 리턴하고 있다. 그렇기 때문에 다음과 같이 2가지 형태로 사용가능 하다.


MenuItem menuItem = menu.add("하이");

menuItem.setIcon(R.id.xxxxxx);

menuItem.setTitle("테스트 항목");


menu.add("하이").setIcon(R.id.xxxxxx).setTitle("테스트입니다.")

 

2.컨텍스트 메뉴

 

컨텍스트 메뉴는 옵션 메뉴와 거의 동일하다. 하지만 옵션메뉴처럼 메뉴버튼에 자동 등록된 녀석이 아니라 원하는 뷰마다 사용가능한 녀석이기 때문에 "" 이라는 메소드가 하나 추가되어 있다.

 

컨텍스트 메뉴를 생성하기 위해서는 아래 4가지 메소드를 재정의 합니다.


public void registerForContextMenu(View view)

 - 특정 뷰에 컨텍스트 메뉴를 추가하고자 할때 매개변수로 등록하고자 하는

    뷰를 넣어 메소드를 호출한다. 필요하다면 여러개 뷰의 등록도 가능하다.


public boolean onCreateContextMenu (ContextMenu menu, View v,

                ContextMenu.ContextMenuInfo menuInfo)

 - 특정 뷰를 컨텍스트메뉴로 등록하였하면 해당 뷰를 롱클릭하면 onCreateContextMenu가 자동 호출된다. 복수의 등록이 가능하므로 2번째 매개변수를 통해 이벤트가 발생한 View를 알수 있으며 3번째 매개변수를 표시해야 할 아이템의 추가적인 정보를 담고 있습니다.

   이 정보는 매개변수 v 에 따라 매우 다양하게 제공된다. 옵션메뉴와 다른 점은 이 메소드는 컨텍스트 메뉴가 사용될 때마다 호출된다는 점이다. 그렇기 때문에 옵션메뉴에 있던 onPrepareOptionsMenu() 가 컨텍스트메뉴에는 필요하지 않다.


public boolean onContextItemSelected (MenuItem item)

 - 컨텍스트 메뉴의 항목을 선택했을때 호출되는 메소드.

   매개변수로 넘어온 item은 사용자가 선택한 메뉴 항목이다.


void onCreatecontextMenu(ContextMenu menu)

 - 자신이 필요한 컨텍스트메뉴를 개별적으로 재정의 하여 사용한다.

 

MenuTestActivity02.java

main.xml

 

3.서브메뉴

 

서브 메뉴는 OptinosMenu와 ContextMenu에서 공통적으로 사용되는 메뉴이다.

일반적으로 두메뉴의 하위에 구성된 메뉴를 말한다. 기존에 작성한 메뉴들은 사용자가 메뉴항목을 선택하면 onXXxxxxxItemSelected() 메소드가 호출되어 해당 메소드에서 정의된 작업을 수행하게 되지만 Sub Menu로 구성된 항목을 선택하면 또다른 메뉴가 리스트 형태로 출력이 된다.

서브메뉴는 다른 메뉴들과는 다르지만 독립적으로 관리되는 것이 아니라 일반메뉴에 포함된 형태로 여겨지기 때문에 코드상에 모두 작성하면 된다.

 

서브메뉴에 서브메뉴를 추가하면 실행시 아래와 같은 에러가 발생합니다.

E/AndroidRuntime( 9248): java.lang.UnsupportedOperationException: Attempt to add a sub-menu to a sub-menu. 

 

MeunTestActivity03.java

main.xml

728x90

'Android' 카테고리의 다른 글

안드로이드 기본 위젯  (0) 2012.07.31
안드로이드 리소스, 에셋  (0) 2012.07.31
안드로이드 입력 (이벤트) 4  (0) 2012.07.31
안드로이드 입력 (이벤트) 3  (0) 2012.07.31
안드로이드 입력 (이벤트) 2  (0) 2012.07.31
Posted by 정망스
,


맨 위로
홈으로 ▲위로 ▼아래로 ♥댓글쓰기 새로고침