Style:

Style是View中一些属性的集合,包括height,padding,font color,background等等,Style单独定义在xml文件中,类似与web页面中css的角色,将设计和内容分开,便于修改和重复使用。

定义Style:

style文件需要保存在res/values目录下,文件名任意,但是必须是xml文件,sytle文件的根标记必须是<resources>。写了一个简单示例,效果如下:

程序目录结构如下图,其中mystyle.xml是自定义的style文件。

main.xml文件代码:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout
  3. xmlns:android="http://schemas.android.com/apk/res/android"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent">
  6. <TextView
  7. style="@style/CodeFont"
  8. android:text="测试style">
  9. </TextView>
  10. </LinearLayout>

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<TextView
style="@style/CodeFont"
android:text="测试style">
</TextView>
</LinearLayout>

声明style是CodeFont,对应的是style文件中的style name。mystyle.xml文件中定义了style name是CodeFont:

parent属性表示style之间可以继承,同时可以覆盖parent style的一些属性。

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <resources>
  3. <style name="CodeFont" parent="@android:style/TextAppearance.Medium">
  4. <item name="android:layout_width">fill_parent</item>
  5. <item name="android:layout_height">wrap_content</item>
  6. <item name="android:textColor">#00FF00</item>
  7. <item name="android:typeface">monospace</item>
  8. </style>
  9. </resources>

<?xml version="1.0" encoding="utf-8"?>
<resources>
<style name="CodeFont" parent="@android:style/TextAppearance.Medium">
<item name="android:layout_width">fill_parent</item>
<item name="android:layout_height">wrap_content</item>
<item name="android:textColor">#00FF00</item>
<item name="android:typeface">monospace</item>
</style>
</resources>

Style的继承:

style继承有两种方式:

  • style的继承可以通过parent属性,用来继承android已经定义好的style,例如:
  1. <style name="GreenText" parent="@android:style/TextAppearance">
  2. <item name="android:textColor">#00FF00</item>
  3. </style>

<style name="GreenText" parent="@android:style/TextAppearance">
<item name="android:textColor">#00FF00</item>
</style>

继承了android中的TextAppearance,同时覆盖了android:textColor属性。

  • 如果要继承自定义的style,不需要通过parent属性,只要style的name以需要继承的style的name开始后跟新的style的name,中间用“.”隔开。注意:这种方式只适用与自定义的style继承 。
  1. <style name="CodeFont.Red">
  2. <item name="android:textColor">#FF0000</item>
  3. </style>

<style name="CodeFont.Red">
<item name="android:textColor">#FF0000</item>
</style>

新的style继承了CodeFont,则在修改上边例子中的main.xml为:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout
  3. xmlns:android="http://schemas.android.com/apk/res/android"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent">
  6. <TextView
  7. style="@style/CodeFont.Red"
  8. android:text="测试style">
  9. </TextView>
  10. </LinearLayout>

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<TextView
style="@style/CodeFont.Red"
android:text="测试style">
</TextView>
</LinearLayout>

效果如下,字体颜色变为了红色:

style也可以多级继承:

  1. <style name="CodeFont.Red.Big">
  2. <item name="android:textSize">30sp</item>
  3. </style>

<style name="CodeFont.Red.Big">
<item name="android:textSize">30sp</item>
</style>

字号变大,效果如下:

sytle的更多属性见android包下的R.attr。需要注意,并不是所有的View都支持定义的style的属性,如果自定义的sytle中包含View不支持的属性,程序会自动忽略它。

Theme:

如果声明一个style作为Theme,需要配置mainfest文件中<activity> 或 <application>的android:theme 属性。

将自定义的style作为application的theme:

修改mystyle.xml为:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <resources>
  3. <style name="CodeFont">
  4. <item name="android:textSize">20sp</item>
  5. <item name="android:typeface">monospace</item>
  6. </style>
  7. </resources>

<?xml version="1.0" encoding="utf-8"?>
<resources>
<style name="CodeFont">
<item name="android:textSize">20sp</item>
<item name="android:typeface">monospace</item>
</style>
</resources>

在mainfest 的application中添加 android:theme属性:

  1. <application android:icon="@drawable/icon"
  2. android:label="@string/app_name"
  3. android:theme="@style/CodeFont">

<application android:icon="@drawable/icon"
android:label="@string/app_name"
android:theme="@style/CodeFont">

则application中的所有text字体都会改变,效果如下:

在每个<activity>标签中使用android:theme属性:

  1. <activity android:name=".MainActivity"
  2. android:label="@string/app_name"
  3. android:theme="@style/CodeFont">

<activity android:name=".MainActivity"
android:label="@string/app_name"
android:theme="@style/CodeFont">

android:theme还可以配置android中已经存在的theme:

  1. <activity android:theme="@android:style/Theme.Translucent">

<activity android:theme="@android:style/Theme.Translucent">

如果想调整android已经定义好的theme,则可以通过自定义style来实现,例如:

  1. <color name="custom_theme_color">#b0b0ff</color>
  2. <style name="CustomTheme" parent="android:Theme.Light">
  3. <item name="android:windowBackground">@color/custom_theme_color</item>
  4. <item name="android:colorBackground">@color/custom_theme_color</item>
  5. </style>

<color name="custom_theme_color">#b0b0ff</color>
<style name="CustomTheme" parent="android:Theme.Light">
<item name="android:windowBackground">@color/custom_theme_color</item>
<item name="android:colorBackground">@color/custom_theme_color</item>
</style>

效果如下:

关于在<activity>中android的Theme的详细使用见:android Theme使用总结

根据android版本选择主题:

在android新的版本中增加了新的theme,如果想在新版中利用新theme同时又兼容旧版本,可以通过配置两个theme文件实现,例如在res/values目录下配置sytle.xml文件:

  1. <style name="LightThemeSelector" parent="android:Theme.Light">
  2. </style>

<style name="LightThemeSelector" parent="android:Theme.Light">
</style>

在res/values-11目录下配置文件style.xml:

  1. <style name="LightThemeSelector" parent="android:Theme.Holo.Light" mce_bogus="1">
  2. </style>

<style name="LightThemeSelector" parent="android:Theme.Holo.Light" mce_bogus="1">
</style>

按照文档中说的在res下创建values-11目录,程序报错,需要找时间研究一下,说不定是android的一个bug。

使用Android提供的Style和Theme:

Android平台提供了大量的styles和themes,可以在android包中的R.style下找到,但是Android现在并未提供关于styles和themes的相关文档说明,具体可以参考styles.xml源码themes.xml源码 ,扫了一下,描述的很清楚。

Android中Style和Theme的使用的更多相关文章

  1. Android中style和theme的区别

    在学习Xamarin android的过程中,最先开始学习的还是熟练掌握android的六大布局-LinearLayout .RelativeLayout.TableLayout.FrameLayou ...

  2. Android:Style和Theme

    在Web开发中,Html负责内容,CSS负责表现.同样,在Android开发中,可以使用Theme.Style+UI组件的方式实现内容和形式的分离. Style是针对窗体元素级别的,改变指定控件或者L ...

  3. android的style控制Theme

    value-v14就是在API14(4.0)的手机上所使用的Theme(其他版本以此类推) theme的名字叫做AppTheme,后面写有继承自哪个Theme,如下所示 <style name= ...

  4. Android中的主题Theme

    系统自带的Theme: android以及为我们定义好了一些theme,需要是我们直接可以拿来使用. 常用的Theme通常如下:  android:theme="@android:style ...

  5. Android中style的使用

    摘自搜搜问问. <item name="#1">#2</item> 1.item 的name属性#1可以为所有系统所带组件的属性,#2为此属性的值如andr ...

  6. 【转】说说Android中的style和theme

    最近在做软件从2.3到4.0的改变的一些工作,其中涉及了一些style和theme相关的东西.上网上查了一些东西,这个一并说说.关于android中style和theme的基本使用,这里就不再赘述了, ...

  7. Android入门第十六篇之Style与Theme [转]

    本文来自http://blog.csdn.net/hellogv/ ,引用必须注明出处! 越来越多互联网企业都在Android平台上部署其客户端,为了提升用户体验,这些客户端都做得布局合理而且美观.. ...

  8. Android中如何利用attrs和styles定义控件

    一直有个问题就是,Android中是如何通过布局文件,就能实现控件效果的不同呢?比如在布局文件中,我设置了一个TextView,给它设置了 textColor,它就能够改变这个TextView的文本的 ...

  9. android 中theme.xml与style.xml的区别

    from://http://liangoogle.iteye.com/blog/1848448 android 中theme.xml与style.xml的区别: 相同点: 两者的定义相同. <r ...

随机推荐

  1. webapp框架—学习AngularUI1(demo折腾)

    angularUI下载地址:https://github.com/Clouda-team/BlendUI 下载解压后,demo在根目录 现在测试官网demo的使用 用浏览器打开mobile-angul ...

  2. 添加三维动画 demo

    - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typica ...

  3. 前端图片预览,上传前预览,兼容IE7、8、9、10、11,Firefox,Chrome(学习到的知识)

    文章地址:http://www.cnblogs.com/rubylouvre/p/4597344.html 一.window.URL 在Chrome中,window.URL和window.webkit ...

  4. 关于.NET的配置文件

    无论是exe文件还是dll文件,都可以添加App.config文件,里面设置配置信息.比如<appSettings></appSettings>之间,可以加入Key-Value ...

  5. bzoj 1853: [Scoi2010]幸运数字 容斥

    1853: [Scoi2010]幸运数字 Time Limit: 2 Sec  Memory Limit: 64 MBSubmit: 1170  Solved: 406[Submit][Status] ...

  6. 用 Webgoat 撬动地球,看安全测试的引路石!

    测试工程师是很多人迈进软件行业的起点.从负责很小的局部到把握整个产品的质量,每个人花费的时间长短不一--从功能到性能.可用性到容错性.从兼容性到扩展性.稳定性到健壮性--方方面面逐渐做广做深. 不过, ...

  7. SQL 能做什么?

    SQL 能做什么? SQL 面向数据库执行查询 SQL 可从数据库取回数据 SQL 可在数据库中插入新的记录 SQL 可更新数据库中的数据 SQL 可从数据库删除记录 SQL 可创建新数据库 SQL ...

  8. Velocity

    vm模板 设计原则 让前端来写后端的vm模板,并且前端不需要搭建各种繁杂的后端环境,前后端以 .vm 为沟通桥梁,另外模板的数据源可以在项目开始前前后端约定之后生成JSON文件,从而使两个角色并行开发 ...

  9. Android基础之响应Menu键弹出菜单Demo

    对于Android我也不是很熟悉,只是学习一些基本内容就OK.所以写的内容也很简单.本Demo要实现的效果就点击Menu键将弹出一个菜单并响应点击菜单项事件. 一.废话少说直接上代码.其实就是重写两个 ...

  10. Android+clipse导入工程提示:invalid project description

    今天遇到一个奇怪的问题.一个android的工程用eclipse导入的时候,提示错误.错误为:invalid project description . details为xxxx project ov ...