Android Support Library 23.2

1387次阅读  |  发布于5年以前

Android Support Library 23.2

Android Support Library 23.2

当我们说起 Android Support Library 时,必须清楚的认识到这不仅仅只是一个库,而是一个能对API向后兼容的,提供独特的功能, 而不需要最新平台(plathform)支持的 库的集合。23.2版本在许多现有库的基础上增加一些新的支持以及功能。

Support Vector Drawables and Animated Vector Drawables

定义在XML里的矢量图片能替换大量的png图片资源,之前只有 API21 以及更高版本才能支持的功能,现在通过两个新增支持库 support-vector-drawable 和 support-animated-vector-drawable,分别提供了 VectorDrawable(矢量图片) 和 AnimatedVectorDrawable(矢量图片动画) 两项功能。

Android studio 1.4 通过在编译期间生成png图片来实现对矢量图的支持。关闭这项功能(以获得这一支持库的真正优势和节省空间,你需要在你的 build.gradle 文件添加代码:

    // Gradle Plugin 2.0+  
       android {  
           defaultConfig {  
           vectorDrawables.useSupportLibrary = true  
           }  
       }  

你将发现以上代码只适用于Gradle 2.0版本。如果你使用的是Gradle 1.5则使用下列代码

     // Gradle Plugin 1.5  
     android {  
         defaultConfig {  
             generatedDensities = []  
         }  

      // This is handled for you by the 2.0+ Gradle Plugin  
        aaptOptions {  
          additionalParameters "--no-version-vectors"  
        }  
     }  

VectorDrawableCompat 最低支持到 API7 ,AnimatedVectorDrawableCompat 最低支持到 API 11 。受限于android的图片加载机制,不是所有支持图片id的地方(例如xml文件里)都能使用矢量图。值得庆幸的是,兼容包(AppCompat)已经增加了许多功能,可以很容易地使用新的矢量绘图资源。

首先,当我们在ImageView(或者子类例如 ImageButton 和 FloatingActionButton)中使用兼容包时,你将会使用到新属性 app:srcCompat 来指定矢量图(所有 android:src 能够指定的图片 app:srcCompat都能指定)

     <ImageView  
      android:layout_width="wrap_content"  
      android:layout_height="wrap_content"  
      app:srcCompat="@drawable/ic_add" />  

如果需要在运行时切换图片,使用和之前一样的方法 setImageResource()。使用兼容包和 app:srcCompat是将矢量图整合进APP中最简单有效的方法。

你会发现系统版本在 Android Lollipop 之前的设备中直接引用矢量图而不是使用 app:srcCompat 属性引用矢量图的话都会失败。然而,当矢量图被 另一个 drawable容器(例如 StateListDrawable, InsetDrawable, LayerDrawable, LevelListDrawable,和 RotateDrawable)引用时,兼容包是可以加载该矢量图的。所以,在一些无法直接使用兼容包(直接使用app:srcCompat)的地方,可以通过间接的方式来使用矢量图,例如 TextView 的 android:drawleLeft 属性。

AppCompat DayNight theme

对矢量图的支持对兼容包已经是一个巨大的改变,在这个版本还增加了一个新的主题(Theme):Theme.AppCompat.DayNight.

在API14之前,DayNight主题以及相关的 DayNight.NoActionBar, DayNight.DarkActionBar, DayNight.Dialog 等等,提供了相同的亮度(意思是不支持API14之前?)。但是 API14 及 以后的设备,DayNight主题支持应用切换 白天 和 夜晚 主题,根据 是否为 ‘夜晚’ 决定是否从白天主题有效的切换到夜晚主题。

默认的,是否为 ‘夜晚’ 是由系统值(由方法 UiModeManager.getNightMode()取得)决定的,但是可以通过重写AppCompatDelegate中的方法来设置是否为‘夜晚’。您可以在app的整个生命周期(除非进程重启)设置这个默认值,设置该值的方法一种是通过静态方法 AppCompatDelegate.setDefaultNightMode() ,或者是 通过getDelegat()取得一个AppCompatDelegate 对象,然后调用方法setLocalNightMode() 来设置当前 activity 或者 dialog 的主题。

当使用 AppCompatDelegate.MODE_NIGHT_AUTO 值时,您的手机时间和您最后定位的地点(如果您的手机开启了定位许可)将会被用于切换白天和黑夜的依据, MODE_NIGHT_NO 和 MODE_NIGHT_YES 则分别强制设定了从不或是一直使用夜晚主题。

当使用白天主题时,彻底的测试是非常重要的,因为白天主题的亮度很可能导致一些文字或者图标变得不可阅读。如果将你的主题中标准的 TextAppearance.AppCompat 样式(例如 android:textColorPrimary)设置到文字或是颜色中,你将会发现他们已经自动更新了。

尽管如此,当你需要为夜晚主题定制一些特殊化资源时,兼容包会重新加载 夜晚专用资源文件夹(night resource qualifier folder),让定制所有资源变得可能。请考虑使用标准色彩,或是遵循兼容包所推荐的色彩方案,这样能让使用这个主题变得更加简单。

Design Support Library: Bottom Sheets

设计支持库提供了许多 Material Design 的格局,这个版本提供了对 bottom sheets 的支持。

在 CoordinatorLayout (即增加属性 app:layout_behavior=”android.support.design.widget.BottomSheetBehavior” )的子view附上一个 BottomSheetBehavior ,你将会得到五个状态的触摸回调。

如果你的抽屉(sheet)中有需要滑动的试图,请务必确保它能支持嵌套滑动(例如 NestedScrollView, RecyclerView, or ListView/ScrollView on API 21+)。

如果你需要接受状态回调,可以添加一个 BottomSheetCallback:

    // The View with the BottomSheetBehavior  
     View bottomSheet = coordinatorLayout.findViewById(R.id.bottom_sheet);  
     BottomSheetBehavior behavior = BottomSheetBehavior.from(bottomSheet);  
     behavior.setBottomSheetCallback(new BottomSheetCallback() {  
    @Override  
    public void onStateChanged(@NonNull View bottomSheet, int newState) {  
      // React to state change  
    }  
      @Override  
      public void onSlide(@NonNull View bottomSheet, float slideOffset) {  
       // React to dragging events  
       }  
     });  

此版本不仅提供了 BottomSheetBehavior 获取抽屉状态的回调,而且还提供了 BottomSheetDialog 和 BottomSheetDialogFragment 来覆盖所有应用场景。只需要简单的替换成 AppCompatDialog 或 AppCompatDialogFragment ,效果等于使用普通dialog并使用抽屉主题。

Support v4: MediaBrowserServiceCompat

Support v4 库为许多支持库提供了基础,并且为一些新版本介绍的特征提供支撑(backports).

之前发布了一个播放媒体的可靠的工具类 MediaSessionCompat, 在这之上,这个版本添加了 MediaBrowserServiceCompat 和 MediaBrowserCompat ,使得支持的版本扩展到 支持API4及其之后版本。提供了这个标准的接口,使得Service及UI界面与媒体的连接更加紧密,无论在Android设备 还是 Android Wear 上播放媒体都变得更加的便捷。

RecyclerView

RecyclerView 提供了先进、灵活的创建列表和网格的功能,并且支持动画。这个版本在 LayoutManager API中提供了一个令人兴奋的特性:auto-measurement.这使得 RecyclerView 可以根据内容的大小来决定自身的大小。RecyclerView之前不能使用的属性(例如WRAP_CONTENT),现在可以使用了。现在你会发现在LayoutManagers 中构建的控件现在都将支持 auto-measurement.

基于这个改变,请确保你的item的布局属性,之前忽略的布局属性(例如 在滑动方向上的MATCH_PARENT),现在将会完全的展开。

如果你自定义了一个LayoutManager并且不是之前的拓展,你可以调用 setAutoMeasureEnabled(true) 以及做一些细小的变化(详情请见Javadoc)来支持这项特性。

请注意,尽管 RecyclerView 可以设置子布局的动画,但是动画不会改变RecyclerView 自己的位置。如果你需要RecyclerView随着动画移动,请查看 Transition APIs.

Custom Tabs

Custom Tabs 可以在保持你的app外观,在用户毫无知觉的情况下无缝的过度到 web 内容。随着这项功能的发布,现在可以在底栏增加一个在侧边显示网站内容的动作。

随着新加的方法 addToolbarItem(),你现在可以在底栏增加五种动作,并且一旦会话开始就可以使用 setToolBarItem()更新他们。和之前的setToolbarColor()类似,你同样会发现一个setSecondaryToolbarColor()方法来自定义底栏的背景颜色。

Leanback for Android TV

Leanback Library 提供一个你需要的工具来方便的将你的应用适配到 Android TV 中,通过针对电视体验优化了的标准组件。GuidedStepFragment 在此版本得到了显著的改进。

最明显的变化可能是引入了一个两列可用的按钮动作(通过重写onCreatButtonActions()或者调用setButtonActions()添加的)。这使得到达列表底部更加简单,而不需要穿越整个list。

说到GuideActions,有一些新的功能,支持更丰富的输入,包括可编辑的描述(通过 descriptionEditable()方法),下拉动作的子动作(通过subActions()),还有 GuidedDatePickerAction。

当你需要时,这些组件让你更容易获取用户的意图。

Copyright© 2013-2020

All Rights Reserved 京ICP备2023019179号-8