我知道我们可以为android设置以下值:gravity和android:layout_gravity财产:

居中中心_垂直center_horizontal等。

但我对这两者都感到困惑。

android:gravity和android:layout_gravity的用法有什么区别?


当前回答

Gravity和layout_Gravity都是XML属性。

android:gravity属性用于排列视图中内容的位置(例如Button小部件中的文本)。

android:layout_gravity用于安排整个视图相对于其容器的位置。

有关详细信息,请参阅此链接。

其他回答

简短回答:使用android:gravity或setGravity()控制容器所有子视图的重力;使用android:layout_gravity或setLayoutParams()控制容器中单个视图的重力。

长话短说:要控制线性布局容器(如LinearLayout或RadioGroup)中的重力,有两种方法:

要控制LinearLayout容器的所有子视图的重力(正如您在书中所做的那样),请在布局XML文件中使用android:gravity(而不是android:layout_gravity)或代码中使用setGravity()方法。要控制子视图在其容器中的重力,请使用android:layout_gravity XML属性。在代码中,需要获取视图的LinearLayout.LayoutParams并设置其重力。下面是一个代码示例,它在水平方向的容器中将按钮设置为底部:import android.widget.LinearLayout.LayoutParams;import android.view.Gravity;...Button Button=(Button)findViewById(R.id.MyButtonId);//需要转换为LinearLayout.LayoutParams才能访问重力场LayoutParams params=(LayoutParams)按钮.getLayoutParams();params.gravity=重力.BOTTOM;button.setLayoutParams(params);

对于水平LinearLayout容器,其子视图的水平重力一个接一个地左对齐,不能更改。将android:layout_gravity设置为center_horizontal没有效果。默认垂直重力为中心(或center_vertical),可以更改为顶部或底部。实际上,默认layout_gravity值为-1,但Android将其垂直居中。

要更改水平线性容器中子视图的水平位置,可以使用子视图的layout_weight、margin和padding。

同样,对于垂直视图组容器,其子视图的垂直重力是上下对齐的,不能更改。默认水平重力为center(或center_horizontal),可以更改为向左或向右。

实际上,像按钮这样的子视图还具有android:gravity XML属性和setGravity()方法来控制其子视图——其中的文本。button.setGravity(int)链接到此developer.android.com条目。

不同之处在于

android:layout_gravity是视图的外部重力。指定视图应接触其父对象边界的方向。

android:重力是该视图的内部重力。指定其内容应对齐的方向。

HTML/CSS等价物

(如果您来自web开发背景)

Android                 | CSS
————————————————————————+————————————
android:layout_gravity  | float
android:gravity         | text-align

帮助你记住的简单技巧

将布局重力作为“外部重力”。

android:gravity用于指定如何将对象的内容放置在对象本身中。换句话说,android:gravity用于指定视图内容的重力。

android:layoutgravity是孩子可以提供给父母的属性,用于指定父母内部视图的重力。

有关详细信息,请访问

http://developer.android.com/reference/android/widget/LinearLayout.LayoutParams.html

查看图像以了解重力

Gravity和layout_Gravity都是XML属性。

android:gravity属性用于排列视图中内容的位置(例如Button小部件中的文本)。

android:layout_gravity用于安排整个视图相对于其容器的位置。

有关详细信息,请参阅此链接。