Android Studio 自带的侧滑布局设置

原创 2016年06月02日 11:56:11
package com.example.k.newapp;

import android.os.Bundle;
import android.support.design.widget.FloatingActionButton;
import android.support.design.widget.Snackbar;
import android.view.Gravity;
import android.view.View;
import android.support.design.widget.NavigationView;
import android.support.v4.view.GravityCompat;
import android.support.v4.widget.DrawerLayout;
import android.support.v7.app.ActionBarDrawerToggle;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity
        implements NavigationView.OnNavigationItemSelectedListener {
    DrawerLayout drawer;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);


        drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
        /*
        *drawerLayout菜单的展开和隐藏可以被DrawerLayout.DrawerListener监听到,所以可以再打开和关闭的时候完成自己的逻辑,
        * 但是如果你还是用Toolbar,建议使用ActionBarDrawerToggle 来监听侧滑菜单的打开和关闭,ActionBarDrawerToggle实现了
        * DrawerListener,所以他能做DrawerListener可以做的任何事情,同时他还能将drawerLayout的展开和隐藏与actionbar的app
        * 图标关联起来,当展开与隐藏的时候图标有一定的动画效果,点击图标的时候还能展开或者隐藏菜单。
         */
        ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close){
            //菜单打开
            @Override
            public void onDrawerOpened(View drawerView) {
                super.onDrawerOpened(drawerView);
            }
            // 菜单关闭
            @Override
            public void onDrawerClosed(View drawerView) {
                super.onDrawerClosed(drawerView);
            }
        };
        //以下是设置标题栏的图标操作
        toggle.setDrawerIndicatorEnabled(false);//设置为false时显示自己设置的图标
        toggle.setHomeAsUpIndicator(R.drawable.ic_menu_camera);//自定义图标
        //自定义图标的点击事件
        toggle.setToolbarNavigationClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                //弹出侧滑
                drawer.openDrawer(Gravity.LEFT);
            }
        });
        drawer.setDrawerListener(toggle);
        toggle.syncState();

        NavigationView navigationView = (NavigationView) findViewById(R.id.nav_view);
        //注册侧滑项监听事件
        navigationView.setNavigationItemSelectedListener(this);
    }

    @Override
    public void onBackPressed() {
        DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
        if (drawer.isDrawerOpen(GravityCompat.START)) {
            drawer.closeDrawer(GravityCompat.START);
        } else {
            super.onBackPressed();
        }
    }
//侧滑项被点击了后调用
    @SuppressWarnings("StatementWithEmptyBody")
    @Override
    public boolean onNavigationItemSelected(MenuItem item) {
        // Handle navigation view item clicks here.
        int id = item.getItemId();

        if (id == R.id.nav_camera) {
            Toast.makeText(this,"1",Toast.LENGTH_SHORT).show();
        } else if (id == R.id.nav_gallery) {
            Toast.makeText(this,"2",Toast.LENGTH_SHORT).show();
        } else if (id == R.id.nav_slideshow) {
            Toast.makeText(this,"3",Toast.LENGTH_SHORT).show();
        } else if (id == R.id.nav_manage) {
            Toast.makeText(this,"4",Toast.LENGTH_SHORT).show();
        } else if (id == R.id.nav_share) {
            Toast.makeText(this,"5",Toast.LENGTH_SHORT).show();
        } else if (id == R.id.nav_send) {
            Toast.makeText(this,"6",Toast.LENGTH_SHORT).show();
        }

        return true;
    }
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

Android Studio——自定义ListView子项目布局

之前学习的ListView都是采用android系统自带的子项目布局,比如android.R.layout.simple_list_item_1(单行文字),以及android.R.layout.si...
  • oscar92420aaa
  • oscar92420aaa
  • 2015年12月08日 22:18
  • 4701

Android Studio官方版DrawerLayout侧滑菜单解析

效果图如下 这是使用Android Studio新建的一个DrawerLayout项目跑出来后的效果(没有Android Studio的盆友赶紧去下载个吧)。 生成后的代码有点混乱,稍微整理一下,那...
  • liu1252247624
  • liu1252247624
  • 2016年06月01日 08:56
  • 3689

android组件之DrawerLayout(抽屉导航)-- 侧滑菜单效果

一、 介绍 导航抽屉显示在屏幕的最左侧,默认情况下是隐藏的,当用户用手指从边缘向另一个滑动的时候,会出现一个隐藏的面板,当点击面板外部或者向原来的方向滑动的时候,抽屉导航就会消失了! 好了,这个抽屉就...
  • crazy1235
  • crazy1235
  • 2014年12月03日 14:25
  • 78402

Android Studio实现侧滑菜单

在多种APP里,比如QQ的主页面就有向右滑动出现菜单栏的情况,今天就来看一下如何实现这种功能。 先看一下程序的运行结果: 我的工程文件布局如下: 我们可以看到,侧滑菜单主要由两个...
  • gewuban
  • gewuban
  • 2016年03月23日 20:40
  • 4294

Android Studio官方版DrawerLayout侧滑菜单

  • 2016年06月01日 08:53
  • 25.55MB
  • 下载

Android studio slideMenu实现侧滑效果

  • 2016年07月19日 14:08
  • 8.17MB
  • 下载

DrawerLayout侧滑菜单

之前写过一篇关于SlidingMenu的侧滑,今天玩了玩谷歌官方的DrawerLayout侧滑。 代码如下:package com.example.lenovo.demo;import androi...
  • AndroidStudioo
  • AndroidStudioo
  • 2016年08月18日 11:41
  • 769

Android Studio布局模板二之Navigation Menu

android的 导航栏 侧滑菜单
  • CSDNhejingzhou
  • CSDNhejingzhou
  • 2016年03月29日 13:48
  • 2126

使用AndroidStudio一分钟实现Navigation Drawer 导航抽屉效果

Navigation Drawer导航抽屉这种效果在目前APP中用的比较广泛,今天就来看看看如何使用AndroidStudio来一键生成这个效果,实在是非常方便,完全傻瓜式的操作,快快动起手来吧!...
  • finddreams
  • finddreams
  • 2015年10月29日 16:31
  • 5028

Android 底部导航栏 BottomNavigationBar的简单使用

BottomNavigationView bottomNavigationBar的简单使用
  • yuzhiqiang_1993
  • yuzhiqiang_1993
  • 2016年08月24日 16:06
  • 12683
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Android Studio 自带的侧滑布局设置
举报原因:
原因补充:

(最多只允许输入30个字)