转载请注明出处:http://blog.csdn.net/bbld_/article/details/40634829

翻译自: http://developer.android.com/training/material/compatibility.html

一些materialdesign中的功能像material主题和自己定义activity的过渡仅仅能在Android 5.0(API级别21)或以上的系统版本号中才干使用。可是你能够设计你的app去使用那些功能,不管在支持materialdesign的设备上亦或是早期的Android版本号上。

定义可选的样式

你能够配置你的app去使用material design在支持它的设备上,在早期的Android版本号中使用旧的主题:

1.        定义一个主题。它继承一个旧的主题(像Holo)。放在res/values/styles.xml。

2.        定义一个同样名字主题,继承material主题,放在res/values-21/styles.xml。

3.        在manifest文件里设置这个主题为你的app主题。

注意:假设你的app使用了material主题可是没有提供一个可替代的主题,你的app将无法在Android 5.0之前的系统中执行。

提供可替代的布局

假设你依据设计准则不使用不论什么Android5.0引入的新的XML的属性去设计你的布局。他们能在Android的早期版本号上执行。否则,你能够提供可选择的布局。你也能够提供可替代的布局。以自己定义你的app看起来是在早期的Android版本号上。

为Android 5.0(API级别21)或以上系统创建布局时则布局文件放在res/layout-v21/目录里。早期Android版本号的可替代的布局则放在res/layout/目录里。比如,res/layout/my_activity.xml是res/layout-v21/my_activity.xml的一个可替代的布局

为了避免反复的代码,在res/values/里定义你的样式资源。为新的API改动的样式则放在res/values-v21/目录里。而且使用样式继承,在res/values/中定义主要的样式。在res/values-v21/.中继承主要的样式。

使用支持库

v7支持库r21及以上的版本号包括下面的material design的特点:

l  当你应用Theme.AppCompat的主题时。一些控件具有materialdesign style的特征。

l  Theme.AppCompat具有Color palette theme属性。

l  RecyclerView控件显示数据集合。

l  CardView控件创建卡片。

l  Palette类去从图片中提取突出的颜色。

系统控件

Theme.AppCompat主题为这些控件提供了material design styles:

l  EditText

l  Spinner

l  CheckBox

l  RadioButton

l  SwitchCompat

l  CheckedTextView

颜色调色板

为了在Android v7支持库中获得material design styles和自己定义调色板,使用一个Theme.AppCompat的主题:

<!-- extend one of the Theme.AppCompat themes -->
<style name="Theme.MyTheme" parent="Theme.AppCompat.Light">
<!-- customize the color palette -->
<item name="colorPrimary">@color/material_blue_500</item>
<item name="colorPrimaryDark">@color/material_blue_700</item>
<item name="colorAccent">@color/material_green_A200</item>
</style>

列表和卡片

RecyclerViewCardView控件能够通过Android
v7支持包在早期的Android版本号上使用。可是有这些限制:

l  CardView回退到使用有规则的阴影通过使用额外的填充。

l  CardView不会裁剪它的子视图。使用圆角相交。

依赖

要在早于Android5.0(API级别21)的系统中使用这些功能。需加入Android v7支持库到你的项目中,以下是加入Gradle依赖

dependencies {
compile 'com.android.support:appcompat-v7:21.0.+'
compile 'com.android.support:cardview-v7:21.0.+'
compile 'com.android.support:recyclerview-v7:21.0.+'
}

补充:Eclipse中加入依赖在前面的博客中我已做了说明(Android Material Design-Creating Lists and Cards(创建列表和卡片)-(三))。

检查系统版本号

下面功能仅适用于Android的5.0(API等级21)以上:

l  Activity transitions(Activity的过渡转换)

l  Touch feedback(触摸反馈)

l  Reveal animations(显示、揭露动画)

l  Path-based animations(基于路径的动画)

l  Vector drawables(矢量画图资源)

l  Drawable tinting(Drawable着色)

为了保持与早期Android版本号的兼容性。在调用这些API之前检查系统的版本号

// Check if we're running on Android 5.0 or higher
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
// Call some material design APIs here
} else {
// Implement this feature without material design
}

注意:要指定你的app所能支持的版本号,使用在你的manifest文件里android:minSdkVersion和android:targetSdkVersion属性去声明。要在Android 5.0中须要使用material desing的功能,设置android:targetSdkVersionattribute属性的值为21.。很多其它的信息请參阅<uses-sdk>的API文档说明。

-----------------------------------------------------------------  Material Design系列的翻译完结  ----------------------------------------------------------------------

Android Material Design-Maintaining Compatibility(保持兼容性)-(七)的更多相关文章

  1. Android Material Design 兼容库的使用

    Android Material Design 兼容库的使用 mecury 前言:近来学习了Android Material Design 兼容库,为了把这个弄懂,才有了这篇博客,这里先推荐两篇博客: ...

  2. Android Material Design Ripple Effect在Android5.0(SDK=21)以下Android版本崩溃问题解决

    Android Material Design Ripple Effect在Android5.0(SDK=21)以下Android版本崩溃问题解决 附录1的Android Ripple Effect水 ...

  3. Android Material Design : Ripple Effect水波波纹荡漾的视觉交互设计

     Android Material Design : Ripple Effect水波波纹荡漾的视觉交互设计 Android Ripple Effect波纹荡漾效果,是Android Materia ...

  4. Android Material Design的FloatingActionButton,Snackbar和CoordinatorLayout

    如果是为了兼容低版本的Android系统,则需要引用Android Material Design的扩展支持库,我在之前的一篇文章张,较为详细的说明了如何导入Android Material Desi ...

  5. MaterialEditText——Android Material Design EditText控件

    MaterialEditText是Android Material Design EditText控件.可以定制浮动标签.主要颜色.默认的错误颜色等. 随着 Material Design 的到来, ...

  6. Android Material Design控件学习(三)——使用TextInputLayout实现酷市场登录效果

    前言 前两次,我们学习了 Android Material Design控件学习(一)--TabLayout的用法 Android Material Design控件学习(二)--Navigation ...

  7. Android Material Design 学习笔记 - Matrial Theme

    google在2014年 I/O大会上推出了一种新的设计设计语言—Material design,这种设计语言语言旨在为手机.平板电脑.台式机和“其他平台”提供更一致.更广泛的“外观和感觉”(附上官方 ...

  8. Android Material design

    1.Material Design:扁而不平 2.Android Support Design 库 之 Snackbar使用及源码分析 3.十大Material Design开源项目,直接拿来用!

  9. Android Material Design控件学习(一)——TabLayout的用法

    前言 Google官方在14年Google I/O上推出了全新的设计语言--Material Design.一并推出了一系列实现Material Design效果的控件库--Android Desig ...

随机推荐

  1. Android流行界面结构——Fragment通过ViewPager(带指示器)嵌套Fragment结构的创建方法详解

    原创文章,转载请注明出处http://www.cnblogs.com/baipengzhan/p/6287213.html 当前Android流行界面结构的一种——Fragment通过ViewPage ...

  2. 【7.1.1】ELK日志系统单体搭建

    ELK是什么? 一般来说,为了提高服务可用性,服务器需要部署多个实例,每个实例都是负载均衡转发的后的,如果还用老办法登录服务器去tail -f xxx.log,有很大可能错误日志未出现在当前服务器中, ...

  3. AI学习笔记(01)

    [1]在Ai中,每个对象有两个属性:填充颜色和描边颜色.   [2]在AI中,非要选中,才操作.而PS中,选中图层即可.   [3]AI中,都是路径.   [4]选择工具是选中整个路径,而直接选择工具 ...

  4. Web框架下安全漏洞的测试反思

    此文已由作者王婷英授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 在平时的测试中,一般情况下,我们都是比较关注功能业务测试,以及对应的接口测试,很少去关注对应的业务设计上存在 ...

  5. xtu DP Training B. Collecting Bugs

    B. Collecting Bugs Time Limit: 10000ms Memory Limit: 64000KB 64-bit integer IO format: %lld      Jav ...

  6. Go函数学习

    package main import ( "fmt" "reflect" "runtime" "math" ) //函 ...

  7. hdu 3940

    #include<stdio.h> #include<math.h> #include<string.h> double first(double vx,doubl ...

  8. hdu 1501 基本搜索深搜

    #include<stdio.h> #include<string.h> char s1[300],s2[300],s[500]; int len1,len2,len3,fla ...

  9. NodeJS仿WebApi路由

    用过WebApi或Asp.net MVC的都知道微软的路由设计得非常好,十分方便,也十分灵活.虽然个人看来是有的太灵活了,team内的不同开发很容易使用不同的路由方式而显得有点混乱. 不过这不是重点, ...

  10. PHP 常见问题2

    11.能够使 HTML 和 PHP 分离开使用的模板(1 分) 答: Smarty,Dwoo,TinyButStrong,Template Lite,Savant,phemplate,XTemplat ...