`
star65225692
  • 浏览: 273424 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类

android UI进阶之style和theme的使用

阅读更多

首先,style和theme都是资源,android提供了很多这样的默认资源。你可以来使用它们。同时你也可以自己定义style和 theme。这非常的简单,只需要在res/values/这个路径里面新建一个.xml文件,而且他的根节点必须 是<resources>.对 每一个style和theme,给<style>element增加一个全局唯一的名字,也可以选择增加一个父类属性,我们写的style和 theme就会继承这个父类的属性。style和theme的定义格式相同。不过style是针对view来说的,比如 TextView,EditText这些,而theme必须针对整个activity或者整个程序,你必须在AndroidManifest.xml中 的<application>或者<activity>中定义。 你可以在睡觉时翩翩起舞吗

先来看看style,比如如下一段代码:

<?
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的名字为CodeFont。 parent后面就是父类的style, CodeFont继承这个父类的属性。可以看到这个父类的style是android中默认的,你也可以继承你自定义的style,这时候不需要再写 parent属性,而是使用ContFont.red这样的方式,而且你可以继续继承,写成ContFont.red.small。 接下来每一个item定义一个属性。定义属性的最好方法就是在api文档里找到这个view的xml属性,比如在EditText中有InputType 这个属性,那么在你的style里面你就可以来定义它。

这样一个style就写好了。宁波海运2010年净利2322万元 同比增36%

使用也非常简单,我们只要在写我们的view时,加入style标签就可以了,就像这样

 

<
TextView

    
style
=
"
@style/CodeFont
"

    
android:text
=
"@string/hello"
 
/>

下面讲讲主题,前面已经说了。主题需要在AndroidManifest.xml中注册。如果你想整个程序都使用这个主题,你可以这样写

 

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

如果你只需要在某个Activity中使用主题,那么只要在Activity标签中写入android:theme=就可以了,android有很多好的默认主题,比如

 

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

这就会使你的整个Activity变成一个对话框形式,或者,如果你希望背景是透明的,可以这样写

 

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

同样的我们也可以继承父类theme,写法和style一样,就不赘述了。当然,和style一样,你也可以自己定义一个theme,写个例子

 

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


<
resources
>

 
<
style
 
name
=
"CustomTheme"
>

 
<
item name
=
"android:windowNoTitle"
>
true
<
/item>
 <item name="windowFrame">@drawable/
screen_frame
<
/item>
 <item name="windowBackground">@drawable/
screen_background_white
<
/item>
 <item name="panelForegroundColor">#FF000000</
item
>

 
<
item name
=
"panelBackgroundColor"
>
#FFFFFFFF</item>

 
<
item name
=
"panelTextColor"
>?
panelForegroundColor
<
/item>
 <item name="panelTextSize">14</
item
>

 
<
item name
=
"menuItemTextColor"
>?
panelTextColor
<
/item>
 <item name="menuItemTextSize">?panelTextSize</
item
>

 
</
style
>


</
resources
>

如果你要在java代码中加载主题的话,只要用setTheme(R.style.CustomTheme)就可以了,不过记得一定要在初始化任何view之前,比如一定要放在我们常用的setContentView()之前。通常,我们不建议这么做。

分享到:
评论

相关推荐

    android_UI进阶之style和theme的使用

    Android_UI进阶之style和theme的使用 Android 中的样式(style)和主题(theme)是两种资源,都是 Android 提供的默认资源,可以供开发者使用。同时,开发者也可以自己定义style和theme,以满足不同的需求。 style...

    Android示例大全教学 PDF

    9. **Style&Theme**:风格和主题是Android UI定制的关键,它们可以统一应用的视觉样式。这部分会教你怎么创建和应用自定义的样式和主题,以及如何利用主题在全局范围内影响应用外观。 10. **其他相关主题**:除了...

    超爽android中文教程 超爽android中文教程

    Android是全球最受欢迎的移动操作系统之一,它为开发者提供了丰富的功能和强大的开发工具,使得创建各种类型的应用程序变得可能。本教程“超爽Android中文教程”旨在帮助初学者和有一定经验的开发者深入理解Android...

    Android应用源码仿唱吧部分布局界面项目

    5. **主题与样式**:为了达到唱吧应用的视觉效果,你需要理解如何使用主题(Theme)和样式(Style)。这包括修改颜色、字体、边距等,以统一应用的视觉风格。 6. **事件监听与响应**:为使界面具有交互性,需要为UI...

    Android快速学习入门

    - `setTheme()` 方法:设置主题样式,这里选择了深色主题`android.R.style.Theme_Dark`。 - `setContentView()` 方法:设置布局文件,这里使用的是`R.layout.main`。 #### 三、布局文件解析 - **文件结构**:`res...

    第一行代码Android学习练习代码

    在深入学习Android时,还会接触到主题(Theme)、样式(Style)、权限管理、广播接收器(BroadcastReceiver)、服务(Service)、ContentProvider等概念。这些都是构建复杂Android应用的基础,它们帮助开发者实现更...

    Android 半透明对话框Demo源码-IT计算机-毕业设计.zip

    setStyle(DialogFragment.STYLE_NO_FRAME, android.R.style.Theme_Translucent); ``` 这将去除对话框的边框并应用半透明主题。 4. **显示对话框**:在适当的时候调用`show()`方法,将对话框添加到界面上。例如,...

    某500强android学习资料

    此外,还会涉及主题(Theme)和样式(Style)的应用,以及Material Design设计规范。 4. **数据存储**:Android支持多种数据存储方式,如Shared Preferences、SQLite数据库、文件存储和网络存储。资料会讲解各种...

    Android代码-更换软件主题apk方式.rar

    android:theme="@style/CustomTheme"&gt; ... ``` 或者针对某个活动: ```xml android:name=".MainActivity" android:theme="@style/CustomTheme"&gt; ``` 4. **打包APK** 完成主题定制后,使用Android ...

    Android+学习笔记

    setTheme(android.R.style.Theme_Dark); setContentView(R.layout.main); } ``` - **onCreate()方法**:这是Activity生命周期中的一个重要方法,用于初始化Activity组件。在本例中,`onCreate()`方法中设置了深色...

    Android(经典实例).pdf

    setTheme(android.R.style.Theme_Dark); setContentView(R.layout.main); } ``` - 这段代码的核心在于`setContentView()`方法,该方法用于设置活动的布局视图,参数`R.layout.main`是指向布局文件的引用。 **...

    android程序换皮肤之一

    - 使用风格(Style)和主题(Theme)进行统一的UI定义,便于管理和切换。 - 设计良好的接口,使皮肤更换逻辑与核心业务逻辑分离,提高代码复用性和可测试性。 8. **优化和进阶**: - 考虑使用插件化框架,如...

    Android 入门学习笔记实用源码

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

    Android初学者教程

    setTheme(android.R.style.Theme_Dark); setContentView(R.layout.main); } ``` - `setContentView()` 方法用于设置Activity的布局文件,即UI界面。 4. **布局文件解析**: - 布局文件通常位于`res/layout`...

    Android欢迎页面

    android:theme="@style/SplashTheme"&gt; &lt;action android:name="android.intent.action.MAIN" /&gt; &lt;category android:name="android.intent.category.LAUNCHER" /&gt; ``` 3. 编写Activity逻辑:在`...

    android制作静态在线考试系统界面,适合初学者学习界面

    学习如何使用样式(Style)、主题(Theme)来统一应用的视觉效果,以及如何通过约束布局(ConstraintLayout)实现自适应屏幕尺寸的界面设计。 6. **事件监听**:在按钮或其他交互元素上设置点击事件监听器,处理...

    Google Android SDK开发范例大全.docx

    指导如何将应用安装到实际的Android设备上进行测试,包括使用USB连接和无线部署等方法。 #### 第3章:用户人机界面 - **3.1 更改与显示文字标签——TextView标签的使用** 介绍了TextView组件的基本用法,包括...

    Android开发入门书籍

    - Style与Theme的区别 - 定义自定义样式 - 应用样式与主题 **2.19 处理不同屏幕尺寸(Chapter 25: Handling Multiple Screen Sizes)** - **知识点:** - 资源限定符 - 屏幕密度与尺寸分类 - 自适应布局策略...

    Android编程自定义圆角半透明Dialog的方法

    &lt;style name="dialog" parent="@android:style/Theme.Dialog"&gt; &lt;item name="android:windowFrame"&gt;@null &lt;item name="android:windowIsFloating"&gt;true &lt;item name="android:windowIsTranslucent"&gt;false ...

    booksystemtest.zip

    为了实现界面美观,开发者可能使用了Android的布局和样式文件,如XML布局文件定义各个组件的位置和样式,主题(Theme)和样式(Style)定义全局的视觉效果。此外,还可以通过Android的Material Design库来提升界面的...

Global site tag (gtag.js) - Google Analytics