Android 使用 TableLayout 布局拉伸宽度

布局文件

  
  1.0" encoding="utf-8"?> 
  
  
   
   http://schemas.android.com/apk/res/android" android:orientation="
   
   vertical" android:layout_width="
   
   fill_parent" android:layout_height="
   
   fill_parent"> 
   
   
    
    match_parent" android:layout_height="
    
    match_parent"> 
    
     
     
     
      
      @+id/et_led" android:layout_width="
      
      fill_parent" android:digits="
      
      1234567890.+-*/=%/n/t()" android:text="
      
      " android:layout_span="
      
      4" /> 
     
     
    
     
    
     
     
      
     
      
     
      
     
      
    
     
    
     
     
      
     
      
     
      
     
      
    
     
    
     
     
      
     
      
     
      
     
      
    
     
    
     
     
      
     
      
     
      
     
      
    
     
    
     
     
      
     
      
     
      
     
      
    
     
   
    
  
  

布局效果:

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值