LinerLayout布局中android:layout_gravity = "right"失效的原因及解决方法

本文讲解了如何在Android中使用TextView组件实现文本右对齐及底部定位。通过设置android:layout_weight=1 android:gravity=right 和 android:layout_gravity=bottom 属性,可以精确控制文本在屏幕上的位置。

原因

 <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="1+1"
            android:layout_gravity="right"
            android:textColor="#000000"
            android:textSize="50sp" />

在设置完其layout_width ,layout_height属性的值为wrap_content之后, 布局管理器把这个线性布局(horizontal)平均分成了好几份.如下图
在这里插入图片描述
所以说此时"1+1"是在右侧的, 不过和预期的效果不一样

解决办法

将TextView组件中的代码改为如下:

 <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="1+1"
            android:layout_weight="1"
            android:gravity="right"
            android:layout_gravity="bottom"
            android:textColor="#000000"
            android:textSize="50sp" />

解释:

android:layout_weight = "1" 是用来设置TextView占据整个布局的宽度 
android:gravity="right"    设置文本内容"1+1"相对于父容器TextView的位置为right
android:layout_gravity="bottom"  设置TextView组件相对于父布局LinerLayout的位置为bottom

PS:
android:gravity是对元素本身说的
android:layout_gravity是相对与它的父元素说的,说明元素显示在父元素的什么位置

Android 布局中,`android:layout_gravity` 和 `android:gravity` 是两个常被混淆的属性,它们虽然都与“对齐”有关,但作用对象不同。 --- ### ✅ `android:layout_gravity` - **作用对象**:**当前控件本身**,用于控制**该控件在其父布局中的对齐方式**。 - **适用范围**:所有 `View` 的子类(如 `Button`、`TextView`、`LinearLayout` 等)。 - **示例**: ```xml <Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="按钮" android:layout_gravity="center" /> ``` - 表示这个按钮在其父布局中居中显示。 --- ### ✅ `android:gravity` - **作用对象**:**控件内部的内容**,用于控制**内容在其内部的对齐方式**。 - **适用范围**:主要用在容器类控件(如 `LinearLayout`、`TextView`、`FrameLayout` 等)。 - **示例**: ```xml <LinearLayout android:layout_width="200dp" android:layout_height="100dp" android:gravity="center"> <TextView android:text="文本" android:layout_width="wrap_content" android:layout_height="wrap_content" /> </LinearLayout> ``` - 表示 `LinearLayout` 内部的内容(TextView)居中显示。 --- ### 🔁 举个形象的对比 | 属性 | 作用对象 | 举例 | |------|----------|------| | `android:layout_gravity` | 控件自己 | 我(按钮)在父布局里靠右 | | `android:gravity` | 控件内部内容 | 我(LinearLayout)里面的子控件居中 | --- ### 🧪 实际布局示例 ```xml <LinearLayout android:layout_width="match_parent" android:layout_height="100dp" android:orientation="vertical" android:background="#EEE"> <TextView android:layout_width="100dp" android:layout_height="50dp" android:text="layout_gravity" android:layout_gravity="right" android:background="#FF9900" /> <TextView android:layout_width="100dp" android:layout_height="50dp" android:text="gravity" android:gravity="right" android:background="#99FF00" /> </LinearLayout> ``` - 第一个 TextView 会显示在父布局右侧(因为用了 `layout_gravity`)。 - 第二个 TextView 内部文字靠右显示(因为用了 `gravity`)。 --- ### ✅ 总结记忆技巧: - `layout_gravity`:**我要在父布局中怎么摆**。 - `gravity`:**我里面的内容怎么摆**。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值