栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > Html/CSS > Bootstrap教程

Android开发最佳实践(三)

Android开发最佳实践(三)

6)使用AppBarLayout并处理滑动手势

AppBarLayout是一个在android.support.design兼容包(这里有关于该兼容包的 官方博客介绍)里面的新推出的组件,它是一个垂直方向的LinearLayout,包装了很多Material Design的设计元素,例如滑动手势的处理。我们可以使用app:layout_scrollFlags这样的标签来设置滑动的行为表现。关于App Bar,官方还有这样一段描述: 

使用AppBarLayout需要注意下面几个要点:


  • 首先,AppBarLayout必须作为CoordinatorLayout的直接子View;

  • 其次,在AppBarLayout里面必须包含一个ToolBar;

  • 最后,在CoordinatorLayout里面可以添加那些可以滑动的组件,例如RecyclerView。


一个标准的布局文件应该是类似下面结构的: 

我们需要注意,在Toolbar里面设置的layout_scrollFlags会影响到滑动之后的显示效果,请看下面的具体解释: 

7)使用SearchView来实现搜索功能

关于在使用搜索的时候及时显示给用户的候选词,会需要根据数据的类型以及具体的情况做不同的处理,这里先暂时不讨论那一块的内容。

上面的图示已经清楚的演示了使用SearchView处理搜索的通常情况,关于如何实现这个功能,需要做到以下几个步骤:


  • 在Menu的XML文件中,声明使用SearchView。


  • 在onCreateOptionsMenu的回调函数里面获取到SearchView,并设置监听(请注意使用MenuItemCompat的那行代码,否者会出现很多兼容性问题,获取不到这个View等等奇怪的BUG),在监听回调里面处理业务逻辑。

至此,其实就已经实现了一个基础的搜索功能。但是,如果为了能够让自己的应用的某些功能被Android系统的Search功能检索到,我们就需要做更进一步的操作,例如定义Searchable,实现一个SearchableActivity,响应系统的Search行为等等。国内的应用很少会去关注这个功能,这里就不展开了,感兴趣点击下面的链接进一步学习:https://developer.android.com/guide/topics/search/index.html。

8)Navigation Drawer, DrawerLayout, NavigationView

Navigation Drawer是Material Design当中很重要的一种设计元素,为了能够快速的实现这种设计,Android在新的design support包里面为我们提供了DrawerLayout与NavigationView。

实现这样的一个功能,我们需要在XML中写下类似下面的布局文件。 

在NavigationView中有两个重要的标签,app:headerLayout与app:menu,分别代表了拉出菜单的顶部布局与下面的菜单项列表。创建菜单项列表,可以使用类似下面的MenuItem文件: 

android:checked表示当前选中的Item,会被系统Highlight出来。除了上面简单的平铺的菜单,还可以使用菜单嵌套的方式实现多级的菜单。关于点击具体某个菜单的时候的监听与响应,需要做如下的设置:

除了点击菜单事件,我们还需要处理整个侧滑菜单的打开与关闭事件,当我们给DrawerLayout设置了setDrawerListener之后,可以得到两个回调。

原文链接:http://www.apkbus.com/blog-822415-76462.html

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/243664.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号