Theme

作者: 背影杀手不太冷 | 来源:发表于2016-06-24 10:23 被阅读125次

    标签(空格分隔): 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设置单独主题了。

    相关文章

      网友评论

          本文标题:Theme

          本文链接:https://www.haomeiwen.com/subject/fmyodttx.html