NavigationDrawerの実装
すぐに忘れるのでメモ。
activity_main.xml
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/drawer_layout" android:layout_width="match_parent" android:layout_height="match_parent" > <!-- メインコンテンツ用レイアウト --> <FrameLayout android:id="@+id/content_frame" android:layout_width="match_parent" android:layout_height="match_parent" > <TextView android:id="@+id/text" android:layout_width="match_parent" android:layout_height="match_parent" android:textSize="20sp" /> </FrameLayout> <!-- スライドメニュー用レイアウト --> <ListView android:id="@+id/left_drawer" android:layout_width="240dp" android:layout_height="match_parent" android:layout_gravity="start" android:background="@android:color/background_light" /> </android.support.v4.widget.DrawerLayout>
MainActivity.java
package com.freefly3104.navigationdrawer01; import android.os.Bundle; import android.support.v4.app.ActionBarDrawerToggle; import android.support.v4.view.GravityCompat; import android.support.v4.widget.DrawerLayout; import android.view.MenuItem; import android.view.View; import android.widget.AdapterView; import android.widget.AdapterView.OnItemClickListener; import android.widget.ArrayAdapter; import android.widget.ListAdapter; import android.widget.ListView; import android.widget.TextView; import android.app.Activity; import android.content.res.Configuration; public class MainActivity extends Activity implements OnItemClickListener{ private DrawerLayout drawerLayout; private ListView drawerList; private ActionBarDrawerToggle drawerToggle; private TextView textView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); drawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout); drawerList = (ListView) findViewById(R.id.left_drawer); textView = (TextView) findViewById(R.id.text); setupNavigationDrawer(); // 一覧のデータを設定 ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, android.R.id.text1); adapter.add("Menu1"); adapter.add("Menu2"); adapter.add("Menu3"); drawerList.setAdapter(adapter); if (savedInstanceState == null) { selectItem(0); } } private void setupNavigationDrawer() { drawerLayout.setDrawerShadow(R.drawable.drawer_shadow, GravityCompat.START); drawerList.setOnItemClickListener(this); // ActionBarのアイコンの左にDrawerToggleを表示する getActionBar().setDisplayHomeAsUpEnabled(true); // ActionBarのホームボタンを有効にします。 getActionBar().setHomeButtonEnabled(true); // ドロワーを開閉した時のイベントを受け取れるようにする drawerToggle = new ActionBarDrawerToggle(this, drawerLayout, R.drawable.ic_drawer, R.string.drawer_open, R.string.drawer_close) { @Override public void onDrawerClosed(View view) { } @Override public void onDrawerOpened(View drawerView) { } }; drawerLayout.setDrawerListener(drawerToggle); } @Override public boolean onOptionsItemSelected(MenuItem item) { // TODO 自動生成されたメソッド・スタブ // DrawerToggle側でオプションメニューの選択を検知できるようにする if (drawerToggle.onOptionsItemSelected(item)) { return true; } return super.onOptionsItemSelected(item); } @Override protected void onPostCreate(Bundle savedInstanceState) { // TODO 自動生成されたメソッド・スタブ super.onPostCreate(savedInstanceState); // DrawerToggle側でオプションメニューを制御できるようにする drawerToggle.syncState(); } @Override public void onConfigurationChanged(Configuration newConfig) { // TODO 自動生成されたメソッド・スタブ super.onConfigurationChanged(newConfig); // DrawerToggle側で上下の変更を制御できるようにする drawerToggle.onConfigurationChanged(newConfig); } @Override public void onItemClick(AdapterView<?> adapterView, View parent, int position, long id) { // TODO 自動生成されたメソッド・スタブ selectItem(position); } private void selectItem(int position) { ListAdapter adapter = drawerList.getAdapter(); String item = (String) adapter.getItem(position); textView.setText("選択したアイテム: " + item); drawerLayout.closeDrawer(drawerList); } }