RelativeLayout中子控件的android:layout_centerVertical="true"失效问题分析

1.显示效果

显示效果
首先来看一下显示效果,001是一个带背景的TextView,设置了

android:layout_centerVertical="true"

属性,但却没有居中显示。


2.代码

xml布局文件的完整代码如下:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/rl"
     android:layout_width="180dip"
    android:layout_height="40dip"
    android:gravity="center_vertical"
    android:background="@android:color/black"
    >
    <TextView
        android:id="@+id/tv_channel_num"
        android:layout_width="30dip"
        android:layout_height="30dip"
        android:text="001"
        android:gravity="center"
        android:textSize="@dimen/mytextsize3"
        android:textColor="@color/channel_num_textcolor"
        android:background="@mipmap/channe_button_2_channel_normal"
        android:textStyle="bold"
        android:layout_alignParentLeft="true"
        android:layout_marginRight="8dip"
        android:layout_centerVertical="true"
        android:layout_marginLeft="5dip"
        />
    <TextView
        android:id="@+id/tv_channel_name_2"
        android:layout_width="120dip"
        android:layout_height="wrap_content"
        android:gravity="center_vertical"
        android:textSize="@dimen/mytextsize3"
        android:layout_toRightOf="@+id/tv_channel_num"
        android:layout_marginLeft="5dip"
        android:textColor="@color/channel_list_textcolor"
        android:ellipsize="marquee"
        android:marqueeRepeatLimit="marquee_forever"
        android:singleLine="true"/>
    <TextView
        android:id="@+id/tv_channel_name_1"
        android:layout_width="120dip"
        android:layout_height="wrap_content"
        android:gravity="center_vertical"
        android:layout_centerVertical="true"
        android:layout_toRightOf="@+id/tv_channel_num"
        android:layout_marginLeft="5dip"
        android:textSize="@dimen/mytextsize3"
        android:textColor="@color/channel_list_textcolor"
        android:visibility="invisible"
        android:ellipsize="marquee"
        android:marqueeRepeatLimit="marquee_forever"
        android:singleLine="true"/>
    <TextView
        android:id="@+id/tv_current_program"
        android:layout_width="120dip"
        android:layout_height="wrap_content"
        android:textSize="@dimen/mytextsize8"
        android:layout_marginLeft="5dip"
        android:layout_toRightOf="@+id/tv_channel_num"
        android:layout_below="@+id/tv_channel_name_2"
        android:textColor="@color/channel_list_textcolor"
        android:ellipsize="marquee"
        android:marqueeRepeatLimit="marquee_forever"
        android:singleLine="true"
        android:visibility="invisible"/>
</RelativeLayout>

3.分析

在dpi为320的机器上调试发现,TextView的top是15,bottom是75,但是正常来说,居中应该是10和70啊,是哪里不对呢,15是哪里来的的呢?

后来发现,如果把RelativeLayout的android:gravity="center_vertical"去掉,保留TextView的android:layout_centerVertical="true",或者反过来,保留RelativeLayout的设置,去掉TextView的设置,TextView都是居中的。

事情蹊跷,一点点来。
在去掉RelativeLayout的android:gravity="center_vertical"时,它的蓝图如下
不写RelativeLayout的android:gravity="center_vertical"
可以看到,TextView是居中的

而此时,如果加上RelativeLayout的android:gravity="center_vertical",蓝图就变成了下面这样:
加上RelativeLayout的android:gravity="center_vertical"

整个RelativeLayout里面的控件整体下移了大概有5的距离,而它们之间的相对位置没有变化,因此,结论就很显然了,图1中,因为tv_channel_name_2是紧贴上边缘的,所以RelativeLaout里的所有控件作为一个整体,top是0,它们距离下边缘的大小是10,所以此时如果设置RelativeLayout的android:gravity="center_vertical",那么必将整体下移5。

由此也可以推断,RelativeLayout的android:gravity="center_vertical"属性,是在所有子空间都摆好之后才去计算并最终生效的。


4.结论

最后的结论就是,要想达到效果,把RelativeLayout的android:gravity="center_vertical"去掉吧


5.补充

最后,再参考一篇博文,父布局为RelativeLayout,textview设置layout_gravity=”center_vertical”无效。
我在评论里面反驳了博主的观点,加深一下理解

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值