首页 > 其他分享 >RelativeLayout(相对布局)

RelativeLayout(相对布局)

时间:2023-03-02 20:00:49浏览次数:45  
标签:layout 布局 height width 相对 组件 RelativeLayout android id

在上一节中我们对LinearLayout进行了详细的解析,LinearLayout也是我们用的比较多的一个布局,我们更多的时候更钟情于他的weight(权重)属性,等比例划分,对屏幕适配还是帮助蛮大的;但是使用LinearLayout的时候也有一个问题,就是当界面比较复杂的时候,需要嵌套多层的LinearLayout,这样就会降低UI Render的效率(渲染速度),而且如果是listview或者GridView上的item,效率会更低,另外太多层LinearLayout嵌套会占用更多的系统资源,还有可能引发stackoverflow;但是如果我们使用RelativeLayout的话,可能仅仅需要一层就可以完成了,以父容器或者兄弟组件参考+margin+padding就可以设置组件的显示位置,是比较方便的!当然,也不是绝对的,具体问题具体分析吧!总结就是:尽量使用RelativeLayout + LinearLayout的weight属性搭配使用吧!

1.核心属性图

RelativeLayout(相对布局)_xml

2.父容器定位属性示意图

RelativeLayout(相对布局)_xml_02

3.根据兄弟组件定位

所谓的兄弟组件就是处于同一层次容器的组件,如图

RelativeLayout(相对布局)_android_03

图中的组件1,2就是兄弟组件了,而组件3与组件1或组件2并不是兄弟组件,所以组件3不能通过组件1或2来进行定位,比如layout_toleftof = "组件1"这样是会报错的!切记!关于这个兄弟组件定位的最经典例子就是"梅花布局"了,下面代码实现下:

运行效果图:

RelativeLayout(相对布局)_android_04

实现代码:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"    
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/RelativeLayout1"
android:layout_width="match_parent"
android:layout_height="match_parent" >

<!-- 这个是在容器中央的 -->

<ImageView
android:id="@+id/img1"
android:layout_width="80dp"
android:layout_height="80dp"
android:layout_centerInParent="true"
android:src="@drawable/pic1"/>

<!-- 在中间图片的左边 -->
<ImageView
android:id="@+id/img2"
android:layout_width="80dp"
android:layout_height="80dp"
android:layout_toLeftOf="@id/img1"
android:layout_centerVertical="true"
android:src="@drawable/pic2"/>

<!-- 在中间图片的右边 -->
<ImageView
android:id="@+id/img3"
android:layout_width="80dp"
android:layout_height="80dp"
android:layout_toRightOf="@id/img1"
android:layout_centerVertical="true"
android:src="@drawable/pic3"/>

<!-- 在中间图片的上面-->
<ImageView
android:id="@+id/img4"
android:layout_width="80dp"
android:layout_height="80dp"
android:layout_above="@id/img1"
android:layout_centerHorizontal="true"
android:src="@drawable/pic4"/>

<!-- 在中间图片的下面 -->
<ImageView
android:id="@+id/img5"
android:layout_width="80dp"
android:layout_height="80dp"
android:layout_below="@id/img1"
android:layout_centerHorizontal="true"
android:src="@drawable/pic5"/>

</RelativeLayout>

4.margin与padding的区别

初学者对于这两个属性可能会有一点混淆,这里区分下:首先margin代表的是偏移,比如marginleft = "5dp"表示组件离容器左边缘偏移5dp;而padding代表的则是填充,而填充的对象针对的是组件中的元素,比如TextView中的文字比如为TextView设置paddingleft = "5dp",则是在组件里的元素的左边填充5dp的空间!margin针对的是容器中的组件,而padding针对的是组件中的元素,要区分开来!下面通过简单的代码演示两者的区别:

比较示例代码如下:

<RelativeLayout 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:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity" >

<Button
android:id="@+id/btn1"
android:layout_height="wrap_content"
android:layout_width="wrap_content"
android:text="Button"/>
<Button
android:paddingLeft="100dp"
android:layout_height="wrap_content"
android:layout_width="wrap_content"
android:text="Button"
android:layout_toRightOf="@id/btn1"/>

<Button
android:id="@+id/btn2"
android:layout_height="wrap_content"
android:layout_width="wrap_content"
android:text="Button"
android:layout_alignParentBottom="true"/>
<Button
android:layout_marginLeft="100dp"
android:layout_height="wrap_content"
android:layout_width="wrap_content"
android:text="Button"
android:layout_toRightOf="@id/btn2"
android:layout_alignParentBottom="true"/>

</RelativeLayout>

运行效果图比较:

RelativeLayout(相对布局)_嵌套_05

5.很常用的一点:margin可以设置为负数

相信很多朋友都不知道一点吧,平时我们设置margin的时候都习惯了是正数的,其实是可以用负数的,下面写个简单的程序演示下吧,模拟进入软件后,弹出广告页面的,右上角的cancle按钮的margin则是使用负数的!

效果图如下:

RelativeLayout(相对布局)_嵌套_06

贴出的广告Activity的布局代码吧,当然,如果你对这个有兴趣的话可以下下demo,因为仅仅是实现效果,所以代码会有些粗糙!

<RelativeLayout 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"
tools:context="com.jay.example.relativelayoutdemo.MainActivity"
android:background="#00CCCCFF">

<ImageView
android:id="@+id/imgBack"
android:layout_width="200dp"
android:layout_height="200dp"
android:layout_centerInParent="true"
android:background="@drawable/myicon" />

<ImageView
android:id="@+id/imgCancle"
android:layout_width="28dp"
android:layout_height="28dp"
android:layout_alignRight="@id/imgBack"
android:layout_alignTop="@id/imgBack"
android:background="@drawable/cancel"
android:layout_marginTop="-15dp"
android:layout_marginRight="-10dp" />

</RelativeLayout>

标签:layout,布局,height,width,相对,组件,RelativeLayout,android,id
From: https://blog.51cto.com/u_15641375/6096754

相关文章

  • 数字中国建设整体布局规划发布,零数蓄势待发
    热点追击我们相信国家《数字中国建设整体布局规划》的发布,将为信息技术行业带来长期、巨大的发展机遇。2月27日,中共中央、国务院印发《数字中国建设整体布局规划》(以下简称......
  • java swing 网格布局
    “`packagecom.js;importjava.awt.*;importjavax.swing.*;publicclassJava_3_swing_7_GridLayoutextendsJFrame{publicJava_3_swing_7_GridLayout(){Co......
  • LinearLayout(线性布局)
    本节引言本节开始讲Android中的布局,今天我们要讲解的就是第一个布局,LinearLayout(线性布局),我们屏幕适配的使用用的比较多的就是LinearLayout的weight(权重属性),在这一节里,......
  • C# Winfrom 快速自适应布局
    实现方式:会将from装进Panel里面对控件进行自动计算。在项目中添加AutoWindowsSize.cs类,内容如下:(优势:不需要在Form1中添加任何布局,直接将类复制到项目中,在form1代码中......
  • vue3+ElementPlus 后台布局搭建
    一、https://element-plus.gitee.io/zh-CN/官网  二、后台布局Layui  代码示例如下<template><divclass="app_container"><divclass="common-layo......
  • 行业报告丨生成式 AI 海内外公司布局梳理(下)——国内篇:AI业务增长新驱动,相关产业技术齐
    原创|文BTF机器人03百度(1)广告收入增长趋缓,AI成业务增长新驱动核心广告业务增长乏力。百度是国内搜索及AI领域头部公司,业务收入主要来自搜索广告带来的在线市场服务,自2......
  • 行业报告丨生成式 AI 海内外公司布局梳理(上)——海外篇:微软弯道超车,谷歌蓄势待发
    原创|文BTF机器人01微软(1)老牌PC软件巨头,近年以云业务为核心,Azure市占率不断提升当前微软的核心业务包括智能云(Azure、WindowsServer、GitHub等)、生产力与企业流程(Off......
  • linux配置修改键盘布局
    1.修改图形化界面的键盘布局2.修改终端配置/etc/vconsole.confKEYMAP=dvorak3.修改/etc/X11/xorg.conf.d/00-keyboard.conf#Writtenbysystemd-localed(8),read......
  • Android布局基础知识
    wrap_content:是layout_width和layout_height的属性值之一,表示和自身内容一样的长度。match_parent:是layout_width和layout_height的属性值之一,表示和父组件一样的长度。......
  • 布局3_FrameLayout
    一:基本使用<?xmlversion="1.0"encoding="utf-8"?><FrameLayoutxmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"......