第9单元Toolbar+DrawerLayout SlideMenu 2种方式实现抽屉侧滑

一.ToolBar常用的方法

Toolbar是在 Android 5.0 开始推出的一个 Material Design 风格的导航控件,以此来取代之前的Actionbar 。我们需要在工程中引入appcompat-v7的兼容包以便向下兼容, 使用android.support.v7.widget.Toolbar进行开发。在设计 Toolbar 的时候,Google也留给了开发者很多可定制修改的余地,这些可定制修改的属性在API文档中都有详细介绍,如:

1. supportRequestWindowFeature(Window.FEATURE_NO_TITLE);去掉标题栏;
2. Toolbar.setLogo(),设置logo图片;
3. Toolbar.setTitle().设置标题;
4. Toolbar.setSubTitle()设置子标题;
5. Toolbar.setTitleTextColor(int color);设置标题文字颜色;
6. Toolbar.setSubtitleTextColor();设置子标题文字颜色;
7. setTitleMargin(int start, int top, int end, int bottom);设置标题margin值;
8. onCreateOptionsMenu,getMenuInflater().inflate(R.menu.menu,menu)
设置菜单在给Toolbar设置为actionbar时使用;
9. Toolbar.setOnMenuItemClickListener();Toolbar绑定menu监听;
10. Toolbar.inflateMenu(R.menu.menu)在Toolbar没有替换actionbar时使用;
11. setSupportActionBar(mToolbar);设置toolbar替换actionbar;
12. getLayoutInflater().inflate(R.layout.view_tv,bar);Toolbar添加自定义view

二.DrawerLayout常用的方法

DrawerLayout.isDrawerOpen(Gravity.LEFT)是否开启;
DrawerLayout.openDrawer(Gravity.LEFT);开启抽屉
DrawerLayout.closeDrawer(Gravity.RIGHT);关闭抽屉

三.ToolBar和DrawerLayout代码

(0)先去掉自带的ActionBar,在清单文件中

在这里插入图片描述

(1)布局文件代码:activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity"
    android:orientation="vertical">


    <android.support.v4.widget.DrawerLayout
        android:id="@+id/drawer"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="vertical"
            >
            <android.support.v7.widget.Toolbar
                android:background="#B0077FF8"
                android:id="@+id/toolbar"
                android:layout_width="match_parent"
                android:layout_height="50dp">
                <ImageView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:background="@mipmap/ic_launcher_round"
                    android:id="@+id/image1"/>

            </android.support.v7.widget.Toolbar>

            <TextView
                android:text="我是侧拉主页面"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content" />

        </LinearLayout>
        <LinearLayout
            android:layout_gravity="left"
            android:layout_width="200dp"
            android:layout_height="match_parent"
            android:gravity="center">
            <ImageView
                android:id="@+id/image2"
                android:background="@mipmap/ic_launcher_round"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content" />
        </LinearLayout>

    </android.support.v4.widget.DrawerLayout>

</LinearLayout>

(2)java 代码:MainActivity.java



class MainActivity extends AppCompatActivity {
    Toolbar toolbar;
    DrawerLayout drawerLayout;
    @RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        drawerLayout = findViewById(R.id.drawer);
        toolbar = findViewById(R.id.toolbar);
        //设置导航图标
        initToolBar();
//        bindToolbar();

    }

    private void bindToolbar() {
        //设置开关
//        new ActionBarDrawerToggle(this,drawerLayout,toolbar,R.string.app_name,R.string.app_name)
    }

    @RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
    private void initToolBar() {

//        toolbar.setNavigationIcon(R.mipmap.ic_launcher);
//        //设置toolbar的大标题
//        toolbar.setTitle("天气");
//        toolbar.setLogo(R.mipmap.ic_launcher_round);
//        //设置小标题
//        toolbar.setSubtitle("Android");
        ImageView imageView = findViewById(R.id.image1);
        imageView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                drawerLayout.openDrawer(Gravity.LEFT);
            }
        });
        ImageView imageView2 = findViewById(R.id.image2);
        imageView2.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                drawerLayout.closeDrawer(Gravity.LEFT);
            }
        });


    }
}

五.SlideMenu实现抽屉

1.SlideMenu的属性:

设置模式: setMode(SlidingMenu.LEFT);
设置触摸屏幕的模式:setTouchModeAbove(SlidingMenu.TOUCHMODE_FULLSCREEN);
//TOUCHMODE_FULLSCREEN全屏;TOUCHMODE_MARGIN边界;TOUCHMODE_NONE不能滑动
设置左侧菜单滑动显示的内容:slidingMenu.setMenu(R.layout.slide_menu);
设置左侧滑动菜单的阴影宽度:slidingMenu.setShadowWidth(300);
设置滑动时的渐变程度:slidingMenu.setFadeDegree(0.5f);范围0.0f-1.0f
设置淡入淡出的效果:slidingMenu.setFadeEnabled(true);
设置左侧滑动菜单的阴影图片(颜色):setShadowDrawable();
设置滑出时主页面显示的剩余宽度:slidingMenu.setBehindOffset(200);

注意:
(1)attachToActivity():将slidemenu和Activity绑定
(2)setMenu():设置菜单显示的内容
(3) Button bt = slidingMenu.getMenu().findViewById(R.id.bt1);为侧滑出来的菜单设置事件监听

2.代码实现:

(1)导入第三方moudle:slidemenu

在这里插入图片描述

(2)activity代码中是实现



class Main2Activity extends AppCompatActivity {
    SlidingMenu slidingMenu;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main2);
        initMenu();
        ImageView imageView = findViewById(R.id.image1);
        imageView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                slidingMenu.showMenu();
            }
        });


    }

    private void initMenu() {
        //创建对象
        slidingMenu = new SlidingMenu(this);
        //设置属性
        //三大属性必须设置
        slidingMenu.attachToActivity(this,SlidingMenu.SLIDING_CONTENT);

        slidingMenu.setMode(SlidingMenu.LEFT);//设置模式 左还是右

        View view = LayoutInflater.from(this).inflate(R.layout.item, null);
        Button button = view.findViewById(R.id.bt1);
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                slidingMenu.showContent();//显示主页面
//                slidingMenu.showMenu();//显示抽屉
            }
        });
        slidingMenu.setMenu(view);//设置布局

        //设置属性
        slidingMenu.setBehindOffset(200);//剩余宽度
        //设置从哪拉才出来
        slidingMenu.setTouchModeAbove(SlidingMenu.TOUCHMODE_FULLSCREEN);



    }


}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值