实现滑动菜单

所谓的滑动菜单就是将一些菜单选项隐藏起来,而不是放置在主屏幕上,然后可以通过滑动的方式将菜单显示出来。这种方式既节省了屏幕空间,又实现了非常好的动画效果。

下面我们实现一个相对基本的滑动菜单。

参考文献:《第一行代码(第2版)》

主要内容


1.使用DrawerLayout控件搭建基础框架

2.使用NavigationView优化滑动菜单页面

步骤概要


1.使用DrawerLayout控件搭建基础框架

新建一个空项目,修改主布局文件如下,DrawerLayout中放置了两个直接子控件,第一个字控件是FrameLayout,用于作为主屏幕中显示的内容,第二个控件这里使用了一个TextView,用于作为滑动菜单中显示的内容:

效果图如下:

       启动程序,主界面如下:

在屏幕左侧边缘向右拖动,就可以让滑动菜单显示出来了:

2.使用NavigationView优化滑动菜单页面

NavigationView是Design Support库中提供的一个控件,它可以将滑动菜单页面的实现变得非常简单。

接下来我们实现一下这个控件,

NavigationView是Design Support库中提供的,那么我们需要将这个库引入到项目中才行,如图中32-33行:

注:Sync的时候可能会出错,这时候添加如27、31两行相关注释即可

其中CircleImageView是一个开源项目,它可以用来轻松实现图片圆形化:

2.2

在开始使用NavigationView之前,我们需要准备好两个东西:

1)menu。用来自NavigationView中显示具体的菜单项;

2)headerLayout。用来在NavigationView中显示头部布局的;

下面开始操作,

新建一个布局文件,编写如下代码:

layout文件夹下再新建一个header布局:

现在menu和header都准备好了,可以使用NavigaView了,修改activity_main.xml中的代码,如下:

其中我们可以看到,如图中27-28行,我们将准备好的menu和header设置到NavigaView里面,

到此为止滑动菜单的UI设计便大功告成了,运行程序,在屏幕左侧边缘向右拖动,就可以如下效果图了:

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

扫码关注云+社区

领取腾讯云代金券