Android 使用 TableLayout 布局拉伸宽度 平均分布各列
2016-03-18 12:10
761 查看
布局文件:
布局效果图
显然这不能满足我们的期望,下面我们演示 使用 android:stretchColumns 来自动拉伸
我们这里简单的给 TableLayout 增加一个属性 android:stretchColumns="*" 表示所有列都要自动拉伸,以便适应
屏幕宽度。
它的值即可以是数字,也可以是*,注意数字是从0开始的,即:android:stretchColumns="1" 是设置 TableLayout
所有行的第二列为扩展列。
上面我们会看到 第四列的按钮比其他列的按钮要宽,如果我们想都一样宽如何办呢?
一个简单办法:
在自动拉伸的基础上,把每一列的宽度都设置成一样,比如下面的代码:
这时候的效果就成了:
注意比起最初的就多了2个设置
android:layout_width="1dip" 和 android:stretchColumns="*"
<span style="font-family:Arial Black;font-size:18px;"><?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></span>
布局效果图
显然这不能满足我们的期望,下面我们演示 使用 android:stretchColumns 来自动拉伸
我们这里简单的给 TableLayout 增加一个属性 android:stretchColumns="*" 表示所有列都要自动拉伸,以便适应
屏幕宽度。
它的值即可以是数字,也可以是*,注意数字是从0开始的,即:android:stretchColumns="1" 是设置 TableLayout
所有行的第二列为扩展列。
上面我们会看到 第四列的按钮比其他列的按钮要宽,如果我们想都一样宽如何办呢?
一个简单办法:
在自动拉伸的基础上,把每一列的宽度都设置成一样,比如下面的代码:
<span style="font-family:Arial Black;font-size:18px;"><?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></span>
这时候的效果就成了:
注意比起最初的就多了2个设置
android:layout_width="1dip" 和 android:stretchColumns="*"
相关文章推荐
- Android:在AlertDialog点击按钮隐藏对话框
- [Android]基于Android的Java学习路线图
- Android TextureView OpenGL场景
- Android控件测量相关
- 不能为虚拟电脑 Custom Phone - 4.1.1 - API 16 - 768x1280 打开一个新任务.
- Activity的创建
- Android之Android Studio 启动异常
- Android Bottom Navigation
- 扣丁学堂笔记第01天Android开发环境搭建
- android 高德地图Maker infoWin窗口中TextView不换行问题
- android使用shape实现布局文件呈圆角
- android 加载自定义图片并在图片上绘图
- mac下android-ndk-r10e-darwin-x86_64.bin解压
- Android常用的第三方组件
- Android含资源文件引用的项目打包成jar包
- 安卓动画android:interpolator
- Android Studio 打包以及获取数字签名
- Android 屏幕适配方案
- android ScrollVIew中嵌套GridView,如何显示GridView
- ANDROID L - Material Design详解(动画篇)