关于layout_centerHorizontal、layout_gravity、gravity的区别

本文深入解析了Android布局属性layout_centerHorizontal和gravity的区别与应用。通过实例对比,解释了两者在控件对齐上的不同作用,以及如何正确使用这些属性使TextView在不同场景下实现水平居中。

layout_centerHorizontal
是相对于RelativeLayout的布局属性
如果设置为true,就将该控价设置在相对于父控件水平居中的位置

layout_gravity
针对LinearLayout的一种控件对齐方式,可以把值设置成下列值:
center_vertical、center_horizontal、center等等

gravity
控制控件内文字的对齐方式

举个栗子:

在写一个简单的RecyclerView的时候,定义RecyclerView的单个item的时候,
我想让TextView居中显示,于是有下面的代码:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <TextView
        android:id="@+id/tv_num"
        android:text="@string/app_name"
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:layout_centerHorizontal="true"
         />
</RelativeLayout>

我在TextView中使用layout_centerHorizontal来让TextView居中,我觉得这样写没问题啊,让TextView位于RelativeLayout内部水平中间的位置,但是我看预览图却怎么不显示。

预览图:

 

 

这样我尝试使用gravity的时候,发现有下面的代码和预览图:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <TextView
        android:id="@+id/tv_num"
        android:text="@string/app_name"
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:gravity="center_horizontal"
         />
</RelativeLayout>

 


这样的话就居中了,我就奇怪,为什么layout_centerHorizontal来定义这个TextView不行,同样也是让子控件水平居中啊,百度了下,然后仔细看了下代码就突然发现问题的原因了。

layout_centerHorizontal,如果设置为true,就将该控价设置在相对于父控件水平居中的位置,gravity,如果设置为center_horizontal,是让控件中的文字水平居中。

接下来我做了个小测试:
我仍然使用layout_centerHorizontal来让TextView居中显示,并且将控件的layout_width属性设置为固定长度,如下布局:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <TextView
        android:id="@+id/tv_num"
        android:text="@string/app_name"
        android:layout_width="60dp"
        android:layout_height="50dp"
        android:layout_centerHorizontal="true"
         />
</RelativeLayout>

这里将宽度固定为60dp,发现预览图是下面这样的:

 


这样你有没有发现为什么第一个场景下为什么TextView不能居中的原因了呢?

因为第一个场景,设置的TextView的layout_width为match_parent,而layout_centerHorizontal设置为true,表示将TextView位于父控件的中间,而父控件的宽度同样是match_parent,这样就导致该TextView已经水平居中了,但是TextView中的文字没有居中。

当我们把TextView固定长度后,就能实现这个效果了。

转载于:https://www.cnblogs.com/powerwu/articles/9882235.html

<?xml version="1.0" encoding="utf-8"?> <androidx.coordinatorlayout.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@color/background_gray"> <!--背景--> <ImageView android:id="@+id/background_on" android:layout_width="match_parent" android:layout_height="match_parent" android:src="@drawable/on" android:visibility="visible" /> <!--文字+按钮容器--> <RelativeLayout android:layout_width="match_parent" android:layout_height="match_parent" android:paddingBottom="110dp"> <ImageButton android:id="@+id/switch_button" android:layout_width="60dp" android:layout_height="60dp" android:layout_marginTop="476dp" android:layout_centerInParent="true" android:layout_centerHorizontal="true" android:background="@android:color/transparent" android:scaleType="centerInside" android:src="@drawable/switchselector"/> <RelativeLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@+id/switch_button" android:layout_centerHorizontal="true" android:layout_marginTop="58dp"> <TextView android:id="@+id/textView_on" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerHorizontal="true" android:text="ON" android:textSize="20dp" android:visibility="visible" /> <TextView android:id="@+id/textView_off" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerHorizontal="true" android:text="OFF" android:textSize="20dp" android:visibility="gone" /> <TextView android:id="@+id/textView_tapon" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@+id/textView_on" android:text="Tap to turn it on" android:textSize="12dp" android:visibility="visible" /> <TextView android:id="@+id/textView_tapoff" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@+id/textView_on" android:text="Tap to turn it off" android:textSize="12dp" android:visibility="visible" /> </RelativeLayout> </RelativeLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="60dp" android:gravity="center" android:orientation="vertical"> <Button android:id="@+id/btn_bottom_sheet" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="32dp" android:text="BottomSheet" android:textAllCaps="false" /> </LinearLayout> <LinearLayout android:id="@+id/ll_bottom_sheet" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical" app:behavior_peekHeight="110dp" app:layout_behavior="@string/bottom_sheet_behavior"> <ImageView android:id="@+id/pull" android:layout_width="match_parent" android:layout_height="30dp" android:background="@color/white" android:clickable="false" android:focusable="false" android:gravity="center" android:paddingTop="15dp" android:src="@drawable/pullselector" /> <TextView android:layout_width="match_parent" android:layout_height="80dp" android:background="@color/white" android:gravity="center" android:text="c" android:textSize="20sp" /> <TextView android:layout_width="match_parent" android:layout_height="80dp" android:background="@android:color/holo_orange_dark" android:gravity="center" android:text="b" android:textSize="20sp" /> <TextView android:layout_width="match_parent" android:layout_height="80dp" android:background="@android:color/holo_green_light" android:gravity="center" android:text="c" android:textSize="20sp" /> <TextView android:layout_width="match_parent" android:layout_height="80dp" android:background="@android:color/holo_orange_dark" android:gravity="center" android:text="b" android:textSize="20sp" /> <TextView android:layout_width="match_parent" android:layout_height="80dp" android:background="@android:color/holo_orange_light" android:gravity="center" android:text="c" android:textSize="20sp" /> </LinearLayout> </androidx.coordinatorlayout.widget.CoordinatorLayout> imagebutton的margintop为甚么 不生效
08-19
说明采用的布局方式,及布局方式的特点 <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity" android:background="@drawable/music_bg"> <Button android:id="@+id/btn_icon" android:layout_width="200dp" android:layout_height="200dp" android:layout_centerHorizontal="true" android:layout_marginTop="200dp" android:background="@drawable/music_icon" /> <Button android:id="@+id/btn_progress" android:layout_width="300dp" android:layout_height="10dp" android:layout_below="@id/btn_icon" android:layout_centerHorizontal="true" android:layout_marginTop="100dp" android:background="@drawable/progress_icon" /> <RelativeLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_below="@id/btn_progress" android:layout_marginTop="35dp" android:gravity="center_horizontal"> <Button android:id="@+id/btn_left" android:layout_width="50dp" android:layout_height="50dp" android:background="@drawable/left_icon" /> <Button android:id="@+id/btn_mid" android:layout_width="50dp" android:layout_height="50dp" android:layout_marginLeft="52dp" android:layout_toRightOf="@id/btn_left" android:background="@drawable/middle_icon" /> <Button android:id="@+id/btn_right" android:layout_width="50dp" android:layout_height="50dp" android:layout_marginLeft="50dp" android:layout_toRightOf="@id/btn_mid" android:background="@drawable/right_icon" /> </RelativeLayout> </RelativeLayout>
最新发布
10-18
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值