• andriod GridLayout


    来自:http://blog.csdn.net/jianghuiquan/article/details/8299973

    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即可,前一个设置表明该控件跨越的行数或列数,后一个设置表明该控件填满所跨越的整行或整列。

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:orientation="vertical"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:padding="3dip"
        >
    
        <!-- 第1个TableLayout,用于描述表中的列属性。第0列可伸展,第1列可收缩 ,第2列被隐藏-->
        <TextView
            android:text="数字键盘"
            android:layout_height="wrap_content"
            android:layout_width="wrap_content"
            android:textSize="20sp"
            android:background="#7f00ffff"/>
    
       
    
        <GridLayout
    
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:orientation="horizontal"
            android:rowCount="5"
            android:columnCount="4">
            <Button  android:id="@+id/one" android:text="1"/>
              <Button
            android:id="@+id/two"
            android:text="2"/>
               <Button
            android:id="@+id/three"
            android:text="3"/>
              <Button
            android:id="@+id/devide"
            android:text="/"/>
              <Button
            android:id="@+id/four"
            android:text="4"/>
              <Button
            android:id="@+id/five"
            android:text="5"/>
              <Button
            android:id="@+id/six"
            android:text="6"/>
              <Button
            android:id="@+id/multiply"
            android:text="×"/>
              <Button
            android:id="@+id/seven"
            android:text="7"/>
              <Button
            android:id="@+id/eight"
            android:text="8"/>
              <Button
            android:id="@+id/nine"
            android:text="9"/>
            <Button
                android:id="@+id/minus"
                android:text="-"/>
            <Button
                android:id="@+id/zero"
                android:layout_columnSpan="2"
                android:layout_gravity="fill"
                android:text="0"/>
            <Button
            android:id="@+id/point"
            android:text="."/>
            <Button
                android:id="@+id/plus"
                android:layout_rowSpan="2"
                android:layout_gravity="fill"
                android:text="+"/>
            <Button
                android:id="@+id/equal"
                android:layout_columnSpan="3"
                android:layout_gravity="fill"
                android:text="="/>
        </GridLayout>
    
    
    </LinearLayout>
  • 相关阅读:
    详细版Jmeter随机参数的接口并发测试总结
    Windows下MQTT代理服务器的搭建
    关于使用elascticsearch的两个小技巧
    解决easyswoole的swServer_start_check: onTask event callback must be set at报错
    解决使用宝塔安装的swoole扩展,运行项目出现的3个常见问题
    浅谈一下ThinkPHP5.1实现事务嵌套的特性
    资源出现多个 "Access-Control-Allow-Origin"
    Mac 制作系统启动盘
    深入剖析分布式一致性共识算法
    分布式系统限流算法分析与实现
  • 原文地址:https://www.cnblogs.com/gisoracle/p/5211539.html
Copyright © 2020-2023  润新知