• Android开发之LinearLayout


    LinearLayout是Android中的一种布局方式之一,也是经常用到的,俗称线性布局,LinearLayout在Activity中是不可见的,布局只是规定Activity中控件的摆放位置,

    LinearLayout是将控件 横向或者 纵横排成一排,LinearLayout是Android布局中最简单的一种,下面看看今天要讲的内容。

    •  LinearLayout布局的嵌套
    • 神奇的Layout_weight属性

    如下我们用嵌套LinearLayout实现下面的布局方式。

      布局文件如下

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        android:gravity="center_horizontal"
        tools:context=".MainActivity" >
        
        <LinearLayout 
            android:layout_width="wrap_content"
            android:layout_height="wrap_content">
              <TextView 
               android:layout_width="wrap_content"
               android:layout_height="wrap_content"
               android:gravity="center"
               android:text="猜拳游戏"/>
              
        </LinearLayout>
        <LinearLayout 
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:orientation="horizontal">
       <LinearLayout 
           android:layout_width="wrap_content"
           android:layout_height="wrap_content"
           android:layout_marginRight="30dp"
           android:orientation="vertical"
           >
           <ImageView 
               android:layout_width="wrap_content"
               android:layout_height="wrap_content"
               android:scaleType="fitCenter"
               android:src="@drawable/xiao"
               />
           <RadioGroup 
               android:layout_width="wrap_content"
               android:layout_height="wrap_content"
               >
               <RadioButton 
                   android:layout_width="wrap_content"
                   android:layout_height="wrap_content"
                   android:text="石头"
                   />
               <RadioButton 
                   android:layout_width="wrap_content"
                   android:layout_height="wrap_content"
                   android:text="剪刀"
                   />
               <RadioButton 
                   android:layout_width="wrap_content"
                   android:layout_height="wrap_content"
                   android:text=""
                   />
           </RadioGroup>
       </LinearLayout>
       
        <LinearLayout 
           android:layout_width="wrap_content"
           android:layout_height="wrap_content"
           android:orientation="vertical"
           >
             <ImageView 
               android:layout_width="wrap_content"
               android:layout_height="wrap_content"
               android:scaleType="fitCenter"
               android:src="@drawable/xiao"
               />
            <RadioGroup 
               android:layout_width="wrap_content"
               android:layout_height="wrap_content"
               >
               <RadioButton 
                   android:layout_width="wrap_content"
                   android:layout_height="wrap_content"
                   android:text="石头"
                   />
               <RadioButton 
                   android:layout_width="wrap_content"
                   android:layout_height="wrap_content"
                   android:text="剪刀"
                   />
               <RadioButton 
                   android:layout_width="wrap_content"
                   android:layout_height="wrap_content"
                   android:text=""
                   />
           </RadioGroup>
       </LinearLayout>
       
       </LinearLayout>
       
       <LinearLayout 
           android:layout_width="wrap_content"
           android:layout_height="wrap_content"
           android:orientation="vertical">
            <Button 
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="测 试 结 果   "
                />
       </LinearLayout>
        <LinearLayout 
           android:layout_width="wrap_content"
           android:layout_height="wrap_content"
           android:orientation="horizontal">
            <TextView 
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginRight="30dp"
                android:text="结果"
                />
            <TextView 
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="测试结果"
                />
       </LinearLayout>
    </LinearLayout>

    测试结果

    LinearLayout中的TextView按比例显示的时候,layout_width="0dp"或者layout_height="0dp"
     在android开发中LinearLayout很常用,LinearLayout的内控件的android:layout_weight在某些场景显得非常重要,比如我们需要按比例显示。android并没用提供table这样的控件,虽然有TableLayout,但是它并非是我们想象中的像html里面的table那么好用,我们常用ListView实现table的效果,但是列对齐确比较麻烦,现在用LinearLayout及属性android:layout_weight能很好地解决。下面我们共同体验下layout_weight这个属性。
    一、LinearLayout内的控件的layout_width设置为"wrap_content"
    请看一下xml配置:

     <LinearLayout
          android:orientation="horizontal"
          android:layout_width="fill_parent"
          android:layout_height="fill_parent"
          android:layout_weight="1"
         >
          <TextView
              android:layout_width="wrap_content"
              android:layout_height="fill_parent"
              android:layout_weight="1"
              android:background="#aa0000"
              android:gravity="center"
              android:text="1"/>
          <TextView
              android:layout_width="wrap_content"
              android:layout_height="fill_parent"
              android:layout_weight="2"
              android:background="#00aa00"
              android:gravity="center"
              android:text="1"/>
          <TextView
              android:layout_width="wrap_content"
              android:layout_height="fill_parent"
              android:layout_weight="3"
              android:background="#0000aa"
              android:gravity="center"
              android:text="1"/>
      </LinearLayout>
    

     效果如下:

    可以看到这三个TextView是按照1:2:3的比例进行显示的,这样看来似乎可以实现按照比例显示了,但是有个问题,如果TextView内的文本长度一同那么较长文本的TextView会宽度会有所增加,见下面配置及效果:
    配置:

     <LinearLayout
          android:orientation="horizontal"
          android:layout_width="fill_parent"
          android:layout_height="fill_parent"
          android:layout_weight="1">
          <TextView
              android:layout_width="wrap_content"
              android:layout_height="fill_parent"
              android:layout_weight="1"
              android:background="#aa0000"
              android:gravity="center"
              android:text="1111111111111111111111111111111111111111111"/>
          <TextView
              android:layout_width="wrap_content"
              android:layout_height="fill_parent"
              android:layout_weight="2"
              android:background="#00aa00"
              android:gravity="center"
              android:text="2"/>
          <TextView
              android:layout_width="wrap_content"
              android:layout_height="fill_parent"
              android:layout_weight="3"
              android:background="#0000aa"
              android:gravity="center"
              android:text="3"/>
      </LinearLayout>
    

     

    这样看来我们所需要的按比例又无法实现了,经过满天地google终于找到了解决方案,就是设置layout_width设置为"wrap_content"。配置及效果见下:

     <LinearLayout
          android:orientation="horizontal"
          android:layout_width="fill_parent"
          android:layout_height="fill_parent"
          android:layout_weight="1">
          <TextView
              android:layout_width="0dp"
              android:layout_height="fill_parent"
              android:layout_weight="1"
              android:background="#aa0000"
              android:gravity="center"
              android:text="1111111111111111111111111111111111111111111"/>
          <TextView
              android:layout_width="0dp"
              android:layout_height="fill_parent"
              android:layout_weight="2"
              android:background="#00aa00"
              android:gravity="center"
              android:text="2"/>
          <TextView
              android:layout_width="0dp"
              android:layout_height="fill_parent"
              android:layout_weight="3"
              android:background="#0000aa"
              android:gravity="center"
              android:text="3"/>
      </LinearLayout>
    

     

    这样终于达到我们的按比例显示的效果了,感觉很是奇怪,android开发框架的大佬们有时候设计确实有点匪夷所思。
    二、LinearLayout内的控件的layout_width设置为"fill_parent"
    请看一下xml配置:

     <LinearLayout
          android:orientation="horizontal"
          android:layout_width="fill_parent"
          android:layout_height="fill_parent"
          android:layout_weight="1">
          <TextView
              android:layout_width="fill_parent"
              android:layout_height="fill_parent"
              android:layout_weight="1"
              android:background="#aa0000"
              android:gravity="center"
              android:text="1"/>
          <TextView
              android:layout_width="fill_parent"
              android:layout_height="fill_parent"
              android:layout_weight="2"
              android:background="#00aa00"
              android:gravity="center"
              android:text="2"/>
      </LinearLayout>
    

     效果如下:

    奇怪吧,整个宽度平分3块,第一个TextView占了两块,这样看来weight值越小的优先级越大。只有两个TextView似乎看出些道理,那么让我们看看三个是什么效果:

    <LinearLayout
          android:orientation="horizontal"
          android:layout_width="fill_parent"
          android:layout_height="fill_parent"
          android:layout_weight="1">
          <TextView
              android:layout_width="fill_parent"
              android:layout_height="fill_parent"
              android:layout_weight="1"
              android:background="#aa0000"
              android:gravity="center"
              android:text="1"/>
          <TextView
              android:layout_width="fill_parent"
              android:layout_height="fill_parent"
              android:layout_weight="2"
              android:background="#00aa00"
              android:gravity="center"
              android:text="2"/>
          <TextView
              android:layout_width="fill_parent"
              android:layout_height="fill_parent"
              android:layout_weight="3"
              android:background="#0000aa"
              android:gravity="center"
              android:text="3"/>
      </LinearLayout>
    

     效果:

    什么意思?第三个TextView丢掉了,很是奇怪,让我们再试一个,把weight分别改为2,3,4的看看效果:

  • 相关阅读:
    超详细教程2021新版oracle官网下载Windows JAVA-jdk11并安装配置(其他版本流程相同)
    个人总结
    6.15 团队项目心得
    五月团队项目收获
    八大排序算法读书笔记
    设计模式读书笔记3
    设计模式读书笔记2
    结对编程收获
    设计模式读书笔记
    UI-12组结对编程作业总结
  • 原文地址:https://www.cnblogs.com/zhoujian315/p/3133792.html
Copyright © 2020-2023  润新知