Android 基础:常用布局 介绍 & 使用(附 属性查询)

 

前言

  • 在 Android开发中,绘制UI时常需各种布局
  • 今天,我将全面介绍Android开发中最常用的五大布局

含 Android Studio 2.2中新增的布局:约束布局(ConstraintLayout)介绍


目录

1. 布局类型

Android中,共有2类、6种布局方式,分别是:

2. 布局介绍

  • 具体介绍
  • 本文主要介绍传统的5大布局,关于约束布局(ConstraintLayout)具体点击查看文章


    3. 布局属性

    • Android的布局属性通过 XML配置
    • 下面,主要讲解布局公有属性 & 特有属性

    3.1 公有属性

    即 5种布局都具备下述属性

    • layout_width 、layout_height
    • layout_margin+方位
    • padding +方位
    • layout_gravity
    • gravity

    
    
  • 3.2 特有属性

    • 具体介绍如下
    • 3.3 特别注意

      • 5个布局元素可相互嵌套使用,从而实现各种不同的效果
      • 关于 线性布局(LinearLayout)的权重属性layout_weight请看文章

      4. 选择器(Selector)

      4.1 作用

      通过设置选择器(selector)可使控件 在不同操作下(默认、点击等) 显示不同样式

      通过 xml编写 = selector.xml

      4.2 属性

      XML属性 说明
      android:drawable 放一个drawable资源
      android:state_pressed 按下状态,如一个按钮触摸或者点击。
      android:state_focused 取得焦点状态,比如用户选择了一个文本框。
      android:state_hovered 光标悬停状态,通常与focused state相同,它是4.0的新特性
      android:state_selected 选中状态
      android:state_enabled 能够接受触摸或者点击事件
      android:state_checked 被checked了,如:一个RadioButton可以被check了。
      android:state_enabled 能够接受触摸或者点击事件

      注:上述所有属性的取值 = boolean属性 = truefalse

      4.3 实例说明

      drawable添加 selector.xml 资源文件

      button_selector.xml:

      <?xml version="1.0" encoding="UTF-8"?>
      < selector xmlns:android="http://schemas.android.com/apk/res/android"> < !-- 指定按钮按下时的图片 -->
      <item android:state_pressed="true"
      android:drawable="@drawable/start_down"
      /> < !-- 指定按钮松开时的图片 -->
      <item android:state_pressed="false"
      android:drawable="@drawable/start"
      /> < /selector>

      在布局文件main.xml中控件的属性设置:

      <Button
      android:id="@+id/startButton"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:background="@drawable/button_selector"
      />

      5. 布局形状(Shape)

      • 作用:设置布局的颜色、边框线
      • 使用:通过 xml编写 = shape.xml
      • 具体使用
      <shape xmlns:android="http://schemas.android.com/apk/res/android">
      
      //默认颜色
      <solid android:color="#876543"/>
      //哪个方向有边框线
      <padding
      android:bottom="0dp"
      android:left="1dp"
      android:right="1dp"
      android:top="1dp" />
      //边框线颜色、大小
      <stroke
      android:width="1dp"
      android:color="#000000" />

      在布局文件main.xml中控件的属性设置:

      <Button
      android:id="@+id/startButton"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:background="@drawable/layout_shape"
      />

      6. 总结

      • 本文全面介绍了 Android常用布局
      
      

Android 基础:常用布局 介绍 & 使用(附 属性查询)的更多相关文章

  1. 跟我学android-android常用布局介绍

    在上一章我们曾经谈到,Android平台的界面 是使用XML的方式设计的,然后在上一章我们只做了一个简单的界面,在这章,我们将介绍如何使用常用的控件设计实用的界面. Android中的视图都是继承Vi ...

  2. Android基础之布局ConstraintLayout

    Google I/O 2016 上发布了 ConstraintLayout,据说很强大,那就一探究竟吧! gradle配置 compile 'com.android.support.constrain ...

  3. Android中常用布局单位

    Android在UI布局时经常用到一些单位,对单位混用直接会影响UI的显示,要想正确的在布局中使用每种单位就必须先真正的熟悉它. UI显示效果的影响因素:屏幕尺寸.屏幕密度.分辨率:而android手 ...

  4. WPF常用布局介绍

    概述:本文简要介绍了WPF中布局常用控件及布局相关的属性 1 Canvas Canvas是一个类似于坐标系的面板,所有的元素通过设置坐标来决定其在坐标系中的位置..具体表现为使用Left.Top.Ri ...

  5. Android 之常用布局

    LinearLayout 线性布局. android:orientation="horizontal" 制定线性布局的排列方式 水平 horizontal 垂直 vertical ...

  6. Android linearlayout常用布局

    用linearlayout完成这样的布局效果,这样的布局还是比较常用的,具体的xml代码如下: <LinearLayout xmlns:android="http://schemas. ...

  7. Android中常用布局

     1.线性布局  LinearLayout         orientation:方向:vertical,垂直:horizontal,水平         gravity:对齐方式,子控件相对于当前 ...

  8. Android五大布局介绍&属性设置大全

    前言 在进行Android开发中,常常需要用到各种布局来进行UI的绘制,今天我们就来讲下Android开发中最常用的五大布局介绍和相关属性的设置. 目录 Android五大布局介绍&属性设置. ...

  9. Android基础夯实--重温动画(四)之属性动画 ValueAnimator详解

    宝剑锋从磨砺出,梅花香自苦寒来:千淘万漉虽辛苦,吹尽狂沙始到金: 长风破浪会有时,直挂云帆济沧海 一.摘要 Animator类作为属性动画的基类,它是一个抽象类,它提供了实现动画的基本架构,但是我们不 ...

随机推荐

  1. Nginx集群之WCF分布式局域网应用

    目录 1       大概思路... 1 2       Nginx集群WCF分布式局域网结构图... 1 3       关于WCF的BasicHttpBinding. 1 4       编写WC ...

  2. Wechat 微信端调用“微信支付接口”的正确方式

    微信端的项目中,比如微信商城之类的,肯定会涉及到微信支付这一块: 下面直接上详细的代码: var data = {--}; // 调用微信支付需要的数据 function onBridgeReady( ...

  3. iOS 关于退出键盘两种方法和避免遮挡

    退出键盘: 方法1:不使用代理,直接使用: -(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event { [self.textFi ...

  4. jQuery 入门

    不能正常引用jQuery-2.2.4.min.js所以代码没生效 jQuery 是一个 JavaScript 函数库.jQuery 库包含以下特性: HTML 元素选取 HTML 元素操作 CSS 操 ...

  5. Java框架之Hibernate(二)

    本文主要介绍: 1 Criteria 接口 2 用 myeclipse 反向生成 3 hibernate  主键生成策略 4 多对一 5 一对多 6 使用List 集合的一对多 7 多对多 一.Cri ...

  6. C和Lua之间的相互调用

    前面的话 第一次接触Lua是因为Unity游戏中需要热更,但是一直没搞懂Lua是怎么嵌入到别的语言中执行的,如何互相调用的.这次打算好好了解一下C跟lua是如何交互的 那么如何使用Lua语言? lua ...

  7. 6、ABPZero系列教程之拼多多卖家工具 框架后台的设置

    接着上篇文章,现在去修改注册登录逻辑代码还为时过早,我们还需要到后台去设置一些配置. 管理---设置 先配置好这2项设置,邮箱配置是为了验证注册时功能是否正常,下一篇文章需要用到. 注:邮箱配置中的密 ...

  8. StackExchange.Redis学习笔记(五) 发布和订阅

    Redis命令中的Pub/Sub Redis在 2.0之后的版本中 实现了 事件推送的  发布订阅命令 以下是Redis关于发布和订阅提供的相关命令 SUBSCRIBE channel [channe ...

  9. weui中的日期选择控件关于时间段的设置!

    近日用到了日期控件,但是需要把时和分去掉,功能上是做一个预约的功能,所以只需要在年月日后面提供时间段的选择. BUG在于如果第一次点开弹框而没做任何操作,然后点了其他任意区域则弹框关闭,甚至你的8:0 ...

  10. CSS3让文本自动换行——word-break属性

    1.依靠浏览器让文本自动换行 浏览器本身都自带着让文本自动换行的功能. 2.指定自动换行的处理方法 在CSS3中,可以使用word-break属性来自己决定自动换行的处理方法. div{ word-b ...