android LinearLayout和RelativeLayout组合实现精确布局方法介绍

时间:2021-06-17 12:33:33 

先明确几个概念的区别
padding margin都是边距的含义,关键问题得明白是什么相对什么的边距.
padding是控件的内容相对控件的边缘的边距.
margin是控件边缘相对父空间的边距.
android LinearLayout和RelativeLayout组合实现精确布局方法介绍 
android:gravity属性是对该view 内容的限定.比如一个button 上面的text. 你可以设置该text 在view的靠左,靠右等位置.该属性就干了这个.
android:layout_gravity是用来设置该view中的子view相对于父view的位置.比如一个button 在linearlayout里,你想把该button放在靠左,靠右等位置就可以在linearlayout中通过该属性设置.


<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="horizontal" android:layout_width="fill_parent"
android:layout_height="wrap_content" android:gravity="center_vertical">
<ImageView android:id="@+id/ivLogo" android:layout_width="50dp"
android:layout_height="50dp" android:src="@drawable/icon"
android:paddingLeft="5dp" />
<RelativeLayout android:id="@+id/rl_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content" android:gravity="right"
android:padding="10dp">
<TextView android:id="@+id/tvApplicationName"
android:layout_width="wrap_content" android:layout_height="wrap_content"
android:textSize="16dp" />
</RelativeLayout>
<RelativeLayout android:id="@+id/rl_score"
android:layout_width="fill_parent"
android:layout_height="wrap_content" android:gravity="right"
android:padding="10dp">
<TextView android:id="@+id/tvRating" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:text="5.0" />
<RatingBar android:id="@+id/ratingbar" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:numStars="5"
style="?android:attr/ratingBarStyleSmall" android:layout_below="@id/tvRating" />
</RelativeLayout>
</LinearLayout>


android LinearLayout和RelativeLayout组合实现精确布局方法介绍 
上面的布局文件是一个ListView中的list_item布局,在一个ListView中显示所有的APK资源,每个资源项显示图标,名称及评分。在listItem的最外层LinearLayout中加android:gravity="center_vertical",设定内容垂直居中显示。在id为rl_score的RelativeLayout中设定android:layout_width="fill_parent"来填充剩余空间;android:gravity="right"设定内容相对于rl_score右对齐;android:padding="10dp"设定RelativeLayout中的内容相对RelativeLayout的边缘的边距为10dp。
这个布局虽然简单,但却是经常用到的。

标签:
0
投稿

猜你喜欢

  • C#实现图形区域组合操作的方法

    2023-05-01 19:08:21
  • c#深拷贝文件夹示例

    2023-07-24 07:50:40
  • android自定义view用path画长方形

    2022-07-20 21:03:00
  • Java发送post方法详解

    2023-10-28 03:55:00
  • java操作json对象出现StackOverflow错误的问题及解决

    2023-03-04 20:06:14
  • 详解Spring Security如何配置JSON登录

    2023-02-08 17:39:07
  • java实现的新浪微博分享代码实例

    2023-07-06 08:33:13
  • ViewPager实现带引导小圆点与自动跳转的引导界面

    2021-07-11 12:25:18
  • Unity3D网格功能生成球体网格模型

    2021-08-01 01:21:47
  • Kotlin协程之Flow基础原理示例解析

    2021-10-17 21:07:44
  • 完成OSS.Http底层HttpClient重构封装 支持标准库

    2021-09-28 11:25:40
  • Android编程实现使用webView打开本地html文件的方法

    2023-04-26 14:30:38
  • 在mybatis 中使用if else 进行判断的操作

    2021-11-10 23:17:11
  • eclipse怎么引入spring boot项目插件的方法

    2021-07-23 20:38:54
  • Maven的安装配置详解

    2023-11-24 08:52:05
  • springboot更新配置Swagger3的一些小技巧

    2023-08-28 06:31:43
  • Android第三方控件PhotoView使用方法详解

    2021-12-07 20:35:48
  • Android开发实现ImageView加载摄像头拍摄的大图功能

    2023-08-06 19:22:33
  • Java引用传递和值传递栈内存与堆内存的指向操作

    2021-05-30 04:43:37
  • SpringBoot 读取yml文件的多种方式汇总

    2023-08-03 13:10:43
  • asp之家 软件编程 m.aspxhome.com