【Android】Layout 水平平分空间、垂直平分空间

这篇博客探讨了如何在Android中使两个按钮在一行内平分空间的问题。作者指出,设置固定宽度可能导致在不同分辨率手机上的适配问题,而设置width为fill_parent则可能导致只有一个按钮显示。通过尝试RelativeLayout和TableLayout,作者发现LinearLayout是实现这一目标的有效方法。关键在于使用`android:layout_weight="1"`,确保按钮权重相等,从而实现平分空间的效果。

今天在论坛看到有人提问,如何让两个按钮平分一行空间。

 

大概效果如下:

有人说,设置宽度固定大小,这样应该可以达到效果(本人没试),但是如果使用不同分辨率的手机来看,肯定会有问题,影响用户体验。

也有人说,设置宽度属性为 fill_parent, 其实这样是不行的。 页面上只会显示一个按钮,要么A ,要么B。(看你布局文件而定)

 

那么有什么解决办法呢?

 

本人试了RelativeLayout、TableLayout,发现都不可以~~ 最后在Android实例中发现, LinearLayout是可以的。

 

把上图效果的布局贴出来给大家参考一下吧: (会的就不用看了,虽然简单,但是想不到的话花一天也未必能做的出来)

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="horizontal"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
	<Button 
	android:id="@+id/bt1"
	android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="A"
    android:layout_weight="1"/>
    <Button android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="B"
    android:layout_weight="1"/>
</LinearLayout>

其中主要就是 android:layout_weight="1",  只要让两个按钮的权重相同就可以,值无所谓。 

 

 

 

 

 

下面贴一下Android 带的布局例子,水平平分、垂直平分都有:

        <?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">
            <LinearLayout android:orientation="horizontal"
                android:layout_width="fill_parent" android:layout_height="fill_parent"
                android:layout_weight="1">
                <TextView android:text="red" android:gravity="center_horizontal"
                    android:background="#aa0000" android:layout_width="wrap_content"
                    android:layout_height="fill_parent" android:layout_weight="1" />
                <TextView android:text="green" android:gravity="center_horizontal"
                    android:background="#00aa00" android:layout_width="wrap_content"
                    android:layout_height="fill_parent" android:layout_weight="1" />
                <TextView android:text="blue" android:gravity="center_horizontal"
                    android:background="#0000aa" android:layout_width="wrap_content"
                    android:layout_height="fill_parent" android:layout_weight="1" />
                <TextView android:text="yellow" android:gravity="center_horizontal"
                    android:background="#aaaa00" android:layout_width="wrap_content"
                    android:layout_height="fill_parent" android:layout_weight="1" />
            </LinearLayout>
            <LinearLayout android:orientation="vertical"
                android:layout_width="fill_parent" android:layout_height="fill_parent"
                android:layout_weight="1">
                <TextView android:text="row one" android:textSize="15pt"
                    android:layout_width="fill_parent" android:layout_height="wrap_content"
                    android:layout_weight="1" />
                <TextView android:text="row two" android:textSize="15pt"
                    android:layout_width="fill_parent" android:layout_height="wrap_content"
                    android:layout_weight="1" />
                <TextView android:text="row three" android:textSize="15pt"
                    android:layout_width="fill_parent" android:layout_height="wrap_content"
                    android:layout_weight="1" />
                <TextView android:text="row four" android:textSize="15pt"
                    android:layout_width="fill_parent" android:layout_height="wrap_content"
                    android:layout_weight="1" />
            </LinearLayout>
        </LinearLayout>

效果图:



评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值