标签(空格分隔): Android
Android Support兼容包详解###
Android的SDK版本很多,新的SDK版本包含了很多新的特性,为此Google官方提供Android Support Library package来保证高版本SDK的向下兼容。通过使用此包,可以让拥有最新SDK特性的应用运行在API lever 4(即Android 1.6) 及更高版本的设备之上。
- support-v4
用在API lever 4(即Android 1.6)或者更高版本之上。它包含了相对更多的内容,而且用的更为广泛,例如:Fragment,NotificationCompat,LoadBroadcastManager,ViewPager,PageTabStrip,Loader,FileProvider 等
compile 'com.android.support:support-v4:21.0.3'
//注意这里的是support,而下面的是appcompat!!!!
- support-v7
(V7已经是包含V4,gradle引用appcompat-v7包的时候就不需要引用v4了,)
这个包是为了考虑API level 7(即Android 2.1)及以上版本而设计的,但是v7是要依赖v4这个包的,v7支持了Action Bar以及一些Theme的兼容。
compile 'com.android.support:appcompat-v7:21.0.3'
//v7 appcompat library 是包含在 v7 Support Libraries里面的一个包,正是此包增加了Action Bar 用户界面的设计模式,并加入了对material design 的支持,是我们使用最多的一个兼容包。
使用appcompat之后,你的所有的Activity应该继承自ActionBarActivity,而ActionBarActivity继承自FragmentActivity,所以放心的使用Fragment;在AndroidStudio中用AppCompatActivity取代了ActinBarActivity
-
support-v13 (常用于平板开发)
这个包的设计是为了API level 13(即Android 3.2)及更高版本的,一般我们都不常用,平板开发中能用到, -
v17 Preference Support Library for TV
看名字就知道了,此包主要是为了TV设备而设计。 -
Design Support Library
Design Support Library除了带来兼容版本的Material Design,还将流行的第三方开源库进行了官方封装。里面有一些MaterialDesign的控件或者特性是support-v7 没有的,然后还有一些像cardview-v7 (com.android.support:cardview-v7:23.4.0)、recyclerview-v7 (com.android.support:recyclerview-v7:23.4.0)等等支持5.0以前的版本的兼容库,每个库都有自己特有的东西
Theme详解###
V7包不但包含Holo Theme还有Material Design Theme喔####
compile ‘com.android.support:appcompat-v7:21.0.3’
//这其中的21代表API level 21推出的兼容包,(即在21API系统5.0推出的有5.0功能的版本)所以如果你引用的是21之前的版本,则默认这些Theme.AppCompat.Light是Holo风格的,从21开始的版本默认是Material风格
Holo Theme####
在4.0(即API14)之后推出了Android Design,才有了Holo风格。是在4.0或者以上的版本才是这样的主题如:Theme.Holo.Light、 Theme.Holo.Light.DarkActionBar,
但是4.0的设计风格为了让4.0之前的版本也能有这种风格就不得不引用v7包了,可是因为引了兼容包所以对应的主题就变成了Theme.AppCompat.Light、 Theme.AppCompat.Light.DarkActionBar;虽然名字不一样,可是达到的效果是一样的!!!如果你的程序最小支持的版本是4.0,那么可以不用考虑v7的兼容。
Material Design Theme####
5.0版本,Android推出了Material Design的概念;在5.0版本的手机有Theme.Material.Light、 Theme.Material.Light.DarkActionBar等主题;在5.0之前就对应Theme.AppCompat.Light、 Theme.AppCompat.Light.DarkActionBar等主题。
关于
No resource found that matches the given name '@style/Theme.AppCompat.Light'
的主题冲突问题请见以下的博客链接
//这是因为build-tools的版本与appcompat包或者support包版本不合,多半是后者比前者的版本高
[博客链接][1]
Theme.AppCompat 主题中提供了这些组件的 Material Design style:
EditText
Spinner
CheckBox
RadioButton
SwitchCompat
CheckedTextView
values-v11 values-v14###
values-v11代表在API 11+的设备上,用该目录下的styles.xml代替res/values/styles.xml
values-v14代表在API 14+的设备上,用该目录下的styles.xml代替res/values/styles.xml
其中API 11+代表android 3.0 +
其中API 14+代表android 4.0 +
values-v9 ,values-v8,values-v1这些也都是有的,只不过很少用罢了
之所以values-v11用的比较多,是因为3.0版本就是为pad而专门设计的,所以一般这个都需要一些单独的配置
同时考虑到4.0以上的版本还是以手机为主,所以需要再添加一个values-v14
[1]: http://www.jianshu.com/p/6ad7864e005e
在代码中设置Activity的主题###
例如:setTheme(R.style.Theme_AppCompat);
Activity 是 ContextThemeWrapper的子类。而ContextThemeWrapper一个很重要的 属性就是Theme。实例化一个View必须要 new View(Context context) 。因为View需要把Attributes交给Context的Theme来确定一堆属性(在一个叫TypedArray的容器里)。比如当你没有定义TextView的字体颜色时,他该显示什么颜色。他要去问Theme。
下面说说style##
theme是全局的设计风格。style是局部的设计风格
系统是Light主题。而ToolBar需要Dark主题。可以给ToolBar单独设置一个 app:theme="@style/Theme.AppCompat"
而只有toolbar是特例。其他view并不能使用这个。
所以谷歌推出了 ThemeOverlay 来解决这个问题
<LinearLayout
android:theme="@android:style/ThemeOverlay.Material.Dark">
<!-- Anything here will also have a dark theme -->
</LinearLayout>
这样就可以给View设置单独主题了。
网友评论