事務屋さんの備忘録

主にプログラミングのことを書いていきます。メモというか備忘録的な感じで。プログラミングといっても、私はプロのエンジニアでも本職のプログラマーでもありません。単なる事務職をやってるサラリーマンで、空いた時間にちょこちょこっとプログラミングしてる程度です。よってこのブログに記載したことが誤っていたり、もっとよい方法がある場合もあると思います。その場合には、ご指摘いただけると嬉しいです。また、このブログを読んで役に立った、なんて方がいらっしゃったら幸いですね。

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);
    }

}