第九单元 ToolBar和DrawLayout和SlidingMenu

一.ToolBar常用的方法

1.supportRequestWindowFeature(Window.FEATURE_NO_TITLE);去掉标题栏;
2.Toolbar.setLogo(),设置logo图片;
3.Toolbar.setTitle().设置标题;
4.Toolbar.setSubTitle()设置子标题;
5.Toolbar.setTitleTextColor(int color);设置标题文字颜色;
6.Toolbar.setSubtitleTextColor();设置子标题文字颜色;

代码:

package com.example.toolbar;

import android.support.v4.widget.DrawerLayout;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.Toolbar;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.Window;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {
    private Toolbar toolbar;
    private DrawerLayout drawerLayout;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        supportRequestWindowFeature(Window.FEATURE_NO_TITLE);//不用自带的
        setContentView(R.layout.activity_main);
        toolbar = findViewById(R.id.toolbar);
        drawerLayout=findViewById(R.id.draw);
        toolbar.setLogo(R.mipmap.ic_launcher_round);
        toolbar.setNavigationIcon(R.mipmap.ic_launcher);
        toolbar.setTitle("工具条");
        toolbar.setSubtitle("1705工具条");
        View inflate = LayoutInflater.from(this).inflate(R.layout.bar, null);//自定义布局
        toolbar.addView(inflate);
        setSupportActionBar(toolbar);//使用toolBar
    }
    //创建菜单
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.menu,menu);
        return super.onCreateOptionsMenu(menu);
    }
    //菜单添加事件
    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        if(item.getItemId()==R.id.menu1){
            Toast.makeText(this,"点了第一个菜单",Toast.LENGTH_SHORT).show();
        }else if(item.getItemId()==R.id.menu2){
            Toast.makeText(this,"点了第二个菜单",Toast.LENGTH_SHORT).show();
        }
        return super.onOptionsItemSelected(item);
    }

二.DrawerLayout常用的方法

DrawerLayout.isDrawerOpen(Gravity.LEFT)是否开启;
DrawerLayout.openDrawer(Gravity.LEFT);开启抽屉

  public void open(View view) {
            drawerLayout.openDrawer(Gravity.RIGHT);//开抽屉
        }
    
        public void close(View view) {
            drawerLayout.closeDrawer(Gravity.RIGHT);//关抽屉
        }
    }

三、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);

package com.example.toolbar;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;

import com.jeremyfeinstein.slidingmenu.lib.SlidingMenu;

public class Main2Activity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main2);
        SlidingMenu s= new SlidingMenu(this);
        s.setTouchModeAbove(SlidingMenu.TOUCHMODE_FULLSCREEN);//滑动方式、(充满整个屏幕)
        s.setMode(SlidingMenu.LEFT);//滑出来的方向
        View inflate = View.inflate(this, R.layout.bar, null);
        s.setMenu(inflate);
        s.attachToActivity(this,SlidingMenu.SLIDING_CONTENT);//把SlidingMenu和activity关联
    }
}

效果图:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值