Web 在线数据建模

Android 之布局

1、RelativeLayout相对布局

a)、第一类:属性值为true或false
  android:layout_centerHrizontal 水平居中
  android:layout_centerVertical 垂直居中
  android:layout_centerInparent 相对于父元素完全居中
  android:layout_alignParentBottom 贴紧父元素的下边缘
  android:layout_alignParentLeft 贴紧父元素的左边缘
  android:layout_alignParentRight 贴紧父元素的右边缘
  android:layout_alignParentTop 贴紧父元素的上边缘  

  b)、第二类:属性值必须为id的引用名“@id/id-name
  android:layout_below 在某元素的下方
  android:layout_above 在某元素的的上方
  android:layout_toLeftOf 在某元素的左边
  android:layout_toRightOf 在某元素的右边
  android:layout_alignTop 本元素的上边缘和某元素的的上边缘对齐
  android:layout_alignLeft 本元素的左边缘和某元素的的左边缘对齐
  android:layout_alignBottom 本元素的下边缘和某元素的的下边缘对齐
  android:layout_alignRight 本元素的右边缘和某元素的的右边缘对齐



  c)、第三类:属性值为具体的像素值,如30dip,40px
  android:layout_marginBottom 离某元素底边缘的距离
  android:layout_marginLeft 离某元素左边缘的距离
  android:layout_marginRight 离某元素右边缘的距离
  android:layout_marginTop 离某元素上边缘的距离

1  <Button
2         android:id="@+id/button1"
3        android:layout_width="wrap_content"                //宽度匹配内容
4         android:layout_height="wrap_content"               //高度匹配内容  
5         android:layout_alignParentLeft="true"                         //贴紧父元素左边
6         android:layout_alignParentTop="true"               //贴紧父元素上边 
7         android:layout_marginLeft="20dp"                              //设置左间距20dp
8         android:layout_marginTop="20dp"                               //设置上间距20dp
9         android:text="第一个按钮" />
1 <Button
2         android:id="@+id/button2"
3         android:layout_width="wrap_content"              //宽度匹配内容
4         android:layout_height="wrap_content"              //高度匹配内容
5         android:layout_below="@+id/button1"              //位置在第一个按钮的下面
6         android:layout_toRightOf="@+id/button1"            //与第一个按钮的右边对齐
7         android:layout_marginTop="15dp"                            //设置上间距15dp
8      android:text="第二个按钮" />
1     <Button
2         android:id="@+id/button3"
3         android:layout_width="wrap_content"              //宽度匹配内容
4         android:layout_height="wrap_content"              //高度匹配内容
5         android:layout_below="@+id/button2"              //位置在第二个按钮的下面
6         android:layout_toLeftOf="@+id/button2"            //与第二个按钮的左边对齐
7         android:layout_marginTop="15dp"                //设置上间距15dp        
8         android:text="第三个按钮" />

 

 

2、LinearLayout线性布局

  LinearLayout是一种线型的布局方式。LinearLayout布局容器内的组件一个挨着一个地排列起来:不仅可以控制个组件横向排列,也可控 制各组件纵向排列。通过orientation属性设置线性排列的方向是垂直(vertical)还是纵向(horizontal)。

 

3、FrameLayout单桢布局

   FrameLayout对象好比一块在屏幕上提前预定好的空白区域,可以将一些元素填充在里面,如图片。所有元素都被放置在FrameLayout区域的最左上区域,而且无法为这些元素制指定一个确切的位置,若有多个元素,那么后面的元素会重叠显示在前一个元素上。

  说明:
  由于 FrameLayout 中后出现的 UI 控件会覆盖前面出现的 UI 控件,每次只能显示一个 UI 控件,因此,我们可以通过在 Activity 中对每次显示的图片内容进行切换以实现动画效果 。 或许你会想到开启一条线程来控制切换 , 但在非主线程中不能更新 UI 界面 , 所以 , 我们使用了Android 提供的消息通讯类 Handler 。该类可以实现非主线程和负责 UI 的主线程之间的通信 ,进而间接实现非主线程更新 UI 界面。由于 sleep 方法中的sendMessageDelayed(obtainMessage(0), delayMillis); 本身会延迟发送一个消息 , 该消息
会 被框架传递给 handleMessage 事件 。 我们在 handleMessage() 方法中再次调用 sleep() 方法 ,形成一个循环调用 。 在我们对界面进行点击之前 , 两个方法会一直循环调用 。 前景图片也会不断的切换,进而实现动画的效果。

4、TableLayout表格布局

  TableLayout是指将子元素的位置分配到行或列中。Android的一个TableLayout有许多TableRow组成,每一个 TableRow都会定义一个Row。TableLayout容器不会显示Row,Column,及Cell的边框线,每个Row拥有0个或多个 Cell,每个Cell拥有一个View对象。

  在使用tablelayout时,应注意每一个cell的宽度。

附:表格布局常见属性介绍

  (1)TableLayout行列数的确定
        TableLayout的行数由开发人员直接指定,即有多少个TableRow对象(或View控件),就有多少行。

        TableLayout的列数等于含有最多子控件的TableRow的列数。如第一TableRow含2个子控件,第二个TableRow含3个,第三个TableRow含4个,那么该TableLayout的列数为4.

  (2)TableLayout可设置的属性详解
  TableLayout可设置的属性包括全局属性及单元格属性。

  a)全局属性也即列属性,有以下3个参数:

  android:stretchColumns    设置可伸展的列。该列可以向行方向伸展,最多可占据一整行。

  android:shrinkColumns     设置可收缩的列。当该列子控件的内容太多,已经挤满所在行,那么该子控件的内容将往列方向显示。

  android:collapseColumns 设置要隐藏的列。

   示例:

  android:stretchColumns="0"           第0列可伸展

  android:shrinkColumns="1,2"         第1,2列皆可收缩

  android:collapseColumns="*"         隐藏所有行

  说明:列可以同时具备stretchColumns及shrinkColumns属性,若此,那么当该列的内容N多时,将“多行”显示其内容。(这里不是真正的多行,而是系统根据需要自动调节该行的layout_height)

  b)单元格属性,有以下2个参数:

  android:layout_column    指定该单元格在第几列显示

  android:layout_span        指定该单元格占据的列数(未指定时,为1)

  示例:

  android:layout_column="1"    该控件显示在第1列

  android:layout_span="2"        该控件占据2列

  说明:一个控件也可以同时具备这两个特性。

 1 <?xml version="1.0" encoding="utf-8"?>
 2 
 3 <TableLayout     
 4     xmlns:android="http://schemas.android.com/apk/res/android"    
 5     android:layout_width="match_parent"
 6     android:layout_height="match_parent"    
 7     android:stretchColumns="1">
 8   //第一行
 9     <TableRow
10         android:id="@+id/tableRow1"
11         android:layout_width="wrap_content"
12         android:layout_height="wrap_content" >
13 
14         <TextView
15             android:id="@+id/tvUserName"
16             android:layout_width="wrap_content"
17             android:layout_height="wrap_content"
18             android:text="用户名:" />
19 
20         <EditText
21             android:id="@+id/etUserName"
22             android:layout_width="wrap_content"
23             android:layout_height="wrap_content"
24             android:ems="10" >
25 
26             <requestFocus />
27         </EditText>
28 
29     </TableRow>
30     //第二行
31     <TableRow
32         android:id="@+id/tableRow2"
33         android:layout_width="wrap_content"
34         android:layout_height="wrap_content" >
35         <TextView 
36             android:text="登录密码:" 
37             android:textStyle="bold"
38             android:gravity="right" 
39             android:padding="3dp" /> 
40         <EditText 
41             android:id="@+id/password" 
42             android:password="true"
43             android:padding="3dp" 
44             android:scrollHorizontally="true" /> 
45     </TableRow> 
46   //第三行      
47     <TableRow
48         android:id="@+id/tableRow3"
49         android:layout_width="wrap_content"
50         android:layout_height="wrap_content" >
51         <Button 
52             android:id="@+id/cancel" 
53             android:text="注册" /> 
54         <Button 
55             android:id="@+id/login" 
56             android:text="登录" /> 
57     </TableRow>
58 
59 </TableLayout>

 

5、GridLayout网格布局

  android4.0以上版本出现的GridLayout布局解决了以上问题。GridLayout布局使用虚细线将布局划分为行、列和单元格,也 支持一个控件在行、列上都有交错排列。而GridLayout使用的其实是跟LinearLayout类似的API,只不过是修改了一下相关的标签而已, 所以对于开发者来说,掌握GridLayout还是很容易的事情。GridLayout的布局策略简单分为以下三个部分:

  首先它与LinearLayout布局一样,也分为水平和垂直两种方式,默认是水平布局,一个控件挨着一个控件从左到右依次排列,但是通过指定 android:columnCount设置列数的属性后,控件会自动换行进行排列。另一方面,对于GridLayout布局中的子控件,默认按照 wrap_content的方式设置其显示,这只需要在GridLayout布局中显式声明即可。

       其次,若要指定某控件显示在固定的行或列,只需设置该子控件的android:layout_row和android:layout_column属性即 可,但是需要注意:android:layout_row=”0”表示从第一行开始,android:layout_column=”0”表示从第一列开 始,这与编程语言中一维数组的赋值情况类似。

  最后,如果需要设置某控件跨越多行或多列,只需将该子控件的android:layout_rowSpan或者 layout_columnSpan属性设置为数值,再设置其layout_gravity属性为fill即可,前一个设置表明该控件跨越的行数或列数, 后一个设置表明该控件填满所跨越的整行或整列。

  <Button  
        android:id="@+id/zero"  
        android:layout_columnSpan="2"      //列扩展两列
        android:layout_gravity="fill"      //按钮填充满两格
        android:text="0"/>  

 

<?xml version="1.0" encoding="utf-8"?>  
<GridLayout                                     //网络布局管理器
    xmlns:android="http://schemas.android.com/apk/res/android"  
    android:layout_width="wrap_content"  
    android:layout_height="wrap_content"  
    android:orientation="horizontal"  			      //水平方向
    android:rowCount="5"                                                  //5行
    android:columnCount="4" >                                             //4列

 

6、Fragment布局

  Android是在Android 3.0 (API level 11)开始引入Fragment的。

  可以把Fragment想成Activity中的模块,这个模块有自己的布局,有自己的生命周期,单独处理自己的输入,在Activity运行的时候可以加载或者移除Fragment模块。

  可以把Fragment设计成可以在多个Activity中复用的模块。

  当开发的应用程序同时适用于平板电脑和手机时,可以利用Fragment实现灵活的布局,改善用户体验。

  Fragment生命周期

 

  因为Fragment必须嵌入在Acitivity中使用,所以Fragment的生命周期和它所在的Activity是密切相关的。

 

  如果Activity是暂停状态,其中所有的Fragment都是暂停状态;如果Activity是stopped状态,这个Activity中所有的Fragment都不能被启动;如果Activity被销毁,那么它其中的所有Fragment都会被销毁。

 

  但是,当Activity在活动状态,可以独立控制Fragment的状态,比如加上或者移除Fragment。

  当这样进行fragment transaction(转换)的时候,可以把fragment放入Activity的back stack中,这样用户就可以进行返回操作

 

7、include other layout

posted @ 2015-06-17 13:11  NetUML大数据搜索  阅读(862)  评论(0编辑  收藏  举报
Web 在线数据建模