Xamarin-메뉴
팝업 메뉴
팝업 메뉴는보기에 첨부 된 메뉴를 의미합니다. 그것은 또한shortcut menu. Android 앱에 팝업 메뉴를 추가하는 방법을 살펴 보겠습니다.
새 프로젝트를 만들고 이름을 지정합니다. popUpMenu App. 열다Main.axml 팝업 메뉴를 표시하는 데 사용할 버튼을 만듭니다.
<?xml version = "1.0" encoding = "utf-8"?>
<LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android"
android:orientation = "vertical"
android:background = "#d3d3d3"
android:layout_width = "fill_parent"
android:layout_height = "fill_parent">
<Button
android:id = "@+id/popupButton"
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"
android:text = "Show popup menu"
android:background = "@android:color/holo_green_dark"
android:textColor = "@android:color/black" />
</LinearLayout>
아래에 새 폴더를 만듭니다. Resources 폴더 및 호출 Menu. 메뉴 폴더 안에 새 xml 파일을 추가하십시오.popMenu.xml.
아래에 popMenu.xml, 다음 메뉴 항목을 추가하십시오.
<?xml version = "1.0" encoding="utf-8"?>
<menu xmlns:android = "http://schemas.android.com/apk/res/android">
<item
android:id = "@+id/file_settings"
android:icon = "@drawable/img_settings"
android:title = "Settings"
android:showAsAction = "ifRoom">
<item
android:id = "@+id/new_game1"
android:icon = "@drawable/imgNew"
android:title = "New File Settings"/>
<item
android:id = "@+id/help"
android:icon = "@drawable/img_help"
android:title = "Help" />
<item
android:id = "@+id/about_app"
android:icon = "@drawable/img_help"
android:title = "About app"/>
</item>
</menu>
메뉴 항목을 추가 한 후 mainActivity.cs 버튼 클릭시 팝업 메뉴를 표시합니다.
protected override void OnCreate(Bundle bundle) {
base.OnCreate(bundle);
SetContentView(Resource.Layout.Main);
Button showPopupMenu = FindViewById<Button>(Resource.Id.popupButton);
showPopupMenu.Click += (s, arg) => {
PopupMenu menu = new PopupMenu(this, showPopupMenu);
menu.Inflate(Resource.Menu.popMenu);
menu.Show();
};
}
이제 애플리케이션을 빌드하고 실행하십시오. 다음 출력을 생성해야합니다.
옵션 메뉴
옵션 메뉴는 앱의 기본 메뉴 모음으로 주로 설정, 검색 등을 저장하는 데 사용됩니다. 여기서는 내부에 세 가지 항목이있는 설정 메뉴를 만들 것입니다. New File Settings, Help, and About App.
옵션 메뉴를 만들려면 리소스 폴더에 새 XML 레이아웃 파일을 만들어야합니다. 먼저 새 XML 파일을 추가합니다. 마우스 오른쪽 버튼으로Layout folder, 다음으로 이동 Add → New item → Visual C# → XML File.
적절한 이름을 선택하십시오. layout file. 이 예에서는 파일을myMenu.xml.
내부 myMenu.xml, 우리는 새 메뉴를 만들고 내부에 항목을 추가 할 것입니다. 다음 코드는이를 수행하는 방법을 보여줍니다.
<?xml version = "1.0" encoding = "utf-8"?>
<menu xmlns:android = "http://schemas.android.com/apk/res/android">
<item
android:id = "@+id/file_settings"
android:icon = "@drawable/img_settings"
android:title = "Settings"
android:showAsAction = "ifRoom">
<menu>
<item
android:id = "@+id/new_game1"
android:icon = "@drawable/imgNew"
android:title = "New File Settings" />
<item
android:id = "@+id/help"
android:icon = "@drawable/img_help"
android:title = "Help" />
<item
android:id = "@+id/about_app"
android:icon = "@drawable/img_help"
android:title = "About app"/>
</menu>
</item>
</menu>
다음으로 이동합니다. MainActivity.cs 에 대한 재정의 클래스를 만듭니다. onOptionsMenu().
public override bool OnCreateOptionsMenu(IMenu menu) {
MenuInflater.Inflate(Resource.Menu.myMenu, menu);
return base.OnPrepareOptionsMenu(menu);
}
다음으로, 우리는 settings menu선택되면. 이를 위해 우리는OnOptionsItemSelected() 메뉴.
public override bool OnOptionsItemSelected(IMenuItem item) {
if (item.ItemId == Resource.Id.file_settings) {
// do something here...
return true;
}
return base.OnOptionsItemSelected(item);
}
최종 완성 된 코드는 다음과 같습니다.
namespace optionsMenuApp {
[Activity(Label = "options Menu", MainLauncher = true, Icon = "@drawable/icon")]
public class MainActivity : Activity {
public override bool OnCreateOptionsMenu(IMenu menu) {
MenuInflater.Inflate(Resource.Menu.myMenu, menu);
return base.OnPrepareOptionsMenu(menu);
}
public override bool OnOptionsItemSelected(IMenuItem item) {
if (item.ItemId == Resource.Id.file_settings) {
// do something here...
return true;
}
return base.OnOptionsItemSelected(item);
}
}
}
이제 애플리케이션을 빌드하고 실행하십시오. 다음 출력을 생성해야합니다.