Android 之 布局训练

Posted Not-Bad

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Android 之 布局训练相关的知识,希望对你有一定的参考价值。

 

1.线性布局 LinearLayout

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"

    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="org.example.linearlayout.MainActivity">

    <ListView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/list_view"
        />
</LinearLayout>
package org.example.linearlayout;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.ArrayAdapter;
import android.widget.ListView;

public class MainActivity extends AppCompatActivity {

    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        ArrayAdapter<String> items = new ArrayAdapter<String>(MainActivity.this, android.R.layout.simple_list_item_1);
        items.addAll("raspberry", "apple", "banana", "orange",
                "watermelon", "pear", "grape", "pineapple", "strawberry", "cherry", "mango");
        ListView listView = (ListView) findViewById(R.id.list_view);
        listView.setAdapter(items);

    }
}

2.表格布局

常用属性:

TableLayout属性(也叫全局属性):*代表所有列

android:shrinkColumns -------设置可收缩的列,(内容过多,则收缩,扩展到第二行,控件没布满TableLayout时不起作用)
android:stretchColumns ------设置可伸展的列,(有空白则填充)列可以同时具备stretchColumns及shrinkColumns属性
android:collapseColumns ------设置要隐藏的列(索引列从0开始)
 
android:layout_column -------该单元格在第几列显示
android:layout_span    -------该单元格占据列数,默认为1
例:
android:stretchColumns="0"           第0列可伸展
android:shrinkColumns="1,2"         第1,2列皆可收缩
android:collapseColumns="*"         隐藏所有行

表格布局示例

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <TableLayout android:id="@+id/Table1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:shrinkColumns="1"
        android:stretchColumns="2">

        <Button android:id="@+id/ok1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="按钮占一行"/>

        <TableRow>
            <Button android:id="@+id/ok2"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="普通按钮"/>
            <Button android:id="@+id/ok3"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="收缩的按钮,可扩展到第二行"/>
            <Button android:id="@+id/ok4"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="拉伸的按钮,可以拉伸"/>
        </TableRow>

        <TableRow>
            <Button android:id="@+id/ok6"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="普通按钮"/>
            <Button android:id="@+id/ok7"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="普通按钮"/>
            <Button android:id="@+id/ok8"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="普通按钮"/>
        </TableRow>

        <TableRow>
            <Button
                android:id="@+id/ok13"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="普通按钮"
                />
            <Button
                android:id="@+id/ok14"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="拉伸的按钮,可以拉伸"
                />
        </TableRow>
    </TableLayout>
</LinearLayout>

3.帧布局

 常用属性:

android:foreground:设置改帧布局容器的前景图像 
android:foregroundGravity:设置前景图像显示的位置

代码:

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <TextView
        android:id="@+id/view1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="right|bottom"
        android:width="160pt"
        android:height="160pt"
        android:background="#f00"/>
    <TextView
        android:id="@+id/view2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:width="140pt"
        android:height="140pt"
        android:background="#0f0"/>
    <TextView
        android:id="@+id/view3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left"
        android:width="120pt"
        android:height="120pt"
        android:background="#00f"/>
    <TextView
        android:id="@+id/view4"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="bottom"
        android:width="100pt"
        android:height="100pt"
        android:background="#ff0"/>
    <TextView
        android:id="@+id/view5"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="top"
        android:width="80pt"
        android:height="80pt"
        android:background="#f0f"/>
    <TextView
        android:id="@+id/view6"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:width="60pt"
        android:height="60pt"
        android:background="#0ff"/>
</FrameLayout>

4.相对布局

<!--属性值为具体像素值的属性,如30dip,40px-->
android:layout_marginBottom  离某元素底边缘的距离
android:layout_marginLeft    离某元素左边缘的距离
android:layout_marginRight   离某元素右边缘的距离
android:layout_marginTop     离某元素上边缘的距离
<!--设为其他组件ID的属性-->
android:layout_alignBottom 将该控件的底部边缘与给定ID控件的底部边缘对齐,并置于父窗口最左边,会覆盖最左边的控件 
android:layout_alignLeft 将该控件的左边缘与给定ID控件的左边缘对齐,并置于父窗口最上边,会覆盖最上边的控件 
android:layout_alignRight 将该控件的右边缘与给定ID控件的右边缘对齐,并置于父窗口最上边,会覆盖最上边的控件 
android:layout_alignTop 将给定控件的顶部边缘与给定ID控件的顶部对齐,并置于父窗口最左边,会覆盖最左边的控件
android:layout_above 将该控件的底部至于给定ID的控件之上,但不会左对齐,默认置于父窗口最左边,会覆盖最左边的控件 
android:layout_below 将该控件的顶部至于给定ID的控件之下,但不会左对齐,默认置于父窗口最左边,会覆盖最左边的控件 
android:layout_toLeftOf 将该控件的右边缘和给定ID的控件的左边缘对齐,默认置于父窗口最上面,会覆盖最上面的控件 
android:layout_toRightOf 将该控件的左边缘和给定ID的控件的右边缘对齐,默认置于父窗口最上面,会覆盖最上面的控件
android:layout_alignBaseline该控件的baseline和给定ID的控件的baseline对齐,并置于父窗口最左边,会覆盖最左边的控件
<!--设为boolean值得属性-->
android:layout_centerHorizonal="true"     水平居中
android:layout_centerVertical="true"      垂直居中
android:layout_centerInParent="true"      位于中央位置
android:layout_alignParentBottom ="true"  控件的底部和父控件的底部对齐,默认置于父窗口最左下,会覆盖最左下的控件 
android:layout_alignParentLeft="true"     控件的左边与父控件的左边对齐,默认置于父窗口最左上,会覆盖最左上的控件 
android:layout_alignParentRight="true"    控件的右边与父控件的右边对齐,默认置于父窗口最右上,会覆盖最右上的控件 
android:layout_alignParentTop="true"      控件的顶部与父控件的顶部对齐,默认置于父窗口最左上,会覆盖最左上的控件
android:layout_alignParentStart="true"    控制该组件和布局管理器开始对齐
android:layout_alignParentEnd="true"      控制该组件是否和布局管理器末端对齐。
android:layout_centerHorizontal="true"    控件将被至于水平方向的中央(默认父布局的上方)  
android:layout_centerInParent="true"      控件将被至于父控件水平方向和垂直方向的中央  
android:layout_centerVertical="true"      控件将被至于垂直方向的中央(默认父布局的左边)
android:layout_alignWithParentIfMissing="true"    如果对应的兄弟元素找不到的话就以父元素做参照物

 代码如下:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <TextView
        android:id="@+id/view1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:width="30pt"
        android:height="30pt"
        android:layout_marginBottom="10pt"
        android:layout_marginLeft="10pt"
        android:layout_marginRight="10pt"
        android:layout_marginTop="10pt"
        android:background="#f00"/>
    <TextView
        android:id="@+id/view2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_above="@id/view1"
        android:layout_alignLeft="@id/view1"
        android:width="30pt"
        android:height="30pt"
        android:background="#0f0"/>
    <TextView
        android:id="@+id/view3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@id/view1"
        android:layout_alignLeft="@id/view1"
        android:width="30pt"
        android:height="30pt"
        android:background="#00f"/>
    <TextView
        android:id="@+id/view4"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_toLeftOf="@id/view1"
        android:layout_alignTop="@id/view1"
        android:width="30pt"
        android:height="30pt"
        android:background="#ff0"/>
    <TextView
        android:id="@+id/view5"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_toRightOf="@id/view1"
        android:layout_alignTop="@id/view1"
        android:width="30pt"
        android:height="30pt"
        android:background="#f0f"/>

</RelativeLayout>

5.网格布局

android:layout_column                设置该子组件在GridLayout的第几列 
android:layout_columnSpan            设置该子组件在GridLayout横向上跨几列 
android:layout_gravity               设置该子组件采用何种方式占据该网格 
android:layout_row                   设置该子组件在GridLayout的第几行 
android:layout_rowSpan               设置该子组件在GridLayout纵向上跨几行。
android:alignmentMode                设置该布局管理器采用的对齐模式
android:columnCount                  设置该网格的列数量
android:columnOrderPreserved         设置该网格容器是否保留列序号
android:orientation                  设置该网格的排列方向,"vertical" 为垂直分布,"horizontal"为水平分布
android:rowCount                     设置该网格的行数量
android:rowOrderPreserved            设置该网格容器是否保留行序号
android:useDefaultMargins            设置是否使用默认的页边距

代码如下:

<?xml version="1.0" encoding="utf-8"?>
<AbsoluteLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
    <TextView
        android:id="@+id/lable"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_x="20dip"
        android:layout_y="20dip"
        android:text="input" />
    <EditText
        android:id="@+id/entry"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_y="40dip" />
    <Button
        android:id="@+id/ok"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_x="180dip"
        android:layout_y="100dip"
        android:width="60dip"
        android:text="确定" />
    <Button
        android:id="@+id/cancel"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_x="270dip"
        android:layout_y="100dip"
        android:width="60dip"
        android:text="取消" />
</AbsoluteLayout>

以上是关于Android 之 布局训练的主要内容,如果未能解决你的问题,请参考以下文章

Android片段布局完成膨胀

Android获取片段中的布局高度和宽度

如何在android中的地图片段内中心线性布局?

iOS 相当于 Android 片段/布局

带有两个列表片段的可滚动布局

在Android中,如何将数据从类传递到相应的布局/片段文件?