android UI进阶之style和theme的使用

本文详细介绍了Android开发中样式(style)和主题(theme)的概念及应用方法。解释了如何创建和使用自定义样式来统一界面元素的外观,并展示了如何通过主题来设定整个应用程序或活动的一致风格。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先,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()之前。通常,我们不建议这么做。

资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在当今的软件开发领域,自动化构建与发布是提升开发效率项目质量的关键环节。Jenkins Pipeline作为一种强大的自动化工具,能够有效助力Java项目的快速构建、测试及部署。本文将详细介绍如何利用Jenkins Pipeline实现Java项目的自动化构建与发布。 Jenkins Pipeline简介 Jenkins Pipeline是运行在Jenkins上的一套工作流框架,它将原本分散在单个或多个节点上独立运行的任务串联起来,实现复杂流程的编排与可视化。它是Jenkins 2.X的核心特性之一,推动了Jenkins从持续集成(CI)向持续交付(CD)及DevOps的转变。 创建Pipeline项目 要使用Jenkins Pipeline自动化构建发布Java项目,首先需要创建Pipeline项目。具体步骤如下: 登录Jenkins,点击“新建项”,选择“Pipeline”。 输入项目名称描述,点击“确定”。 在Pipeline脚本中定义项目字典、发版脚本预发布脚本。 编写Pipeline脚本 Pipeline脚本是Jenkins Pipeline的核心,用于定义自动化构建发布的流程。以下是一个简单的Pipeline脚本示例: 在上述脚本中,定义了四个阶段:Checkout、Build、Push packageDeploy/Rollback。每个阶段都可以根据实际需求进行配置调整。 通过Jenkins Pipeline自动化构建发布Java项目,可以显著提升开发效率项目质量。借助Pipeline,我们能够轻松实现自动化构建、测试部署,从而提高项目的整体质量可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值