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”无效。
我在评论里面反驳了博主的观点,加深一下理解

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
这段代码定义了一个垂直排列的LinearLayout,其中包含一个RelativeLayout作为顶部栏,里面包括一个居中显示的TextView和一个右侧对齐的ImageView。 具体解释如下: - LinearLayout:定义了一个垂直排列的布局。 - android:orientation="vertical":设置LinearLayout的方向为垂直。 - android:layout_width="match_parent":设置LinearLayout的宽度为match_parent,即与父容器宽度相同。 - android:layout_height="match_parent":设置LinearLayout的高度为match_parent,即与父容器高度相同。 - RelativeLayout:定义了一个相对布局。 - android:layout_width="wrap_content":设置RelativeLayout的宽度为包裹内容。 - android:layout_height="48dp":设置RelativeLayout的高度为48dp。 - android:background="@android:color/holo_red_light":设置RelativeLayout背景颜色为淡红色。 - TextView:定义了一个文本视图。 - android:layout_width="wrap_content":设置TextView的宽度为包裹内容。 - android:layout_height="wrap_content":设置TextView的高度为包裹内容。 - android:text="商品详情":设置TextView的文本内容为“商品详情”。 - android:textSize="24sp":设置TextView的文本大小为24sp。 - android:layout_centerVertical="true":设置TextView在垂直方向上居中对齐。 - android:layout_centerHorizontal="true":设置TextView在水平方向上居中对齐。 - ImageView:定义了一个图像视图。 - android:id="@+id/iv_me":为ImageView设置一个唯一的标识符,以便在代码中引用。 - android:layout_width="wrap_content":设置ImageView的宽度为包裹内容。 - android:layout_height="wrap_content":设置ImageView的高度为包裹内容。 - android:src="@mipmap/icon_shopping_car":设置ImageView的图像源为指定的图片资源。 - android:layout_alignParentRight="true":设置ImageView在父容器的右侧对齐。 - android:layout_centerVertical="true":设置ImageView在垂直方向上居中对齐。 - android:padding="12dp":设置ImageView的内边距为12dp。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值