`
zangwenyang
  • 浏览: 127658 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

学习笔记:自定义样式(style)与主题(theme)

阅读更多
Android提供了许多可视的组件。通过自定义样式和主题,可以避免用这些组件开发的应用看上去千篇一律。

样式和主题都是通过预定义一系列属性值来形成统一的显示风格。区别是,样式只能应用于某种类型的View;而主题刚好相反,它不能应用于特定的View,而只能作用于一个或多个Activity,或是整个应用。

以下结合具体例子说明如何定义样式和主题:

1.定义样式和主题
    在工程中res/values/下添加styles.xml


<?xml version="1.0" encoding="utf-8"?>

<resources>

<!-- 定义my_style_1,没有指定parent,用系统缺省的 -->

<style name="my_style_1">

  <!-- 定义与指定View相关的若干属性 -->

  <item name="android:hint">load from style 1</item>

</style>



<!-- 定义my_style_2,用自定义的my_style_1作为parent -->

<style name="my_style_2" parent="@style/my_style_1">

  <!-- 定义与指定View相关的若干属性 -->

  <item name="android:textSize">30sp</item>

  <item name="android:textColor">#FFFF0000</item>

  <item name="android:hint">load from style 2</item>

</style>



<!-- 定义my_style_3,用android的EditText作为parent -->

<style name="my_style_3" parent="@android:style/Widget.EditText">

  <!-- 定义与指定View相关的若干属性 -->

  <item name="android:hint">"load from style 3"</item>

  <item name="android:textStyle">bold|italic</item>

  <item name="android:typeface">monospace</item>>

  <item name="android:background">@drawable/mybackground</item>

</style>



<!-- 定义MyTheme,用android的Theme作为parent -->

<style name="MyTheme" parent="@android:style/Theme">

  <item name="android:textSize">20sp</item>

  <item name="android:textColor">#FF0000FF</item>

  <item name="android:hint">"load from style 3"</item>

  <item name="android:textStyle">bold|italic</item>

  <item name="android:typeface">monospace</item>>

  <item name="android:background">@drawable/gallery_selected_pressed</item>

  <item name="myStyle">@style/my_style_3</item>

</style>

</resources>



主题和样式的定义方法类似,都是在<style>下添加N个<item>。
    <style>下有两个有用的属性:
         name - 以后引用时会用到;
         parent - 可选,一些在自定义的style中没有指定的属性会继承parent style中的值。parent可以是android预定义的resource,也可以是自己定义的style。
    <item>下定义需要改变的属性值。Android中能使用的属性可以在<sdk>/docs/reference/android/R.styleable.html中查到;也可以用自己定义的属性值;

2.使用主题
a)从AndroidManifest中指定,可以选择Application应用级:


    <application android:theme="@style/MyTheme">


或是Activity级:
  
    <activity android:theme="@style/MyTheme">

b)从Java代码中指定:
    
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
       setTheme(R.style.MyTheme);
        setContentView(R.layout.main);
    }


3.使用样式
a)从layout的xml文件中指定:
    <EditText android:id="@+id/EditText03" 
          style="@style/my_style_3"
          android:layout_width="fill_parent" 
          android:layout_height="wrap_content">
</EditText>

b)从Java代码中指定:

    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        setTheme(R.style.MyTheme);
        setContentView(R.layout.main);
        LinearLayout ll = (LinearLayout)findViewById(R.id.llMain);
        
        EditText et = new EditText(this, null, R.attr.myStyle);
        ll.addView(et);
    }


-----------------
附件中是用到的具体例子
referenece:<android-sdk-windows-1.5_r2>/docs/guide/topics/ui/themes.html

=====================================================
转载自http://www.eoeandroid.com/viewthread.php?tid=1277&extra=&highlight=%E4%B8%BB%E9%A2%98&page=1

文章写得很基础是入门级材料,但是很多东西还要自己去doc中学
分享到:
评论
1 楼 spysoos 2013-05-16  
谢谢分享了

相关推荐

    Android 入门学习笔记实用源码

    样式(Style)和主题(Theme)是Android中用于统一应用UI外观的方式。它们定义在res/values/styles.xml文件中,可以应用于Activity、View或整个应用。理解如何创建和应用样式,以及使用父样式和属性继承,能提高...

    学习笔记----Android的对话框

    - 主题(Theme):通过设置对话框的style属性,可以改变对话框的整体样式,如颜色、形状等。 - 图标(setIcon):可以为对话框添加图标,增强视觉效果。 5. ProgressDialog的使用: - 进度条类型:有两种,圆形...

    Android PreferenceActivity 学习笔记

    这篇学习笔记将深入探讨PreferenceActivity的使用方法、功能以及与源码相关的知识。 首先,PreferenceActivity是Android SDK提供的一种特殊类型的Activity,它允许开发者快速构建具有可配置选项的界面,类似于系统...

    android学习笔记

    Android中的主题(Theme)决定了Activity的视觉样式和行为。在XML布局文件中,我们可以通过`android:theme`属性为Activity指定主题。例如: ```xml android:name=".YourActivity" android:theme="@android:style...

    theme_adaptable_moodle37_2020042500 (1)_Moodle_

    为了充分利用"Adaptable"主题,Moodle管理员需要了解一些关键概念,如区域管理(regions management)、主题配置(theme settings)和样式覆盖(style overrides)。区域管理允许用户决定在页面上显示哪些区块,而...

    C#学习笔记....

    根据提供的文件信息,我们可以整理出以下关于C#与ASP.NET的关键知识点: ...这些知识点覆盖了控件操作、用户控件属性设置、主题与皮肤的应用以及CSS样式的使用等方面,对于初学者来说是非常实用且基础的技能。

    Android 学习笔记

    - **预定义主题**:Android 提供了一系列预定义的主题,可以在 `AndroidManifest.xml` 文件中通过 `&lt;activity android:theme="@style/Theme.Dialog"/&gt;` 设置。 - **自定义主题**:可以通过在 `res/values` 目录下的 ...

    第一行代码笔记

    - 在Activity的XML布局文件中设置`android:theme="@android:style/Theme.Dialog"`可以实现对话框样式的自定义。 8. **TextView文本省略处理**: - `android:ellipsize`属性可以设置当文本超过容器宽度时如何处理,...

    create-a-custom-theme-d8:在Drupal 8中有关主题的演示

    在Drupal 8中创建自定义主题是一个涉及到网页设计与开发的重要步骤,这允许你根据自己的需求和品牌风格来定制网站的外观和交互。本演示将引导你了解如何使用Drupal 8的主题系统,以及如何结合使用reveal.js框架来...

    bootstrap基础知识学习笔记

    Bootstrap 基础知识学习笔记主要涵盖了以下几个核心概念: 1. **引入 Bootstrap**:在 HTML 文件中,你需要引入 Bootstrap 的 CSS 和 JavaScript 文件。这通常包括 jQuery(因为 Bootstrap 的某些组件依赖于它)。...

    roam-research-themes-share:分享我最喜欢的主题

    - **兼容性**:确保你选择的主题与当前Roam Research的版本兼容,因为不同版本可能会有小的界面调整,不兼容的主题可能导致部分样式失效。 - **备份**:在修改默认样式前,最好备份原有的[[roam / css]]页面,...

    Android开发笔记——UI基础编程

    开发者可以通过定义主题(Theme)和样式(Style)来统一应用的视觉风格,包括字体、颜色、边距等。这可以在全局的res/values/styles.xml文件中定义,并应用于整个应用或特定Activity。 六、自定义视图 当系统默认的...

    jquery pagination使用(笔记)

    jQuery Pagination 提供了一种简单的方法来创建美观的分页组件,它支持自定义样式、事件监听和多种配置选项。这个插件通常与 AJAX 数据加载结合使用,使得页面无需刷新即可动态加载更多内容。 ### 二、安装与引入 ...

    Angular学习笔记之集成三方UI框架、控件的示例

    安装完成后,需要在Angular CLI配置文件(`angular.json`)中引入Material的主题样式: ```json "styles": [ "node_modules/@angular/material/prebuilt-themes/indigo-pink.css" ] ``` 或者在`style.css`中...

    jQuery Pagination分页插件.zip

    cssStyle: "light-theme", // 样式主题 displayPerPage: false, // 是否显示每页显示条数选项 prevText: "上一页", nextText: "下一页", onPageClick: function(pageNumber, event) { // 分页跳转时执行的回调...

    新版Android开发教程+笔记七--基础UI编程

    Android允许通过主题(Theme)和样式(Style)来统一应用的外观。主题可以全局改变应用的视觉效果,比如字体、颜色方案;样式则可以单独应用于某个UI元素,提供一致的设计。 七、自定义视图 如果预定义的组件不能...

Global site tag (gtag.js) - Google Analytics