实现滑动菜单(富文本版本)

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

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


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


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

主要内容


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

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



步骤概要


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

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

img_2b4f9a59f03c1051fdad815a2c42ab69.png


效果图如下:


       启动程序,主界面如下:

img_85531fa34a94bc1b4d3c056ca4c17e9b.png

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

img_5f260fa9edcc7210a7ab2babae3961ec.png


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

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

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

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

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

img_5ec10965abf33264eb67c89cf84090af.png



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

2.2

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

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

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

下面开始操作,

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

img_55b01cc0fb550a0e3259ad02a8b3ac01.png

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

img_4c2f84c07ee491da8637ad6206d92bfc.png

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

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

img_07f53e05e39e4d36a3bdce8f33b4cee3.png

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

img_bb7adef698aa37e6bc4555a5d279d48d.png
目录
相关文章
|
11天前
|
JavaScript
安装富文本组件
安装富文本组件
|
8月前
uniapp显示富文本
uniapp显示富文本
63 0
|
4月前
|
XML Java Android开发
Android Studio App开发之实现底部标签栏BottomNavigationView和自定义标签按钮实战(附源码 超详细必看)
Android Studio App开发之实现底部标签栏BottomNavigationView和自定义标签按钮实战(附源码 超详细必看)
71 0
|
自然语言处理 数据可视化
Qt开发技术:Qt富文本(二)Qt文本光标操作、文档布局、富文本编辑、处理和Demo
Qt开发技术:Qt富文本(二)Qt文本光标操作、文档布局、富文本编辑、处理和Demo
Qt开发技术:Qt富文本(二)Qt文本光标操作、文档布局、富文本编辑、处理和Demo
|
图形学
Unity 编辑器开发实战【Custom Editor】- 为UI视图制作动画编辑器
Unity 编辑器开发实战【Custom Editor】- 为UI视图制作动画编辑器
198 1
Unity 编辑器开发实战【Custom Editor】- 为UI视图制作动画编辑器
|
存储 前端开发
Flutter 实现多选底部弹窗
本篇介绍了底部弹窗实现多选的方式,其中实现的方式还可以有很多种,例如直接在自定义组件中使用有状态组件。这里介绍的方法可以作为一个参考,通过动态构建有状态组件能够简单快速地实现底部弹窗的多选功能。
617 0
Flutter 实现多选底部弹窗
|
iOS开发
uwp - ContentDialog - 自定义仿iphone提示框,提示框美化
原文:uwp - ContentDialog - 自定义仿iphone提示框,提示框美化 为了实现我想要的效果花费了我很长时间,唉,当初英语不好好学,翻官网翻了半天才找到,分享给刚入门的新手。   首先看一张图片示例,我们要模仿的dialog就是长这样的:     做出来的效果图: 【代码】 XAML【MainPage.
1272 0
|
Android开发 iOS开发 索引
Xamarin自定义布局系列——支持无限滚动的自动轮播视图CarouselView
原文:Xamarin自定义布局系列——支持无限滚动的自动轮播视图CarouselView 背景简述 自动轮播视图(CarouselView)在现在App中的地位不言而喻,绝大多数的App中都有类似的视图,无论是WebApp还是Native App。
1829 0
|
Android开发
Android 优化个人封装仿网易新闻可滑动标题栏 TabLayout (文字或图标)
      小菜在向朋友推荐了自己修改封装的仿网易顶部滑动标题栏 TabSlideLayout 滑动内容可以是文字也可以是网络图标,其原型为 FlycoTabLayout,但是因为年代很久远,小菜当时技术太渣,存在一些小问题,后期做过一些优化,今天趁机会整理一下。
2999 0