欢迎来到Doc100.Net免费学习资源知识分享平台!
您的位置:首页 > 程序异常 >

android 使用 tablelayout 格局拉伸宽度

更新时间: 2014-01-05 02:35:39 责任编辑: Author_N1

 

Android 使用 TableLayout 布局拉伸宽度
转自:[url]http://www.cnblogs.com/ghj1976/archive/2011/04/21/2023850.html[/url]
布局文件

<?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>

[img]http://dl2.iteye.com/upload/attachment/0092/0698/ffbd88cc-1d8d-3953-8269-d9144bfd0b8d.png[/img]

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

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

布局效果

[img]http://dl2.iteye.com/upload/attachment/0092/0700/c37b4879-b261-364e-bdca-0bed4d8ba286.png[/img]

它的值即可以是数字,也可以是*,注意数字是从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="*"

[img]http://dl2.iteye.com/upload/attachment/0092/0702/4ef6131c-ab0d-3676-94cd-b9e39fd0789a.png[/img]


上一篇:上一篇
下一篇:下一篇

 

随机推荐程序问答结果

 

 

如对文章有任何疑问请提交到问题反馈,或者您对内容不满意,请您反馈给我们DOC100.NET论坛发贴求解。
DOC100.NET资源网,机器学习分类整理更新日期::2014-01-05 02:35:39
如需转载,请注明文章出处和来源网址:http://www.doc100.net/bugs/t/11872/
本文WWW.DOC100.NET DOC100.NET版权所有。