zoukankan      html  css  js  c++  java
  • Android 使用 TableLayout 布局拉伸宽度

    布局文件

    <?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">
    
    	<TableLayout android:layout_width="match_parent"
    		android:layout_height="match_parent">
    		<TableRow>
    			<EditText android:id="@+id/et_led" android:layout_width="fill_parent"
    				android:digits="1234567890.+-*/=%\n\t()" android:text=""
    				android:layout_span="4" />
    		</TableRow>
    		<TableRow>
    			<Button android:text="(" android:id="@+id/btn_LeftParenthesis"></Button>
    			<Button android:text=")" android:id="@+id/btn_RightParenthesis"></Button>
    			<Button android:text="*" android:id="@+id/btn_x"></Button>
    			<Button android:text="back" android:id="@+id/btn_back"></Button>
    		</TableRow>
    		<TableRow>
    			<Button android:text="7" android:id="@+id/btn_7"></Button>
    			<Button android:text="8" android:id="@+id/btn_8"></Button>
    			<Button android:text="9" android:id="@+id/btn_9"></Button>
    			<Button android:text="%" android:id="@+id/btn_mod"></Button>
    		</TableRow>
    		<TableRow>
    			<Button android:text="4" android:id="@+id/btn_4"></Button>
    			<Button android:text="5" android:id="@+id/btn_5"></Button>
    			<Button android:text="6" android:id="@+id/btn_6"></Button>
    			<Button android:text="/" android:id="@+id/btn_div"></Button>
    		</TableRow>
    		<TableRow>
    			<Button android:text="1" android:id="@+id/btn_1"></Button>
    			<Button android:text="2" android:id="@+id/btn_2"></Button>
    			<Button android:text="3" android:id="@+id/btn_3"></Button>
    			<Button android:text="-" android:id="@+id/btn_sub"></Button>
    		</TableRow>
    		<TableRow>
    			<Button android:text="0" android:id="@+id/btn_0"></Button>
    			<Button android:text="." android:id="@+id/btn_dot"></Button>
    			<Button android:text="+" android:id="@+id/btn_plus"></Button>
    			<Button android:text="=" android:id="@+id/btn_equal"></Button>
    		</TableRow>
    	</TableLayout>
    
    </LinearLayout>

    布局效果:

    image

    显然这不能满足我们的期望,下面我们演示 使用 android:stretchColumns 来自动拉伸

    我们这里简单的给 TableLayout 增加一个属性 android:stretchColumns="*" 表示所有列都要自动拉伸,以便适应屏幕宽度。

    布局效果

    image

    它的值即可以是数字,也可以是*,注意数字是从0开始的,即:android:stretchColumns="1" 是设置 TableLayout所有行的第二列为扩展列。

    上面我们会看到 第四列的按钮比其他列的按钮要宽,如果我们想都一样宽如何办呢?

    一个简单办法:

    在自动拉伸的基础上,把每一列的宽度都设置成一样,比如下面的代码:

    <?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">
    
    	<TableLayout android:layout_width="match_parent"
    		android:layout_height="match_parent" 		android:stretchColumns="*">
    		<TableRow>
    			<EditText android:id="@+id/et_led" android:layout_width="fill_parent"
    				android:digits="1234567890.+-*/=%\n\t()" android:text=""
    				android:layout_span="4" />
    		</TableRow>
    		<TableRow>
    			<Button android:text="(" android:id="@+id/btn_LeftParenthesis"
    				android:layout_width="1dip"></Button>
    			<Button android:text=")" android:id="@+id/btn_RightParenthesis"
    				android:layout_width="1dip"></Button>
    			<Button android:text="*" android:id="@+id/btn_x"
    				android:layout_width="1dip"></Button>
    			<Button android:text="back" android:id="@+id/btn_back"
    				android:layout_width="1dip"></Button>
    		</TableRow>
    		<TableRow>
    			<Button android:text="7" android:id="@+id/btn_7"></Button>
    			<Button android:text="8" android:id="@+id/btn_8"></Button>
    			<Button android:text="9" android:id="@+id/btn_9"></Button>
    			<Button android:text="%" android:id="@+id/btn_mod"></Button>
    		</TableRow>
    		<TableRow>
    			<Button android:text="4" android:id="@+id/btn_4"></Button>
    			<Button android:text="5" android:id="@+id/btn_5"></Button>
    			<Button android:text="6" android:id="@+id/btn_6"></Button>
    			<Button android:text="/" android:id="@+id/btn_div"></Button>
    		</TableRow>
    		<TableRow>
    			<Button android:text="1" android:id="@+id/btn_1"></Button>
    			<Button android:text="2" android:id="@+id/btn_2"></Button>
    			<Button android:text="3" android:id="@+id/btn_3"></Button>
    			<Button android:text="-" android:id="@+id/btn_sub"></Button>
    		</TableRow>
    		<TableRow>
    			<Button android:text="0" android:id="@+id/btn_0"></Button>
    			<Button android:text="." android:id="@+id/btn_dot"></Button>
    			<Button android:text="+" android:id="@+id/btn_plus"></Button>
    			<Button android:text="=" android:id="@+id/btn_equal"></Button>
    		</TableRow>
    	</TableLayout>
    
    </LinearLayout>

    这时候的效果就成了:

    注意比起最初的就多了2个设置

    android:layout_width="1dip" 和  android:stretchColumns="*"

    image

  • 相关阅读:
    svn ------ 更改提交地址,显示relocate
    .NET ------ 前端连接到新的界面与后台链接到新的界面
    .NET ------ 修改时间改变排序
    .NET ------ 通过flag 实现一表多用
    Java面向对象——抽象类与抽象方法
    Java——final关键字
    Java——类的成员之4:代码块(初始化块)
    Java——main方法的使用
    单例(Singleton)设计模式
    Java面向对象——static关键字
  • 原文地址:https://www.cnblogs.com/ghj1976/p/2023850.html
Copyright © 2011-2022 走看看