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. [js高手之路] vue系列教程 - vue的基本用法与常见指令(1)

    本系列课程选用vue的版本为1.0.21, 什么是vue? vue是由尤雨溪开发的一款基于MVVM的框架,M->模型,V->视图, 也就是说模型数据改变了,视图也跟着改变, 视图内容改变, ...

  2. CSS制作波浪线

    建议先去了解清楚了径向渐变,线性渐变的用法先 这个作者的css制作波浪线讲解很不错额:https://www.jianshu.com/p/8570433e3669不理解的可以看看这个链接的额 可以去菜 ...

  3. python3基础(二)

    loops循环语句 一 if语句,if语句配合else使用,可以没有else. 单分支if语句 age = input('Age:') password = '67' if age == passwo ...

  4. 跟我一起读postgresql源码(九)——Executor(查询执行模块之——Scan节点(上))

    从前面介绍的可优化语句处理相关的背景知识.实现思想和执行流程,不难发现可优化语句执行的核心内容是对于各种计划节点的处理,由于使用了节点表示.递归调用.统一接口等设计,计划节点的功能相对独立.代码总体流 ...

  5. webpack构建本地服务器

    webpack构建本地服务器 想不想让你的浏览器监测你的代码的修改,并自动刷新修改后的结果,其实Webpack提供一个可选的本地开发服务器,这个本地服务器基于node.js构建, 可以实现你想要的这些 ...

  6. IO(文件)处理

    一.文件操作 1)介绍: 计算机系统分为:计算机硬件,操作系统,应用程序三部分. 我们用python或其他语言编写的应用程序若想要把数据永久保存下来,必须要保存于硬盘中,这就涉及到应用程序要操作硬件, ...

  7. Maven适配多种运行环境的打包方案

    项目从开发到部署会历经多个运行环境,如开发环境.测试环境和生产环境,不同环境中项目的配置文件通常也会不同,典型的如数据库连接配置.我们当然不希望每次部署打包前都去修改配置文件以适配环境,利用Maven ...

  8. Unknown column in 'where clause'

    Unknown column in 'where clause' 错误如题:Unknown column in 'XXX' 'where clause' 意思是:未知表名 排查 1,查表名是否有错 2 ...

  9. 信息学奥赛一本通算法(C++版)基础算法:高精度计算

    高精度加法(大位相加) #include <bits/stdc++.h> using namespace std; int main() { ],b1[]; ],b[],c[];//a,b ...

  10. Codeforces 791B Bear and Friendship Condition(DFS,有向图)

    B. Bear and Friendship Condition time limit per test:1 second memory limit per test:256 megabytes in ...