Support Library详解之Design Support
什么是Design Support Library
Design Support Library提供了用于向您的App添加Material Design(材料设计)风格的组件样式API。
那么Design Support Library都有什么呢?它包括:navigation drawers,floating action buttons (FAB), snackbars, 和 tabs 以及Material Design的EditText等等.
我们该如何添加Design Support Library支持呢?
很简单 如果你在使用Android Studio的话那么你只需要添加一句话
data:image/s3,"s3://crabby-images/7cefc/7cefccb590b20378350d197bd884e9d1a95b7c62" alt=""
好吧,如果你是小白又对Material Design十分的感兴趣那我不介意多写一点,如果你是大神那么可以跳过这一部分。
data:image/s3,"s3://crabby-images/6dcfb/6dcfb9b5211c64c3161b370ade3b9591c505eee0" alt=""
data:image/s3,"s3://crabby-images/9ea32/9ea3208eaec6c1ca1f1b76cd09fc6705232e5452" alt=""
data:image/s3,"s3://crabby-images/1cf7b/1cf7ba604fa980486b6b1c40a309fbcbbc79a8ba" alt=""
那么我们应该如何使用Design Support Library呢?
1.SnackBar
Snackbar提供了一个介于Toast和AlertDialog之间轻量级控件,它可以很方便的提供消息的提示和动作反馈。他的使用用法与Toast基本一致但是他可以对点击事件有更好的支持。
data:image/s3,"s3://crabby-images/f6838/f6838416c7d7f19811f3f24a028f4d01a27bcb80" alt=""
data:image/s3,"s3://crabby-images/8f605/8f605f8e0df71a3b79bb5d44949197dee358b77f" alt=""
Google API 官方说明文档地址:
http://developer.android.com/reference/android/support/design/widget/Snackbar.html
2.Floating Action Button
fab是一个圆形的按钮,谷歌建议这个按钮用作积极的意义,比如添加收藏等等,最好不要用于如删除等操作。他的默认颜色为主题中colorAccent。
data:image/s3,"s3://crabby-images/8f605/8f605f8e0df71a3b79bb5d44949197dee358b77f" alt=""
FloatingActionButton-fab的使用非常简单,把他当做一个button就可以了,最好是配合CoordinatorLayout布局使用,这个布局类似于一个加强的Framelayout,这个我们之后会提到的。
data:image/s3,"s3://crabby-images/c1d18/c1d18250d5b212fd09e72e9e0f2b745e2615d967" alt=""
fab有两种大小如果你希望使用一个小一点的可以在xml中添加一句这样的话:app:fabSize="mini"
另外他还可以设置FloatingActionButton.OnVisibilityChangedListener,用于监控他显示还是隐藏的改变
Google API 官方说明文档地址:
http://developer.android.com/reference/android/support/design/widget/FloatingActionButton.html
3.TextInputLayout
TextInputLayout作为一个父容器控件,包装了新的EditText。一般情况下,单独的EditText会在用户输入第一个字母之后就隐藏hint提示信息,但是现在你可以使用TextInputLayout 结合EditText使提示信息变成一个显示在EditText之上的标签,他的默认颜色也是主题中colorAccent。
data:image/s3,"s3://crabby-images/c20eb/c20ebaa01f61ebcfcd8dcb430e6f9b841ac73d35" alt=""
data:image/s3,"s3://crabby-images/98680/9868027d1fa302eb7591e03f6e844c40075657ec" alt=""
data:image/s3,"s3://crabby-images/b959a/b959afa5c263726c50a50ea51c65ac8da0732360" alt=""
TextInputEditText
data:image/s3,"s3://crabby-images/ed1cf/ed1cfd3e8cd2d7977c19bc983b4f29d79795e177" alt=""
data:image/s3,"s3://crabby-images/f145f/f145f8d5d50b5b7fe64b8d9da65a3da268bcbb19" alt=""
data:image/s3,"s3://crabby-images/61702/6170251e24d34886d77a6f7e713f305c5fd98d7f" alt=""
4.TabLayout
tablayout是用来实现标签的,那么他应该如何与ViewPager配合使用呢?
很简单:1,通过setOnTabSelectedListener设置一个监听器来响应选项卡的选择状态 2,通过setTabsFromPagerAdapter来使用PagerAdapter的page title 3,使用TabLayout.TabLayoutOnPageChangeListener来联动滑动
data:image/s3,"s3://crabby-images/ce9be/ce9be658dc1c12ad7cc96dc6fe6af7e8871feb03" alt=""
data:image/s3,"s3://crabby-images/27d58/27d58890e1914023f60156e3f6cfd4e94dd28adc" alt=""
data:image/s3,"s3://crabby-images/4e98c/4e98c6e84c25851fb0b45d251ebd3f44773f90d3" alt=""
大致上说Design库有几种控件,下一次我们将一起感受一直他的layout部分。