张萌&韩墨羽——Toolbar和DrawerLayout+SlideMenu 2种方式实现抽屉侧滑

Toolbar和DrawerLayout+SlideMenu 2种方式实现抽屉侧滑

效果图
在这里插入图片描述
一.ToolBar常用的方法
二.DrawerLayout常用的方法
三.ToolBar和DrawerLayout绑定
四.ToolBar和DrawerLayout代码
五.SlideMenu实现抽屉
1.SlideMenu的属性:
2.代码实现:
效果图
1.Toolbar和DrawerLayout实现
Toolbar:标题栏
DrawerLayout:可以实现侧滑
2.SlideMenu实现 第三方 需要导入moudle(slidemenu)

一.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绑定

private void bindToolBar() {
    //设置开关
    ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(this, drawerLayout, toolbar, R.string.app_name, R.string.app_name);
    //开启同步
    toggle.syncState();
    //设置给drawerLayout
    drawerLayout.addDrawerListener(toggle);
}

四.ToolBar和DrawerLayout代码
(0)先去掉自带的ActionBar,在清单文件中

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

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.example.day3.MainActivity"
    android:orientation="vertical">
    <android.support.v7.widget.Toolbar
        android:background="#bdbebf"
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="50dp">
    </android.support.v7.widget.Toolbar>
    <android.support.v4.widget.DrawerLayout
        android:id="@+id/drawer_layout"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
        <!--主界面,必须先写-->
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:gravity="center"
            >
            <TextView
                android:text="我是侧拉主界面"
                android:textSize="50sp"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content" />
        </LinearLayout>
        <!--侧滑部分  android:layout_gravity="left" 从左侧滑出-->
        <LinearLayout
            android:layout_gravity="left"
            android:layout_width="200dp"
            android:layout_height="match_parent"
            android:gravity="center">
            <ListView
                android:id="@+id/lv"
                android:background="#b49797"
                android:layout_width="wrap_content"
                android:layout_height="match_parent"></ListView>
        </LinearLayout>

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


</LinearLayout>

(2)java 代码:MainActivity.java

public class MainActivity extends AppCompatActivity {
    Toolbar toolbar;
    DrawerLayout drawerLayout;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
      
        setContentView(R.layout.activity_main);
        drawerLayout=findViewById(R.id.drawer_layout);
        initToolBar();//初始化bar
        bindToolBar();//绑定bar
    }
    private void initToolBar() {

        toolbar = findViewById(R.id.toolbar);
        //设置导航图标.
        toolbar.setNavigationIcon(R.mipmap.ic_launcher);
        //设置toolbar的大标题
        toolbar.setTitle("天气");
        toolbar.setLogo(R.mipmap.ic_launcher_round);
        //设置toolbar的小标题.
        toolbar.setSubtitle("Android");
      

    }
    //toolbar和drawerLayout绑定实现切换效果
    private void bindToolBar() {
        //设置开关
        ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(this, drawerLayout, toolbar, R.string.app_name, R.string.app_name);
        //开启同步
        toggle.syncState();
        //设置给drawerLayout
        drawerLayout.addDrawerListener(toggle);
    }
}

五.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代码中是实现

public class SlidingMenuActivity extends AppCompatActivity {
    private SlidingMenu slidingMenu;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_sliding_menu);
        initmenu();
    }

    private void initmenu() {
        //TODO 1:创建菜单对象
        slidingMenu=new SlidingMenu(this);
        //TODO 2:设置属性
        //SlidingMenu.RIGHT   SlidingMenu.LEFT
        slidingMenu.setMode(SlidingMenu.LEFT);//设置从哪边出来
        //TOUCHMODE_FULLSCREEN全屏;TOUCHMODE_MARGIN边界;TOUCHMODE_NONE不能滑动
        slidingMenu.setTouchModeAbove(SlidingMenu.TOUCHMODE_FULLSCREEN);//在屏幕的任何位置左滑都可以显示出来
        slidingMenu.setBehindOffset(200);//单位是像素px 侧滑菜单滑出后,界面剩余的宽度。
        slidingMenu.attachToActivity(this, SlidingMenu.SLIDING_CONTENT);//绑定到指定的Context
        //TODO 3:设置布局并且相应布局上面的按钮
      View view = LayoutInflater.from(this).inflate(R.layout.slide, null);
Button button=view.findViewById(R.id.bt_close);
button.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        //关闭抽屉
       // slidingMenu.showMenu();//显示抽屉
        slidingMenu.showContent();//显示主页面
    }
});
slidingMenu.setMenu(view);//设置布局        //TODO 4:设置监听listener,监听侧滑菜单的打开和关闭.
        slidingMenu.setOnOpenedListener(new SlidingMenu.OnOpenedListener() {
            @Override
            public void onOpened() {
                Toast.makeText(SlidingMenuActivity.this, "打开了", Toast.LENGTH_SHORT).show();
            }
        });
        slidingMenu.setOnClosedListener(new SlidingMenu.OnClosedListener() {
            @Override
            public void onClosed() {
                Toast.makeText(SlidingMenuActivity.this, "侧滑菜单关闭", Toast.LENGTH_SHORT).show();
            }
        });
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
旋转木马布局效果     gradle    compile 'com.dalong:carrousellayout:1.0.0'or Maven    <dependency>       <groupId>com.dalong</groupId>       <artifactId>carrousellayout</artifactId>       <version>1.0.0</version>       <type>pom</type>     </dependency>xml:     <com.dalong.carrousellayout.CarrouselLayout            android:id="@ id/carrousel"            app:rotateDirection="anticlockwise"            app:r="200dp"            app:rotationTime="3000"            android:gravity="center"            android:layout_marginBottom="180dp"            android:layout_width="match_parent"            android:layout_height="match_parent">           <ImageView               android:src="@mipmap/image1"               android:layout_width="wrap_content"               android:layout_height="wrap_content" />           <ImageView               android:src="@mipmap/image2"               android:layout_width="wrap_content"               android:layout_height="wrap_content" />               ...        </com.dalong.carrousellayout.CarrouselLayout>java:    CarrouselLayout carrousel= (CarrouselLayout) findViewById(R.id.carrousel);     carrousel.setR(width/3)//设置R的大小              .setAutoRotation(false)//是否自动切换              .setAutoRotationTime(1500);//自动切换的时间  单位毫秒
智慧校园建设是当前高校关注的焦点之一。本文将从智慧校园建设的问题与对策、水平评价、第三方企业代理、国内研究综述和技术标准等方面进行综合分析。 首先,文献[6]针对高校智慧校园建设问题进行了研究。从智慧校园建设的现状和存在的问题出发,提出了相应的对策。例如,加强对智慧校园建设的投入、完善智慧校园建设的相关规定等。 其次,文献[7]则从智慧校园建设水平评价出发,提出了评价指标和方法,并对评价结果进行了解读。该文献为高校智慧校园建设提供了一定的参考依据。 此外,文献[8]则提出了第三方企业代理智慧校园建设、评价与改进策略。该方案可以有效地提高智慧校园建设效率和质量,避免了高校在建设过程中可能遇到的困难。 同时,文献[9]则对国内智慧校园研究综述进行了总结和反思。该文献指出,虽然国内对智慧校园建设进行了一定的研究,但是仍然存在很多问题需要解决,例如如何保证智慧校园中的数据安全和隐私保护等。 最后,文献[10]则从技术标准的角度探讨了智慧校园建设的相关问题。该文献指出,智慧校园建设需要遵循相应的技术标准,才能保证智慧校园的正常运行。 综合以上五篇文献可以看出,智慧校园建设是当前高校关注的重要领域。虽然各高校在智慧校园建设方面已经有所建设,但是仍然存在很多问题需要解决。例如,如何保证数据的安全和隐私的保护等。在未来的发展中,除了需要加强对智慧校园建设的投入之外,还需要加强对智慧校园建设中所面临的问题的研究与解决。同时,在智慧校园建设过程中,需要遵循相应的技术标准,以保证智慧校园的正常运行。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值