layout_gravity和gravity的用法

layout_gravity和gravity的用法也谈layout_gravity和gravity的用法相信对于Android的初学者来说,大家都曾经被layout里这两个极其相似的属性迷惑过。简单使用一下搜索工具,我们就不难找到下面这样的答案:layout_gravity表示组件自身在父组件中的位置gravity            表示组件的子组件在组件中的位置看似很简单嘛~)貌似大伙瞅一眼就明白了。

大家好,又见面了,我是你们的朋友全栈君。

相信对于Android的初学者来说,大家都曾经被layout里这两个极其相似的属性迷惑过。

简单使用一下搜索工具,我们就不难找到下面这样的答案:

layout_gravity 表示组件自身在父组件中的位置

gravity             表示组件的子组件在组件中的位置

看似很简单嘛~)

貌似大伙瞅一眼就明白了。今天我要说的就是这貌似瞅一眼就明白的道理。
为什么这么简单的道理,总有同学会发现,在“某些时候”,layout_gravity这个属性不好使了,失去了它应有的作用。

于是同学们又开始使用搜索工具,一边还不停的骂:Google做的这个layout真他妈的不好使!
下面我们就网上找来的一个例子来简单描述一种layout_gravity失效的情况。

  1. <?xml version=”1.0″ encoding=”utf-8″?>
  2. <!– android:gravity设置了按钮上面的文字的显示位置,而android:layout_gravity设置了按钮在布局中的显示位置。 –>
  3. <LinearLayout xmlns:android=”http://schemas.android.com/apk/res/android”
  4.         android:orientation=”vertical”
  5.         android:layout_width=”fill_parent”
  6.         android:layout_height=”wrap_content”>
  7.         <Button android:layout_width=”250dip”
  8.                 android:gravity=”right”
  9.                 android:layout_height=”wrap_content”
  10.                 android:text=”我居右显示”
  11.                 android:layout_gravity=”right” />;
  12. </LinearLayout>

复制代码

这段代码的展现效果如下:!

 

layout_gravity和gravity的用法

 

然后我们再看下面这段代码:

  1. <?xml version=”1.0″ encoding=”utf-8″?>
  2. <!– android:gravity设置了按钮上面的文字的显示位置,而android:layout_gravity设置了按钮在布局中的显示位置。 –>
  3. <LinearLayout xmlns:android=”http://schemas.android.com/apk/res/android”
  4.         android:layout_width=”fill_parent”
  5.         android:layout_height=”wrap_content”>
  6.         <Button android:layout_width=”250dip”
  7.                 android:gravity=”right”
  8.                 android:layout_height=”wrap_content”
  9.                 android:text=”我居右显示”
  10.                 android:layout_gravity=”right” />
  11. </LinearLayout>

复制代码

这段代码我们一样设置了android:layout_gravity=”right”,但是它的展现效果却是下面这样的:

 

layout_gravity和gravity的用法

 

于是我们前面所说的情况就发生了,“Google做的这个layout真他妈的不好使!”

问题究竟出在哪里了呢?
细心一点的同学就会发现,下面的这段代码,最外层的LinearLayout少了这样一个属性:androidlayout_gravity和gravity的用法rientation=”vertical”
不错,正是缺少了这个属性才导致了android:layout_gravity=”right”的失效。
因为LinearLayout默认的是:androidlayout_gravity和gravity的用法rientation=”horizontal

也就是说,只有在作为父layout的LinearLayout是androidlayout_gravity和gravity的用法rientation=”vertical” 的时候,android:layout_gravity=”right”才会生效。

到这里本次“讲座”可以结束了吗? No!

看完上面的内容,有同学也许还会发现,当外层的LinearLayout为androidlayout_gravity和gravity的用法rientation=”vertical” 的时候,android:layout_gravity=”bottom”失效了

看到这里相信大家都明白了

下面我们还需要做一个简单的总结:
当作为父layout的LinearLayout的属性为androidlayout_gravity和gravity的用法rientation=”vertical” 的时候,android:layout_gravity=”?”这里设为横向的时候才能生效。比如:left,right,center_horizontal等

当作为父layout的LinearLayout的属性为androidlayout_gravity和gravity的用法rientation=”horizental” 的时候,android:layout_gravity=”?”这里设为纵向的时候才能生效。比如:top,bottom,center_vertical等;

有一个比较特殊的是center,不管是横向还是纵向的时候,它总有一个方向起作用layout_gravity和gravity的用法

另外有几个别急面生的:fill_vertical,fill_horizontal,fill,clip_vertical,clip_horizontal
这几个以前没留意过,莫非是新版本的SDK中,新引进的?分散对齐?很迷惑。
有用过的同学还请不吝赐教一下
layout_gravity和gravity的用法

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/159725.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • JWPlayer_nplayer浏览器

    JWPlayer_nplayer浏览器网盘:https://pan.baidu.com/s/1mmtppZSFOni5tLI2TJWKrw<scripttype=”text/javascript”>varthePlayer;//保存当前播放器以便操作$(function(){thePlayer=jwplayer(‘container’).setu…

    2022年10月8日
    0
  • Linux命令之—–watch命令

    Linux命令之—–watch命令

    2021年6月3日
    102
  • pycharm安装pyside2_python pycharm安装

    pycharm安装pyside2_python pycharm安装一、Python IDE安装 python的IDE软件多种多样,可自行选择;下面是来自知乎9种ide的推荐:(https://zhuanlan.zhihu.com/p/26146374 点击打开链接) pycharm 下载地址:https://www.jetbrains.com/pycharm/download/#section=windows1.首先从网站下载pycharm:…

    2022年8月29日
    2
  • 字典序输出_按姓名字典序排序

    字典序输出_按姓名字典序排序这一类的题目在面试中的算法是比较常见的,这里也自己做一个总结1.输入一个数字n,输出从1~n组成的数字的全排列,每个排列占一行,输出按照数值升序排列https://blog.csdn.net/desirepath/article/details/50447712从数组的末尾开始,首先找到第一个升序的数字对,然后交换这个数字对,然后从这个数字对开始,按照生序交换后面的所有数字。2…将1~…

    2025年7月5日
    0
  • 网站安全检测:推荐8款免费的 Web 安全测试工具「建议收藏」

    随着Web应用越来越广泛,Web安全威胁日益凸显。黑客利用网站操作系统的漏洞和Web服务程序的SQL注入漏洞等得到Web服务器的控制权限,轻则篡改网页内容,重则窃取重要内部数据,更为严重的则是在网页中植入恶意代码,使得网站访问者受到侵害。这也使得越来越多的用户关注应用层的安全问题,对Web应用安全的关注度也逐渐升温。下面向大家推荐8款非常有用的免费 Web安全测试工具。

    2022年4月10日
    54
  • python语言的优点和缺点[通俗易懂]

    python语言的优点和缺点[通俗易懂]python作为一门高级编程语言,它的诞生虽然很偶然,但是它得到程序员的喜爱却是必然之路。龟叔给Python的定位是“优雅”、“明确”、“简单”,所以Python程序看上去总是简单易懂,初学者学Py

    2022年7月3日
    25

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号