zoukankan      html  css  js  c++  java
  • LinearLayout的gravity属性以及其子元素的layout_gravity何时有效;RelativeLayout如何调整其子元素位置只能用子元素中的属性来控制,用RelativeLayout中的gravity无法控制!!!

    LinearLayout的gravity属性以及其子元素的layout_gravity何时有效;RelativeLayout如何调整其子元素位置只能用子元素中的属性来控制,用RelativeLayout中的gravity无法控制!!!

    LinearLayout的gravity属性以及其子元素的layout_gravity何时有效

    转自:http://www.cnblogs.com/xiaoran1129/archive/2013/03/26/2982733.html

    相信对于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>
    复制代码

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

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

    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",但是它的展现效果却是下面这样的:

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

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

    也就是说,只有在作为父layout的LinearLayout是android:orientation="vertical" 的时候,android:layout_gravity="right"才会生效。

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

    看完上面的内容,有同学也许还会发现,当外层的LinearLayout为android:orientation="vertical" 的时候,android:layout_gravity="bottom"失效了

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

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

    当作为父layout的LinearLayout的属性为android:orientation="horizental" 的时候,android:layout_gravity="?"这里设为纵向的时候才能生效。比如:top,bottom,center_vertical等;

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

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

    RelativeLayout如何调整其子元素位置只能用子元素中的属性来控制,用RelativeLayout中的gravity无法控制!!!

    转自:http://blog.sina.com.cn/s/blog_4e1e357d0101am70.html

    android RelativeLayout 内容居中解决办法:

    使用Linearlayout本来利用父控件的gravity属性是很好解决的。但是对应RelativeLayout虽然有 gravity属性,但是如果你使用,你会发现实际他是不能生效的
     
    解决办法:
    在RelativeLayout的子空间里,使用以下3个属性就行了。
     
                        android:layout_centerVertical="true"
     
                        android:layout_centerHorizontal="true"
     
    gravity 一般是针对linearlayout会使用很方便。
    转自:http://blog.sina.com.cn/s/blog_6efce07e01012zue.html
     
     最近在遇到RelativeLayout里的gravity属性给它复制center_horizontal或者center都不能居中它的子组件,后来找到了替代方法,只要在它的每个子组件里加上android:layout_centerHorizontal="true" 就可以了
     
                        android:layout_centerInParent="true"
  • 相关阅读:
    js原生实现div渐入渐出
    js刷新界面前事件onbeforeunload
    js手机短信验证
    scroll滚动条样式修改
    省市区三级联动
    js this的含义以及讲解
    炫酷实用的CSS3代码垂直手风琴菜单
    机器学习初探(手写数字识别)HOG图片
    机器学习初探(手写数字识别)matlab读取数据集
    Google B4网络阅读记录(翻译)
  • 原文地址:https://www.cnblogs.com/cheneasternsun/p/5402903.html
Copyright © 2011-2022 走看看