zoukankan      html  css  js  c++  java
  • Android的FrameLayout使用要注意的问题

      帧布局FrameLayout在Android的五大布局中是最简单的布局方式,在需要布局中的控件有重叠的情况下才使用。


      今天Shamoo使用FrameLayout的时候,发现布局里面的控件设置layout_margin类的属性没有效果。后来百度一下才知道FrameLayout中的控件layout_margin设置要依赖layout_gravity属性,否则layout_margin设置无效。


      layout_gravity有好几个值可以设置,具体要设置哪一个呢?其实layout_gravity可以理解为设置控件的参考点,控件最终显示位置最终由layout_gravity和layout_margin共同决定。


      如果想要控件正常显示,可以将控件的layout_gravity设置为top,以屏幕左上角为参考点。

        <FrameLayout 
            android:layout_width="fill_parent"
            android:layout_height="fill_parent">
            <!-- layout_gravity设置为top,以屏幕左上角为参考点 -->
            <TextView
    	        android:layout_width="100dp"
    	        android:layout_height="100dp"
    	        android:layout_gravity="top"
    	        android:background="#FF0000"
    	        android:gravity="center"
    	        android:text="1"
    	        android:textSize="30sp" />
            <TextView
                android:layout_marginLeft="80dp"
                android:layout_marginTop="80dp"
    	        android:layout_width="100dp"
    	        android:layout_height="100dp"
    	        android:layout_gravity="top"
    	        android:background="#00FF00"
    	        android:gravity="center"
    	        android:text="2"
    	        android:textSize="30sp" />
            <TextView
                android:layout_marginLeft="160dp"
                android:layout_marginTop="160dp"
    	        android:layout_width="100dp"
    	        android:layout_height="100dp"
    	        android:layout_gravity="top"
    	        android:background="#0000FF"
    	        android:gravity="center"
    	        android:text="3"
    	        android:textSize="30sp" />
        </FrameLayout>


      改变所有的控件的参考点,layout_gravity设置为center,看看效果



      另外FrameLayout在一些控件动画中和一些复杂的UI设计大有用处,还是挺不错的。


  • 相关阅读:
    jenkins学习:jenkins+maven
    git学习
    jenkins学习:jenkins+gitlab
    mongodb安装和运行
    ideaJ+maven+javaweb实践: sevlet实现upload&download,javaIO代码
    pageObject学习
    postman接口测试
    TODO 软件测试68题
    testng优化:失败重跑,extentReport+appium用例失败截图,测试报告发邮件
    testng报告-extentsReports使用-klov
  • 原文地址:https://www.cnblogs.com/jiangu66/p/3235278.html
Copyright © 2011-2022 走看看