Android布局中gravity与layout_gravity属性说明

 更新时间:2023年01月17日 09:50:35   作者:黄元帅  
这篇文章主要介绍了Android布局中gravity与layout_gravity属性说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

gravity与layout_gravity属性

在android布局中,我们经常会用到“重心”-gravity这个属性。

但是gravity有不同的类型:

  • gravity
  • layout_gravity
  • 相对布局中的layout_center等属性

今天我们就来具体说说。

1、gravity

gravity属性是对控件自身内容对自己的限定,拿布局文件test.xml举例来说:

此时在TextView中并没有对gravity属性进行操作,文字内容如上图。

接下来,我们继续设置TextView的gravity属性,观察效果:

2、layout_gravity属性

与gravity属性不同的是,layout_gravity属性是用来设置该View相对与父View的位置,

具体情况就个人判断有下面这4种情况:

另外还有一种在父布局横或纵设置wrap_content时,如果在该方向设置layout_gravity属性。

我直接在一个布局中,把这5种情况列出来,下面是我的布局文件代码:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context="com.example.primexiao.myapplication.MainActivity"
    >
//第4种情况
<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="0dp"
    android:layout_weight="1"
    android:background="#00f0f0"
    android:orientation="vertical">
        <TextView
            android:id="@+id/tv1"
            android:layout_centerHorizontal="true"
            android:layout_centerVertical="true"
            android:layout_centerInParent="true"
            android:text="我是测试内容"
            android:background="#000000"
            android:layout_gravity="center_horizontal"
            android:textColor="#ffffff"
            android:layout_width="100dp"
            android:layout_height="100dp" />
</LinearLayout>
//第1种情况
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:background="#00ff00"
        android:orientation="vertical">
        <TextView
            android:layout_centerHorizontal="true"
            android:layout_centerVertical="true"
            android:layout_centerInParent="true"
            android:text="我是测试内容"
            android:background="#000000"
            android:textColor="#ffffff"
            android:layout_gravity="center_vertical"
            android:layout_width="100dp"
            android:layout_height="100dp" />
    </LinearLayout>
    //第3种情况
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:background="#00f0f0"
        android:orientation="horizontal">
        <TextView
            android:layout_centerHorizontal="true"
            android:layout_centerVertical="true"
            android:layout_centerInParent="true"
            android:text="我是测试内容"
            android:background="#000000"
            android:layout_gravity="center_vertical"
            android:textColor="#ffffff"
            android:layout_width="100dp"
            android:layout_height="100dp" />
    </LinearLayout>
    //第2种情况
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:background="#ff0000"
        android:orientation="horizontal">
        <TextView
            android:layout_centerHorizontal="true"
            android:layout_centerVertical="true"
            android:layout_centerInParent="true"
            android:text="我是测试内容"
            android:background="#000000"
            android:layout_gravity="center_horizontal"
            android:textColor="#ffffff"
            android:layout_width="100dp"
            android:layout_height="100dp" />
    </LinearLayout>
    //第5种情况
    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:background="#fff000"
        android:orientation="horizontal">
        <TextView
            android:layout_centerHorizontal="true"
            android:layout_centerVertical="true"
            android:layout_centerInParent="true"
            android:text="我是测试内容"
            android:background="#000000"
            android:layout_gravity="center_horizontal"
            android:textColor="#ffffff"
            android:layout_width="100dp"
            android:layout_height="100dp" />
    </LinearLayout>
</LinearLayout>

效果图如下:

我们可以看到第1和第2种情况下,layout_gravity这一属性根本没有起到作用,个人看法是子控件如果选择横或纵居中,这种属性声明是不能和父布局的排列方式相冲的,这个坑我先替你们踩着:D。

3、相对布局中的layout_center属性

之前遇到过这么一个问题,在RelativeLayout中设置layount_gravity属性,发现并不能实现居中效果,并且layout_gravity也是手动输入,期间并没有智能提示。

后来发现相对布局中,有layout_centerX这么一个属性,让我们来试一下:

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Android 两个ViewPager的联动效果的实现

    Android 两个ViewPager的联动效果的实现

    这篇文章主要介绍了Android 两个ViewPager的联动效果的实现,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-08-08
  • Android 画中画模式的实现示例

    Android 画中画模式的实现示例

    这篇文章主要介绍了Android 画中画模式的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • Android CameraX结合LibYUV和GPUImage自定义相机滤镜

    Android CameraX结合LibYUV和GPUImage自定义相机滤镜

    之前使用Camera实现了一个自定义相机滤镜(Android自定义相机滤镜 ),但是运行起来有点卡顿,这次用Camerax来实现一样的效果发现很流畅,在此记录一下,也希望能帮到有需要的同学
    2021-12-12
  • 解决Android 5.1限制外置SD卡写入权限的问题

    解决Android 5.1限制外置SD卡写入权限的问题

    今天小编就为大家分享一篇解决Android 5.1限制外置SD卡写入权限的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-08-08
  • Flutter Widget之NavigationBar使用详解

    Flutter Widget之NavigationBar使用详解

    这篇文章主要为大家介绍了Flutter Widget之NavigationBar使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • Android表格自定义控件使用详解

    Android表格自定义控件使用详解

    这篇文章主要为大家详细介绍了Android表格自定义控件的使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • Android Zxing二维码扫描图片拉伸问题的解决方法

    Android Zxing二维码扫描图片拉伸问题的解决方法

    这篇文章主要为大家详细介绍了Android Zxing二维码扫描图片拉伸问题的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • Android以对话框形式制作数字软键盘示例

    Android以对话框形式制作数字软键盘示例

    大家好,本篇文章主要讲的是Android以对话框形式制作数字软键盘示例,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2021-12-12
  • Android使用fragment实现左侧导航

    Android使用fragment实现左侧导航

    这篇文章主要为大家详细介绍了Android使用fragment实现左侧导航,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-02-02
  • 利用Flutter制作一个摸鱼桌面版App

    利用Flutter制作一个摸鱼桌面版App

    Win10商店上架了一款名为《摸鱼》的App,在下载打开之后,这个App会让你的电脑进入一个假更新的画面。本文将为大家介绍如何通过Flutter制作一个桌面版的摸鱼APP,快跟小编一起学习一下吧
    2021-12-12

最新评论