• 【Android布局】在程序中设置android:gravity 和 android:layout_Gravity属性


    在进行UI布局的时候,可能常常会用到 android:gravity  和 android:layout_Gravity 这两个属性。

    关于这两个属性的差别,网上已经有许多人进行了说明,这边再简单说一下。 (资料来自网络)


    LinearLayout有两个很类似的属性:

    android:gravity与android:layout_gravity。

    他们的差别在于:

    android:gravity 属性是对该view中内容的限定.比方一个button 上面的text. 你能够设置该text 相对于view的靠左,靠右等位置.

    android:layout_gravity是用来设置该view相对与父view 的位置.比方一个button 在linearlayout里,你想把该button放在linearlayout里靠左、靠右等位置就能够通过该属性设置. 

    即android:gravity用于设置View中内容相对于View组件的对齐方式,而android:layout_gravity用于设置View组件相对于Container的对齐方式。

    原理跟android:paddingLeft、android:layout_marginLeft有点类似。假设在按钮上同一时候设置这两个属性。

    android:paddingLeft="30px"  按钮上设置的内容离按钮左边边界30个像素
    android:layout_marginLeft="30px"  整个按钮离左边设置的内容30个像素


    以下回到正题, 我们能够通过设置android:gravity="center"来让EditText中的文字在EditText组件中居中显示;同一时候我们设置EditText的android:layout_gravity="right"来让EditText组件在LinearLayout中居右显示。看下效果:

    正如我们所示,在EditText中,当中的文字已经居中显示了,而EditText组件自己也对齐到了LinearLayout的右側。

    附上布局文件:

     


    那么上面是通过布局文件的方式来设置的。,相信大家都曾写过,那么怎样通过Java代码来设置组件的位置呢?

    依旧考虑实现上述效果。

    通过查看SDK,发现有一个setGravity方法, 顾名思义, 这个应该就是用来设置Button组件中文字的对齐方式的方法了。

    细致找了一圈,没有发现setLayoutgravity方法, 有点失望。 只是想想也对, 假设这边有了这种方法, 将Button放在不支持Layout_Gravity属性的Container中怎样是好! 

    于是想到, 这个属性有可能在Layout中 , 于是细致看了看LinearLayout 的 LayoutParams, 果然有所发现, 里面有一个 gravity 属性,相信这个就是用来设置组件相对于容器本身的位置了,没错,应该就是他了。

    实践后发现,假设如此, 附上代码,各位自己看下。

    代码比較简单,可是发现它们还是花了我一点时间的。

     

    或者这样也能够:

     

    好了,效果图就不上了,跟上面的一样。 就讲这么多。

    另外,要设置在RelativeLayout中的位置时使用addRule方法,例如以下:

    params = new RelativeLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
            params.addRule(RelativeLayout.CENTER_IN_PARENT);
            mContainer.addView(progress,params);

    假设认为本文对您有帮助, 还请留言支持一下, 很感谢!

  • 相关阅读:
    JavaScript 中的求值策略
    JavaScript中的reduce()的5个用例
    使用JavaScript检测空闲的浏览器选项卡,可以做些什么?
    前端优化代码
    你可能不需要在JavaScript使用switch语句
    Js中的compose函数和pipe函数
    css是什么格式的文件?
    h5和css3的新特性有哪些?
    ES2020的这些新功能令人期待
    WindowsServer2003服务器的性能监视
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/4199933.html
Copyright © 2020-2023  润新知