`
dato0123
  • 浏览: 915697 次
文章分类
社区版块
存档分类
最新评论

Android实例剖析笔记(六)

 
阅读更多

上一篇文章介绍了我对Snake这个示例程序进行的一些简单修改,从这一篇开始真正开始详细分析Snake的具体实现。

本文首先分析Snake的界面Layout实现,并通过一个实验来说明项目中使用的FrameLayoutRelativeLayout这两种布局的效果,其次还介绍了一个用于UI优化的工具---hierarchyviewer

Android Layout机制

1, FrameLayout

先来看官方文档的定义:FrameLayout是最简单的一个布局对象。它被定制为你屏幕上的一个空白备用区域,之后你可以在其中填充一个单一对象比如,一张你要发布的图片。所有的子元素将会固定在屏幕的左上角;你不能为FrameLayout中的一个子元素指定一个位置。后一个子元素将会直接在前一个子元素之上进行覆盖填充,把它们部份或全部挡住(除非后一个子元素是透明的)。

有点绕口而且难理解,下面还是通过一个实例来理解吧。我们仿照Snake项目中使用的界面一样,建立一个简单的FrameLayout,其中包含两个Views元素:ImageViewTextView,而后面的TextView还包含在一个RelativeLayout中。

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--><FrameLayoutxmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width
="fill_parent"
android:layout_height
="fill_parent">
<ImageView
android:layout_width="fill_parent"
android:layout_height
="fill_parent"
android:scaleType
="center"android:src="@drawable/img0"/>
<RelativeLayout
android:layout_width="fill_parent"
android:layout_height
="fill_parent">
<TextView
android:text="HelloAndroid"
android:visibility
="visible"
android:layout_width
="wrap_content"
android:layout_height
="wrap_content"
android:layout_centerInParent
="true"
android:gravity
="center_horizontal"
android:textColor
="#ffffffff"
android:textSize
="24sp"/>
</RelativeLayout>
</FrameLayout>

效果如下图所示:


2UI优化

Androidtools目录下提供了许多实用工具,这里介绍其中一个用于查看当前UI结构视图的工具hierarchyviewer

打开tools/hierarchyviewer.bat后,查看上面这个示例的UI结构图可得:


我们可以很明显的看到由红色线框所包含的结构出现了两个framelayout节点,很明显这两个完全意义相同的节点造成了资源浪费(这里可以提醒大家在开发工程中可以习惯性的通过hierarchyViewer查看当前UI资源的分配情况),那么如何才能解决这种问题呢(就当前例子是如何去掉多余的frameLayout节点)?这时候就要用到<merge />标签来处理类似的问题了。我们将上边xml代码中的framLayout替换成merge

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--><mergexmlns:android="http://schemas.android.com/apk/res/android">
<ImageView
android:layout_width="fill_parent"
android:layout_height
="fill_parent"
android:scaleType
="center"android:src="@drawable/img0"/>
<RelativeLayout
android:layout_width="fill_parent"
android:layout_height
="fill_parent">
<TextView
android:text="HelloAndroid"
android:visibility
="visible"
android:layout_width
="wrap_content"
android:layout_height
="wrap_content"
android:layout_centerInParent
="true"
android:gravity
="center_horizontal"
android:textColor
="#ffffffff"
android:textSize
="24sp"/>
</RelativeLayout>
</merge>

运行程序后在Emulator中显示的效果是一样的,可是通过hierarchyviewer查看的UI结构是有变化的,当初多余的FrameLayout节点被合并在一起了,或者可以理解为将merge标签中的子集直接加到ActivityFrameLayout跟节点下(这里需要提醒大家注意:所有的Activity视图的根节点都是frameLayout)。如果你所创建的Layout并不是用framLayout作为根节点(而是应用LinerLayout等定义root标签),就不能应用上边的例子通过merge来优化UI结构。


3RelativeLayout

RelativeLayout允许子元素指定他们相对于其它元素或父元素的位置(通过ID指定)。因此,你可以以右对齐,或上下,或置于屏幕中央的形式来排列两个元素。元素按顺序排列,因此如果第一个元素在屏幕的中央,那么相对于这个元素的其它元素将以屏幕中央的相对位置来排列。如果使用XML来指定这个layout,在你定义它之前,被关联的元素必须定义。

解释起来也比较麻烦,不过我做个对比实验可以明白它的用处了,试着把上面例子里的RelativeLayout节点去掉看看,效果如下图所示,可以看到由于FrameLayout的原因,都在左上角靠拢了,而使用了RelativeLayout,则可以让TextView相对于屏幕居中。


4Snake的界面分析
有了上述Layout的基础知识,我们再来看Snake的布局文件就很好理解了,就是一个SnakeView和一个TextView,启动后,后者会覆盖在前者上面。

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--><FrameLayoutxmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width
="fill_parent"
android:layout_height
="fill_parent">
<com.example.android.snake.SnakeView
android:id="@+id/snake"
android:layout_width
="fill_parent"
android:layout_height
="fill_parent"
tileSize
="24"
/>
<RelativeLayout
android:layout_width="fill_parent"
android:layout_height
="fill_parent">
<TextView
android:id="@+id/text"
android:text
="@string/snake_layout_text_text"
android:visibility
="visible"
android:layout_width
="wrap_content"
android:layout_height
="wrap_content"
android:layout_centerInParent
="true"
android:gravity
="center_horizontal"
android:textColor
="#ff8888ff"
android:textSize
="24sp"/>
</RelativeLayout>
</FrameLayout>

也就是这样的效果:



那么相应的代码是如何实现这个效果的呢?

SnakeView有一个私有变量存放覆盖其上的TextView

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->privateTextViewmStatusText;

Snake这个activityonCreate方法中,首先将Layout文件中的SnakeViewTextView关联起来:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->setContentView(R.layout.snake_layout);
mSnakeView
=(SnakeView)findViewById(R.id.snake);
mSnakeView.setTextView((TextView)findViewById(R.id.text));

然后设置SnakeView的状态为Ready

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->mSnakeView.setMode(SnakeView.READY);

这一句代码会调用下述函数:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->publicvoidsetMode(intnewMode)
{
intoldMode=mMode;
mMode
=newMode;
if(newMode==RUNNING&oldMode!=RUNNING)
{
//游戏进入“运行”状态,则隐藏文字信息
mStatusText.setVisibility(View.INVISIBLE);
update();
return;
}
//根据新状态,设置待显示的文字信息
Resourcesres=getContext().getResources();
CharSequencestr
="";
if(newMode==PAUSE)
{
//新状态为“暂停”
str=res.getText(R.string.mode_pause);
}
if(newMode==READY)
{
//新状态为“准备开始”
str=res.getText(R.string.mode_ready);
}
if(newMode==LOSE)
{
//新状态为“游戏失败”
str=res.getString(R.string.mode_lose_prefix)+mScore
+res.getString(R.string.mode_lose_suffix);
}
//设置文字信息并显示
mStatusText.setText(str);
mStatusText.setVisibility(View.VISIBLE);
}

mStatusText.setVisibility(View.VISIBLE);这一句后就显示出上面这个游戏起始画面了。


作者:phinecos(洞庭散人)
出处:http://phinecos.cnblogs.com/
本文版权归作者和博客园共有,欢迎转载,但请保留此段声明,并在文章页面明显位置给出原文连接

分享到:
评论

相关推荐

    Android实例剖析笔记

    Android实例剖析笔记 Android实例剖析笔记

    android开发资料大全

    Android实例教程 会员贡献索引贴 实用Android开发工具和资源精选 APK权限大全 - Android必懂知识 最无私的Android资料(书籍+代码)分享[总结] Android中文帮助教程(非常合适新手入门) android程序编写及调试...

    Android学习笔记之应用单元测试实例分析

    主要介绍了Android学习笔记之应用单元测试,结合实例形式较为详细的分析了Android单元测试的实现原理与具体步骤,具有一定参考借鉴价值,需要的朋友可以参考下

    android学习笔记

    1. 入门实例剖析1 2 2.在测试时,如何实现一个提示 8 3.可以使用AlertDialog.Builder 才产生一个提示框. 9 4. menu 的用法. 10 1. 简单的代码 10 2. menu实现的两种方法 10 5.Activity 的切换(含Bundle传值) 14 1. ...

    Android学习笔记之ActionBar Item用法分析

    主要介绍了Android学习笔记之ActionBar Item用法,结合实例形式分析了ActionBar Item的具体功能与相关使用技巧,需要的朋友可以参考下

    Android开发之电话拨号器实例详解

    主要介绍了Android开发之电话拨号器,结合实例形式详细分析了Android电话拨号器的实现步骤与具体代码,并附带了一个Android开放电话拨号器的学习笔记,需要的朋友可以参考下

    Android编程中全局变量问题分析

    本文实例讲述了Android编程中全局变量。分享给大家供大家参考,具体如下: 现在每天都在忙,而且一忙起来,就把写笔记的事情放在了后面,最近在写程序的时候,突然要使用全局变量,就按照以前的方式,写了一个类,...

    百度地图开发java源码-blog-backup:学习文章,也是我博客的备份

    中的实例,来分析 ViewGroup 的事件分发机制。 本章介绍 View(视图) 动画相关概念以及应用。 本篇介绍 Handler 和 Message 以及 Looper 的基本用法和工作原理。 本篇介绍 AsyncTask 的使用方法和工作原理 本篇介绍 ...

Global site tag (gtag.js) - Google Analytics