现在的位置: 首页 > 综合 > 正文

开源中国Android版学习笔记(三) layout文件夹的xml文件(B)

2012年05月02日 ⁄ 综合 ⁄ 共 2089字 ⁄ 字号 评论关闭

      在layout文件夹中有四个首字母为B的xml文件,其实一看前缀就知道是关于blog细节的部分,依次是footer(页脚),header(页首),detail(正文)和listitem(引用),这四个文件构建了一个显示博客的页面。下面开始一一介绍:

1. blog_detail_footer:博客的页脚,下面根据效果图来理解代码:

      依旧是一个线性布局,之后有一个<ViewSwitcher>标签,它的作用是在两个视图间转换时显示动画。接下来是9个图片文件保存在一个LinearLayout中,分别是发表评论框,分割线,浏览正文,分割线,评论,分割线,收藏,分割线,分享,值得一提的是,这些图片都保存在drawable-hdpi中,而且有些有按下和没按下两种图片。后面又是一个线性布局,保存着按下发表评论框后变化的文本输入框和按钮,这就是<ViewSwitcher>标签的作用。在<EditText>标签中,有三个很有意思的属性,分别是focusable,focusableInTochMode和visibility,分别有设置是否获得焦点,可以通过touch事件来获得focus(这个以后会讲到),设置此视图是否显示这些功能,把意思理解后,这些属性也不难理解。

 2.blog_detail_header:博客的页眉,下附一张图:


用的是FrameLayout布局,因为考虑到要被覆盖,在这之中,我发现了一个有意思的问题:

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/blog_detail_header"
   	android:layout_width="fill_parent"
   	android:layout_height="wrap_content"
   	android:paddingLeft="2dip"
   	android:paddingRight="2dip"
   	android:gravity="center_vertical"
   	android:orientation="horizontal"
   	android:background="@drawable/head_bg">

      在这段代码最后一句是显示背景即head_bg,但是当我到drawable_hdpi文件夹中寻找它时,却发现原图是这个样子的:

很明显这张图在用到的时候被放大并旋转了,这里提出来,以后再去寻找它的代码。

      ok,回到层次布局,这里面依次有图片、文本、进度条和图片,按照顺序就是返回,显示“博客正文”,图中那样的进度条和刷新页面(这个和进度条是重合的)。也没啥难懂的,下一个。

3.blog_detail:博客的正文,看下图片来理解:


      这个就比较复杂了,开头是一个喜闻乐见的LinearLayout布局,下面有

<include layout="@layout/blog_detail_header"/>

      这段代码就是把之前讲的的页面插入进来,实现了代码的重用,后面的所有的代码被包括在ViewSwitcher中,实现的分屏动画效果(具体作用没看懂),这之后,这些又包括在一个ScrollView标签中,它的作用是为布局添加垂直滚动条。又是一个LinearLayout囊括了一个图片和文本,前者显示的是文章的类型(原创或者转载),后者是文章名。接着一个LinearLayout,依据图片看代码可得知分别是作者名,“发布于”,发布时间,被评论图标,评论数量。

	<View style="@style/detail_cut_line"/>

 
    上面那段代码是图中那条蓝色的分割线。

<WebView 
				android:id="@+id/blog_detail_webview"
		        	android:layout_width="fill_parent"
		        	android:layout_height="wrap_content"
			        android:background="@color/white"/>

      这段代码是网络视图,用于把网上文章显示出来。

 <include layout="@layout/comment_list"/>

      这段代码我还没找到用处,评价意见么?

   	<include layout="@layout/blog_detail_footer"/>

      结尾是把之前的页脚代码用上了,这就是完整的博客正文页面。

4.blog_detail_lisitem:引用,老实说,我认为这段代码应该放在正文之上的,因为这段代码的具体作用就是显示了页眉和网络视图之间的那段内容,但是不同于blog_detail_footer和blog_detail_header,在正文中,他没有想前者那样被include标签引用,真的不知道为什么,明明能简化代码,却没被使用,然后我仔细对比了两段代码,发现其中的数据很多不一样,可能是因为在正文中要适当的缩小的缘故吧。因为具体和正文内容一样就不一一介绍了。

OK,未完待续。

抱歉!评论已关闭.