상세 컨텐츠

본문 제목

[안드로이드] DrawerLayout Navigation 메뉴(Menu) 추가하기

안드로이드

by aries574 2021. 1. 19. 14:53

본문



이번 시간에는 이전에 DrawerLayout Navigation에 메뉴를 넣어보겠습니다.

이전에 했던 소스 그대로 이어서 하겠습니다. 

2021/01/19 - [안드로이드] - [안드로이드] DrawerLayout Navigaion 쉽게 만들어보기

1. 메뉴 추가

res -> New -> Android Resource File

File name은  drawer_menu

Resource type은 Menu를 선택하신 후 Ok를 누르시면 메뉴폴더가 자동생성되면서, 그 안에 파일이 생성됩니다.


<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">

<group android:checkableBehavior="single">
<item
android:id="@+id/nav_camera"
android:title="Camera"
android:icon="@drawable/ic_camera"
/>

<item
android:id="@+id/nav_photo"
android:title="Photo"
android:icon="@drawable/ic_photo"
/>

<item
android:id="@+id/nav_slideShow"
android:title="SlideShow"
android:icon="@drawable/ic_slideshow"
/>
</group>

</menu>


res -> drawable 폴더에 아이콘 추가

ic_slideshow.xml

ic_photo.xml

ic_camera.xml



2. 메인화면 수정(activity_main.xml)

NavigationView 속성에 app:menu="@menu/drawer_menu 추가

<?xml version="1.0" encoding="utf-8"?>
<androidx.drawerlayout.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity"
android:id="@+id/drawer_layout"
android:fitsSystemWindows="true"
>

<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">

<include layout="@layout/toolbar_layout"/>
</LinearLayout>

<com.google.android.material.navigation.NavigationView
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
android:id="@+id/navigationView"
android:layout_gravity="left"
app:menu="@menu/drawer_menu"
/>

</androidx.drawerlayout.widget.DrawerLayout>


3. 메인코드 수정(MainActivity.java)

NavigationView, DrawerLayout 객체 생성 후 NavigationView 안에 메뉴 선택시 이벤트 발생하는 리스너 생성


import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.appcompat.widget.Toolbar;
import androidx.drawerlayout.widget.DrawerLayout;
import android.os.Bundle;
import android.view.MenuItem;
import android.widget.Toast;

import com.google.android.material.navigation.NavigationView;

public class MainActivity extends AppCompatActivity {

private Toolbar toolbar;

private NavigationView navigationView;
private DrawerLayout drawerLayout;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

toolbar = findViewById(R.id.toolBar);
setSupportActionBar(toolbar);

navigationView = findViewById(R.id.navigationView);
drawerLayout = findViewById(R.id.drawer_layout);

navigationView.setNavigationItemSelectedListener(new NavigationView.OnNavigationItemSelectedListener() {
@Override
public boolean onNavigationItemSelected(@NonNull MenuItem menuItem) {

switch(menuItem.getItemId()){
case R.id.nav_camera:
menuItem.setChecked(true);
displayMessage("camera selected");
drawerLayout.closeDrawers();
return true;

case R.id.nav_photo:
menuItem.setChecked(true);
displayMessage("photo selected");
drawerLayout.closeDrawers();
return true;

case R.id.nav_slideShow:
menuItem.setChecked(true);
displayMessage("slideshow selected");
drawerLayout.closeDrawers();
return true;
}

return false;
}
});
}

private void displayMessage(String message){
Toast.makeText(this, message, Toast.LENGTH_SHORT).show();
}
}



4. 실행화면




반응형

관련글 더보기

댓글 영역