(4.0.7)android的样式(style)与主题(theme)
⽂章⽬录
在Web开发中,Html负责内容,CSS负责表现。同样,在Android开发中,可以使⽤Theme、Style+UI组件的⽅式实现内容和形式的分离。
Android上的Style分为了两个⽅⾯:
1. Theme是针对窗体级别的,改变窗体样式;
2. Style是针对窗体元素级别的,改变指定控件或者Layout的样式。
Android系统的l和l(位于系统源代码frameworks\base\core\res\res\values)包含了很多系统定义好的style,建议在⾥⾯挑个合适的,然后再继承修改。
创建样式(style)与主题(theme)的步骤是⼀样的
1. 在res/values ⽬录下新建⼀个名叫l的⽂件。增加⼀个根节点。
2. 对每⼀个样式和主题,给< style >element增加⼀个全局唯⼀的名字,也可以选择增加⼀个⽗类属性。
在后边我们可以⽤这个名字来
应⽤样式,⽽⽗类属性标识了当前风格是继承于哪个样式。
3. 在< style >元素内部,申明⼀个或者多个< item >,每⼀个< item >定义了⼀个名字属性,并且在元素内部定义了这个样式的值。
4. 你可以应⽤在其他XML定义的资源。
1-style演⽰
样式是⼀个包含⼀种或者多种格式化属性(这些属性往往就是那些控件或者布局的属性)的集合,你可以将其⽤为⼀个单位⽤在布局XML 单个元素当中。⽐如,你可以定义⼀种样式来定义⽂本的字号⼤⼩和颜⾊,然后将其⽤在View元素的⼀个特定的实例
定义⼀个styles,在res/values/⽬录下建⽴l:
<style name="mystyle" parent="AppBaseTheme">
<item name="android:textSize">18sp</item>
<item name="android:textColor">#ff0000</item>
</style>
在布局⽂件中引⽤style
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/hello_world" />
在程序中设置style
text.setTextAppearance(this, style);
2-Theme演⽰
主题是⼀个包含⼀种或者多种格式化属性的集合,你可以将其为⼀个单位⽤在应⽤中所有的Activity当中或者应⽤中的某个Activity当 中。⽐如,你可以定义⼀个主题,它为window frame和panel 的前景和背景定义了⼀组颜⾊,并为菜单定义可⽂字的⼤⼩和颜⾊属性,你可以将这个主题应⽤在你程序当中所有的Activity⾥。
就像风格⼀样,主题依然在< style >元素⾥边申明,也是以同样的⽅式引⽤。不同的是你通过在Android Manifest中定义的< application >和< activity >元素将主题添加到整个程序或者某个 Activity,但是主题是不能应⽤在某⼀个单独的View⾥。
theme的style可以定义在l中,也可以单独定义在⾃⼰新建的l:
注意我们⽤了@符号和?符号来应⽤资源。@符号表明了我们应⽤的资源是前边定义过的(或者在前⼀个项⽬中或者在Android 框架中)。问号?表明了我们引⽤的资源的值在当前的主题当中定义过。通过引⽤在⾥边定义的名字可以做到(panelTextColor ⽤的颜⾊和panelForegroundColor中定义的⼀样)。这中技巧只能⽤在XML资源当中。
<?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>
2-1 在manifest当中设置主题
如果整个⼯程⽤⼀个主题就在application 标签中定义
android:theme="@style/myTheme"
如果你只是想让你程序当中的某个Activity拥有这个主题,就在activity标签中定义
<activity android:name=".Activity" android:theme="@style/Activity.Basic"/>
Android中提供了⼏种内置的资源,有好⼏种主题你可以切换⽽不⽤⾃⼰写。⽐如你可以⽤对话框主题来让你的Activity看起来像⼀个对话框。在manifest中定义如下:
<activity android:theme="@android:style/Theme.Dialog">
如果你喜欢⼀个主题,但是想做⼀些轻微的改变,你只需要将这个主题添加为⽗主题。⽐如我们修改Theme.Dialog主题。我们来继承Theme.Dialog来⽣成⼀个新的主题。
<style name="CustomDialogTheme" parent="@android:style/Theme.Dialog">
继承了Theme.Dialog后,我们可以按照我们的要求来调整主题。我们可以修改在Theme.Dialog中定义的每个item元素的值,然后我们在Android Manifest ⽂件中使⽤CustomDialogTheme ⽽不是 Theme.Dialog 。
2-2 在程序当中设置主题
如果需要的话,你可 以在Activity当中通过使⽤⽅法setTheme()来加载⼀个主题。注意,如果你这么做的话,你应该初始化任何View之前设置主题。⽐如,在调 ⽤setContentView(View) 和inflate(int, ViewGroup)⽅法前。这保证系统将当前主题应⽤在所有的UI界⾯。例⼦如下:
protected void onCreate(Bundle savedInstanceState) {
...
setTheme(android.R.style.Theme_Light);
setContentView(R.layout.linear_layout_3);
}
如果你打算在程序代码中来加载主界⾯的主题,那么需要注意主题当中不能包括任何系统启动这个Activity所使⽤的动画,这些动画将在程序启动前显⽰。在很多情况下,如果你想将主题应⽤到你的主界⾯,在XML中定义似乎是⼀个更好的办法。
安卓⾃带的主题android:theme
下⾯的前三个之外直接复制就会出错。@是说明系统已经定义过的,@android:style/ 是必须带上的。
android:theme="@android:style/Theme.Dialog" 将⼀个Activity显⽰为能话框模式
android:theme="@android:style/Theme.NoTitleBar" 不显⽰应⽤程序标题栏
android:theme="@android:style/Theme.NoTitleBar.Fullscreen" 不显⽰应⽤程序标题栏,并全屏
android:theme=“Theme.Light” 背景为⽩⾊
android:theme=“Theme.Light.NoTitleBar” ⽩⾊背景并⽆标题栏
android:theme=“Theme.Light.NoTitleBar.Fullscreen” ⽩⾊背景,⽆标题栏,全屏
android:theme=“Theme.Black” 背景⿊⾊
android:theme=“Theme.Black.NoTitleBar” ⿊⾊背景并⽆标题栏
android:theme=“Theme.Black.NoTitleBar.Fullscreen” ⿊⾊背景,⽆标题栏,全屏
android:theme=“Theme.Wallpaper” ⽤系统桌⾯为应⽤程序背景
android:theme=“Theme.Wallpaper.NoTitleBar” ⽤系统桌⾯为应⽤程序背景,且⽆标题栏
android:theme=“Theme.Wallpaper.NoTitleBar.Fullscreen” ⽤系统桌⾯为应⽤程序背景,⽆标题栏,全屏
android:theme=“Translucent” 背景为透明
android:theme=“Theme.Translucent.NoTitleBar” 透明背景并⽆标题栏
android:theme=“Theme.Translucent.NoTitleBar.Fullscreen” 透明背景并⽆标题栏,全屏
android:theme=“Theme.Panel” 内容容器
android:theme=“Theme.Light.Panel” 背景为⽩⾊的内容容器
安卓主题的常⽤属性
其他属性:可以在sdk查看: …\sdk\platforms\android-7\data\res\l
或者直接看继承的主题有的属性
<item name="android:windowFrame">@null</item>
Dialog的windowFrame框为⽆
<item name="android:windowNoTitle">true</item>
textstyle是否显⽰标题栏
<item name="android:windowFullscreen">?android:windowNoTitle</item>
是否填充慢屏幕,往往引⽤android:windowNoTitle 的值 ?android:windowNoTitle,取决于android:windowNoTitle的值
<item name="android:windowBackground">@android:color/transparent</item>
window的背景,注意是window
<item name="android:backgroundDimEnabled">false</item>:
背景是否模糊显⽰
android:windowIsFloating
是否浮现在activity之上
<item name="android:windowIsTranslucent">false</item>
是否半透明
android:windowContentOverlay
<item name="android:windowSoftInputMode">adjustPan</item>
键盘弹出后界⾯的调整模式
键盘弹出后界⾯的调整模式
activity主窗⼝与软键盘的交互模式,可以⽤来避免输⼊法⾯板遮挡问题,Android1.5后的⼀个新特性。
这个属性能影响两件事情:
【⼀】当有焦点产⽣时,软键盘是隐藏还是显⽰
【⼆】是否减少活动主窗⼝⼤⼩以便腾出空间放软键盘
它的设置必须是下⾯列表中的⼀个值,或⼀个”state…”值加⼀个”adjust…”值的组合。在任⼀组设置多个值——多个”state…”values,例如&mdash有未定义的结果。各个值之间⽤|分开。例如:<activity Android:windowSoftInputMode="stateVisible|adjustResize". . . >
值的含义:
【A】stateUnspecified:软键盘的状态并没有指定,系统将选择⼀个合适的状态或依赖于主题的设置
【B】stateUnchanged:当这个activity出现时,软键盘将⼀直保持在上⼀个activity⾥的状态,⽆论是隐藏还是显⽰
【C】stateHidden:⽤户选择activity时,软键盘总是被隐藏
【D】stateAlwaysHidden:当该Activity主窗⼝获取焦点时,软键盘也总是被隐藏的
【E】stateVisible:软键盘通常是可见的
【F】stateAlwaysVisible:⽤户选择activity时,软键盘总是显⽰的状态
【G】adjustUnspecified:默认设置,通常由系统⾃⾏决定是隐藏还是显⽰
【H】adjustResize:该Activity总是调整屏幕的⼤⼩以便留出软键盘的空间
【I】adjustPan:当前窗⼝的内容将⾃动移动以便当前焦点从不被键盘覆盖和⽤户能总是看到输⼊内容的部分
<item name="android:windowAnimationStyle">@style/Animation.Activity</item>
activity的进出动画style
<style name="NotAnimation.Activity" parent="@android:style/Animation">
<item name="android:activityOpenEnterAnimation">@null</item>
<item name="android:activityOpenExitAnimation">@null</item>
<item name="android:activityCloseEnterAnimation">@null</item>
<item name="android:activityCloseExitAnimation">@null</item>
<item name="android:taskOpenEnterAnimation">@null</item>
<item name="android:taskOpenExitAnimation">@null</item>
<item name="android:taskCloseEnterAnimation">@null</item>
<item name="android:taskCloseExitAnimation">@null</item>
<item name="android:taskToFrontEnterAnimation">@null</item>
<item name="android:taskToFrontExitAnimation">@null</item>
<item name="android:taskToBackEnterAnimation">@null</item>
<item name="android:taskToBackExitAnimation">@null</item>
</style>
<item name="android:textViewStyle">@style/</item>
⾃定义text风格
<style name="" parent="@android:style/Widget.TextView">
<item name="android:typeface">sans</item>
</style>
<item name="android:editTextStyle">@style/</item>
⾃定义editext风格
<style name="" parent="@android:style/Widget.EditText">
<item name="android:textColorHint">#cccccc</item>
</style>

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。