统一的用户界面是可以使得应用程序更友好。要做到用户界面的统一,我们就必须用到风格(style)和主题(theme)。OPhone系统提供了很多系统默认的风格和主题,但是很多情况下,这些不能满足我们的需要。例如我们不可能总是希望背景色是系统规定的,我们也不希望字体大小一成不变。当然我们可以在每个空间里面进行修改,但是如果放到风格里面去做,可以更容易的做到用户界面统一。如果有朋友还不清楚什么是风格什么是主题,你可以在Andoird的Dev Guide文档里面找到详细的解释,这篇文章要描述的是开发者怎么定制自己的风格和主题,以满足开发者的要求,使得用户界面更容易实现。
在这篇文章中,我们用一个简单的例子来逐步展示如何定制风格。主要用到一个定制的类TextView。我们通过修改设定给TestView的风格,让你一步步的了解如何定制风格的。
(一)简单定制及应用风格
开发者在查询OPhone的Dev Guide文档时,可能已经发现文档介绍了一种简单的风格定制。这种简单的风格定制,可以满足很多用户的需要。比如你仅仅希望修改View的背景颜色,或者字体大小等。你所能修改的所有条目(item)都是系统已经定义过的,开发者可以改变条目的值,来来达到不同的效果。示例一就是这样一个简单定制。在values目录下创建styles.xml,然后把风格的名字定义为Widget.TestView。设置背景颜色为白色。
view plaincopy to clipboardprint?
<resources>
<style name=”Widget.TestView” parent=”android:Widget”>
<item name=”android:background”>#FFFFFFFF</item>
</style>
</resources><span style=”font-style: italic; font-size: 10.5pt; font-family: ‘Times New Roman’;”><br></span>
示例一
示例一展示了如何定制风格,要把定制的风格应用到示例中的TestView,还需要在layout/testtheme.xml文件使用TestView时,指定这个风格。做完这个步骤,然后运行示例程序就可以看到白色背景效果。示例二中,
你可以看到语句style=”@style/Widget.TestView”,就是起这个作用的。
view plaincopy to clipboardprint?
<com.android.mytest.TestView
style=”@style/Widget.TestView”
android:layout_width=”wrap_content”
android:layout_height=”wrap_content”/>
示例二
(二)定制风格条目
如果开发者想要进一步开发,他可能发现仅仅继承并修改系统定义好的条目不能满足他的需要。比如开发者想让定制的TestView上可以显示一个带颜色的圆圈,显然系统定义的条目没有关于圆圈的信息。那怎么来实现?用前面介绍的简单定制就不能满足开发者的需要了。
简单起见,这里我们假设TestView需要了解到圆圈的颜色和半径就可以绘制一个圆圈。可能有人会异议说,我们在TestView的代码里面直接写上不就可以了嘛,实现起来是没有问题。但是一旦用户修改就必须得修改代码,就有可能出错。如果我们把这些信息可以放到自己定制的风格里面,就简单多了。如果用户想修改颜色或者大小,只需要修改定义风格xml文件的信息,不需要修改代码。
好了,决定要添加圆圈信息了,首先在styles.xml里面,添加circleColor和circleRadius两个条目,并设置他们相应的值,示例三展示了如何添加这两个条目。是不是这样就万事大吉了那?如果你现在去编译,肯定会得到这两个条目不存在的错误信息。为什么呢?我们想一下,系统没有定义这两个条目,我们仅仅使用了这两个条目,也没有定义它们,当然不知道两个条目是什么东西了。
如果要让系统知道有这两个条目,我们首先要定义它们。在values目录下创建一个attrs.xml文件。然后添加圆圈的半径和颜色。
在attrs.xml里面可以定义很多类型的条目(item),例如integer, float, color, reference, string等。在这里只定义了两种一个是用color来定义颜色,一种是用float来定义半径。这些类型信息告诉OPhone的资源(Resource)系统如何去解读这些字段,
具体参看示例四。
view plaincopy to clipboardprint?
<resources>
<style name=”Widget.TestView” parent=”android:Widget”>
<item name=”android:background”>#FFFFFFFF</item>
<item name=”circleColor”>#FFFF0000</item>
<item name=”circleRadius”>60</item>
</style>
</resources>
示例三
view plaincopy to clipboardprint?
<resources>
<!– These are the attributes that make up customized theme. –>
<declare-styleable name=”TestView”>
<!– Default TestView style. –>
<attr name=”testViewStyle” format=”reference” />
<!– Color to use for the background of the Circle –>
<attr name=”circleColor” format=”color” />
<attr name=”circleRadius” format=”float”/>
</declare-styleable>
</resources>
示例四
在attrs.xml里面定义完成了,在styles.xml也添加了,现在你去编译应该不会有什么错误了。问题是,怎么让TestView知道这些信息。这两个条目是我们自己定义的,所以我们也得自己去添加一些代码让TestView了解到这些信息。以下的示例五,展示了怎么从资源总找到我们添加进去的两个条目的值。
view plaincopy to clipboardprint?
public TestView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
TypedArray a =
context.obtainStyledAttributes(
attrs, R.styleable.TestView, defStyle, 0);
int n = a.getIndexCount();
for (int i = 0; i < n; i++) {
int attr = a.getIndex(i);
switch (attr) {
case R.styleable.TestView_circleColor:
mCircleColor = a.getColor(attr, Color.RED);
break;
case R.styleable.TestView_circleRadius:
mCircleRadius = a.getFloat(attr, 40f);
break;
}
}
}
示例五
TestView获取到圆圈的颜色和半径信息后,就可以用这些信息去画开发者想要的圆圈了。关于如何画这个带颜色的圆圈,不是我们这里要描述的内容,请参看附件代码。
(三)设置默认风格
在第一部份讲到,如果开发者想要应用你所定制的风格给你定制的TestView,开发者用style=”@style/Widget.TestView”这种方式。如果开发者在他的应用里就用了一次TestView,我想这也没什么大不了的。但是如果开发者用到TestView的地方很多,这种方式就有点麻烦了,万一有时候还要修改这个风格,那就更糟糕了。下面是一个简单的方法,就是把你所定制的风格放到一个你自己定制的主题中去。关于创建一个主题,在OPhone的文档里面已经有了。细心的读者可能发现在示例四中,除了圆圈信息还有另外一个条目(testViewStyle),它的作用就是用在这里。在开发这定制的主题中,把这个条目的值设置为我们定制的风格(示例六),还记得风格的名字叫:Widget.TestView 吧?现在我们所定制的风格就是对这个TestView的默认风格了。
view plaincopy to clipboardprint?
<resources>
<style name=”Theme.OMS” parent=”android:Theme”>
<item name=”testViewStyle”>@style/Widget.TestView</item>
</style>
</resources>
示例六
然后就是应用所定制的主题到设计的应用,简单的一点的方式就是在AndroidManifest.xml中添加语句 android:theme=”@style/Theme.OMS”>。现在你就可以看到你所定制的风格的效果了。赶紧去编译运行一下。
本文首先描述了如何简单的定制风格,这种简单定制可以满足一部分要求,但是不能深度定制。如果要深度定制,就必须要开发者自己定义条目,并解析条目。最后介绍如何使用户定制的风格成为某个View的默认风格。
相关推荐
最后,Android的Material Design设计语言提供了统一的界面风格和交互指南。遵循这些指导原则,可以确保应用的界面既美观又易于使用。源码中可能包含如何应用Material Design组件和主题的示例。 总的来说,"安卓...
"安卓Android源码——win7风格的进度条源码.zip"是一个专为Android平台设计的资源包,它提供了模仿Windows 7操作系统风格的进度条组件的源代码。这个组件可以用于创建具有独特视觉效果的应用,为用户带来熟悉的界面...
这个"安卓Android源码——UITableView ios风格控件.rar"压缩包文件很可能包含了一个开源项目,它旨在模仿iOS的UITableView的功能,使得Android应用能够拥有类似的用户界面和交互体验。 在iOS的UITableView中,它...
Windows风格的Dialog是借鉴了桌面操作系统Windows的界面设计,通常具有清晰的边框、标题以及可定制的按钮布局。这个压缩包"安卓Android源码——实现Windows风格的Dialog.zip"很可能包含了一个自定义Dialog的实现,它...
"安卓Android源码——仿UCWEB界面源码.zip" 是一个与安卓应用开发相关的资源,其中包含了实现UCWEB浏览器界面风格的源代码。UCWEB是一款流行的移动浏览器,尤其在中国市场广泛使用。这个标题暗示了我们可以通过学习...
【Android源码——仿苹果通话界面源码】是一个Android开发项目,旨在实现与苹果iOS通话界面类似的用户界面和交互体验。这个源码可以帮助Android开发者学习和理解如何在Android平台上创建高度定制和美观的用户界面,...
【Android 源码分析:...通过以上步骤,我们不仅理解了如何使用Android源码实现Win7风格的进度条,还了解了自定义View的基本流程,包括绘制、动画以及属性定制。这将有助于我们更好地理解和扩展Android系统的UI组件。
本资源提供的"安卓Android源码——韩国风格的秒表源码.zip"是一个专门展示韩国风格秒表应用的实例,可以帮助开发者了解如何在Android环境下创建具有特定国家或地区特色的计时工具。 首先,这个源码示例涵盖了...
本资源"安卓Android源码——安卓Android实现Windows风格的Dialog.zip"提供了一种方法,让Android应用能够展示具有Windows样式特征的Dialog。 首先,理解Windows风格的Dialog通常包含的特点:边框、标题、最小化、...
综上所述,这个"Android源码——仿苹果通话界面源码.zip"项目涵盖了Android UI设计、自定义视图、事件处理、状态栏与导航栏定制、权限管理和性能优化等多个核心知识点。通过研究这个源码,开发者不仅可以学习到如何...
本资源"安卓Android源码——安卓Android实现Windows风格的Dialog.rar"提供了一种实现方式,帮助开发者在安卓系统上构建出与Windows系统类似风格的对话框。 首先,了解Dialog在Android中的基本使用。在Android SDK中...
在安卓Android平台上,开发者经常需要实现各种用户界面(UI)设计,其中可能包括模仿其他操作系统或应用的风格。本资源“安卓Android源码——仿苹果通话界面源码.zip”提供了一个示例,帮助开发者理解如何在Android...
在安卓开发中,为了提供独特的用户体验,开发者常常会尝试引入其他平台的设计元素,例如苹果iOS的界面风格。本文将深入探讨如何在Android平台上实现一个仿iPhone风格的翻页控件,这一过程涉及到对Android UI组件的...
这篇内容将深入解析“Android源码——仿乐淘的应用界面源码.zip”这一主题,重点关注在Android平台上构建类似乐淘应用界面的相关知识点。乐淘是中国知名的在线鞋类购物平台,其用户界面设计简洁且功能丰富,是...
本项目"Android——仿美图秀秀和IOS系统的相机胶卷"旨在实现一个高效且用户体验良好的图片浏览和管理应用。以下是基于这个项目的一些关键知识点: 1. **多媒体文件管理**: - `com.song.ImageManager.class`:这是...
【安卓Android源码——360新版特性界面源代码.zip】这个压缩包文件包含了360公司在其新版本中对于Android系统的一些定制化界面和功能的源代码。通过对这些源代码的学习和研究,我们可以深入了解如何在Android平台上...
该压缩包文件“安卓Android源码——安卓win8风格音乐播放器.zip”包含了一个基于Android平台的音乐播放器应用的源代码,其设计灵感来源于Windows 8的界面风格。这个项目可能对Android开发者,尤其是对UI设计和音乐...
【安卓Android源码——精典源码之精仿QQ设置界面】 在安卓开发中,精仿QQ设置界面是一项常见的需求,它涉及到用户界面(UI)的设计、布局管理、事件监听以及自定义控件等多个方面。这份源码提供了一个实现此类界面...
"安卓"和"android"表明这与Google的Android操作系统有关,而"源码"则意味着我们可以访问到这个组件的原始编程代码,可以进行学习、修改或定制以满足特定需求。 【知识点详解】 1. **Android开发环境**:在Android...