人类科技的进步源自探索,探索来自于发现本原,当然App布局没这么先进,本文也只是一个归类总结。
这篇文章是Android开发人员的必备知识,是我特别为大家整理和总结的,不求完美,但是有用。
Android界面开发多多少少会有很多雷同或者相似的布局,不仅如此,纵观Android应用的界面,总也逃不出那些熟悉的结构。
今天,我根据经验,把我认为的常见的布局做一个分析,归纳出几种简单的模型,这些模型一般是我认为解决其对应布局问题的最佳布局,具体要看情况。
因为工作的限制,我无法专门研究天马行空,万罗天象的布局,只能根据我工作中碰到的布局,略加斟酌。
还有一点我要强调,这些布局的原则就是:简单,灵活。
模型一: 水平三列坐拥式
      效果图:
<ignore_js_op>       
      说明:水平三列,两边分别是"返回","提交"的按钮,中间是必须居中的几个字,一般都是标题名称。
              仿佛标题内容的背景坐拥左右两位美女般的按钮。
      方法:主要使用FrameLayout布局
      素材:
            <ignore_js_op> 、<ignore_js_op> 
      layout代码:
  1. <!--这种布局:
  2. 缺点是,标题只能就几个字,字多了就会撑开并和两边的按钮重叠
  3. 优点是,代码简洁;-->
  4. <?xml version="1.0" encoding="utf-8"?>
  5. <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
  6. android:layout_width="fill_parent"
  7. android:layout_height="wrap_content"
  8. android:background="@drawable/layout01_bg"
  9. android:paddingLeft="10dip"
  10. android:paddingRight="10dip"
  11. >
  12. <Button android:layout_gravity="left|center_vertical"
  13. android:layout_width="wrap_content"
  14. android:layout_height="wrap_content"
  15. android:background="@drawable/layout01_tool"
  16. android:text="返回"
  17. android:padding="8dip"
  18. />
  19. <TextView android:layout_gravity="center"
  20. android:layout_width="wrap_content"
  21. android:layout_height="wrap_content"
  22. android:text="标题内容"
  23. android:textSize="18dip"
  24. android:textColor="#000000" />
  25. <Button android:layout_gravity="right|center_vertical"
  26. android:layout_width="wrap_content"
  27. android:layout_height="wrap_content"
  28. android:background="@drawable/layout01_tool"
  29. android:text="前进"
  30. android:padding="8dip"
  31. />
  32. </FrameLayout>

复制代码

模型二:水平三列双耳式
      效果图:
<ignore_js_op> 
      说明: 水平三列,两边分别是"返回","提交"的按钮,中间是几个字,这几个字可以居左,居中,居右,而不与两边的按钮重叠。
               此模型和坐拥式模型相似,但是中间的部分不是把左右按钮坐拥入怀,而是单独占据,且也只占据中间部分。
               这种模型能够实现坐拥式模型的效果,而且能偏左偏右而不和两边按钮重叠。
               但是因为这种情况使用RelativeLayout布局比较好,需要定义ID,稍微麻烦了一点点。 
      方法:主要是RelativeLayout布局
      素材:同上
      layout代码:

  1. <!--这种布局:
  2. 缺点是代码还算简洁,但是比坐拥式要稍微复杂一点
  3. 有点是比坐拥式更强大,更灵活
  4. -->
  5. <?xml version="1.0" encoding="utf-8"?>
  6. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  7. android:layout_width="fill_parent"
  8. android:layout_height="wrap_content"
  9. android:background="@drawable/layout01_bg"
  10. android:paddingLeft="10dip"
  11. android:paddingRight="10dip"
  12. >
  13. <Button android:id="@+id/left_button"
  14. android:layout_alignParentLeft="true"
  15. android:layout_centerVertical="true"
  16. android:layout_width="wrap_content"
  17. android:layout_height="wrap_content"
  18. android:background="@drawable/layout01_tool"
  19. android:text="返回列表"
  20. android:padding="8dip"
  21. />
  22. <Button android:id="@+id/right_button"
  23. android:layout_alignParentRight="true"
  24. android:layout_centerVertical="true"
  25. android:layout_width="wrap_content"
  26. android:layout_height="wrap_content"
  27. android:background="@drawable/layout01_tool"
  28. android:text="评论"
  29. android:padding="8dip"
  30. />
  31. <!--设置LeftOf和RightOf,可填充中间空余部分-->
  32. <TextView android:layout_toRightOf="@id/left_button"
  33. android:layout_toLeftOf="@id/right_button"
  34. android:layout_centerVertical="true"
  35. android:gravity="left"
  36. android:paddingLeft="5dip"
  37. android:layout_width="fill_parent"
  38. android:layout_height="wrap_content"
  39. android:text="资讯>>正文"
  40. android:textSize="18dip"
  41. android:textColor="#000000" />
  42. </RelativeLayout>

复制代码

  关于这个模型,我补充一点,很多人认为这个用LinearLayout布局,设置两边的控件居左居右,中间的设置layout_gravity想偏左就偏左,想偏右就偏右。
      但是,LinearLayout布局方向为"horizontal" ,layout_gravity是无效的。
模型三: 水平四列双耳互补式
      效果图:
<ignore_js_op> 
<ignore_js_op> 
      说明: 两边是按钮,中间部分被两个控件互补式分割,主要是左边的会随内容填充,但是必须两者内容宽度之和不能大于中间部分。
               这个和双耳式差不多,也说明了,双耳式在保证有空余空间的基础上,可以扩充到4列,5列等多列。
      方法:主要是RelativeLayout布局
      素材:同上
      layout代码:
  1. <!--双耳式在多列情况下的扩展式-->
  2. <?xml version="1.0" encoding="utf-8"?>
  3. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  4. android:layout_width="fill_parent"
  5. android:layout_height="wrap_content"
  6. android:background="@drawable/layout01_bg"
  7. android:paddingLeft="10dip"
  8. android:paddingRight="10dip"
  9. >
  10. <Button android:id="@+id/left_button"
  11. android:layout_alignParentLeft="true"
  12. android:layout_centerVertical="true"
  13. android:layout_width="wrap_content"
  14. android:layout_height="wrap_content"
  15. android:background="@drawable/layout01_tool"
  16. android:text="返回列表"
  17. android:padding="8dip"
  18. />
  19. <Button android:id="@+id/right_button"
  20. android:layout_alignParentRight="true"
  21. android:layout_centerVertical="true"
  22. android:layout_width="wrap_content"
  23. android:layout_height="wrap_content"
  24. android:background="@drawable/layout01_tool"
  25. android:text="评论"
  26. android:padding="8dip"
  27. />
  28. <!-- 下面这个宽度是wrap_content,在左边按钮的右边,能够随内容加宽 -->
  29. <TextView android:id="@+id/center_text_01"
  30. android:layout_toRightOf="@id/left_button"
  31. android:layout_centerVertical="true"
  32. android:gravity="left"
  33. android:paddingLeft="5dip"
  34. android:layout_width="wrap_content"
  35. android:layout_height="wrap_content"
  36. android:background="#aabbcc"
  37. android:text="夫妇+小三"
  38. android:textSize="18dip"
  39. android:textColor="#000000" />
  40. <!-- 下面这个宽度是fill_parent,自动填充中间部分的空余空间,分别定义了左右依赖的控件,所以放在最后 -->
  41. <TextView android:id="@+id/center_text_02"
  42. android:layout_toRightOf="@id/center_text_01"
  43. android:layout_toLeftOf="@id/right_button"
  44. android:layout_centerVertical="true"
  45. android:gravity="right"
  46. android:paddingLeft="5dip"
  47. android:layout_width="fill_parent"
  48. android:layout_height="wrap_content"
  49. android:background="#ccaabb"
  50. android:text="何求"
  51. android:textSize="18dip"
  52. android:textColor="#000000" />
  53. </RelativeLayout>

复制代码

模型四:水平多列分摊式(增强版)
      效果图:
<ignore_js_op> 
      说明:几大模块均占所有区域,之间以小小的分割线隔离。
              因为分割线只占很小的部分,所有模块和分割线并不是分摊的,但是模块标题本身占据大头,他们之间是分摊的。
      素材:
<ignore_js_op> 
      方法: 直接用LinearLayout布局,模块均摊,都设置layout_weight="1",分割线不分摊,不设置layout_weight,默认自包裹,不延伸。
      layout代码:

  1. <!--此代码采用动态生成,只要稍加判断,效果一样-->
  2. <?xml version="1.0" encoding="utf-8"?>
  3. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  4. android:layout_width="fill_parent"
  5. android:layout_height="25dip"
  6. android:background="#ffffff"
  7. >
  8. <TextView android:text="首页"
  9. android:layout_weight="1"
  10. android:gravity="center"
  11. android:layout_gravity="center_vertical"
  12. android:layout_width="wrap_content"
  13. android:layout_height="wrap_content"
  14. />
  15. <ImageView android:gravity="center"
  16. android:layout_gravity="center_vertical"
  17. android:layout_width="10dip"
  18. android:layout_height="wrap_content"
  19. android:src="@drawable/layout04_split"
  20. />
  21. <TextView android:text="资讯"
  22. android:layout_weight="1"
  23. android:gravity="center"
  24. android:layout_gravity="center_vertical"
  25. android:layout_width="wrap_content"
  26. android:layout_height="wrap_content"
  27. />
  28. <ImageView android:gravity="center"
  29. android:layout_gravity="center_vertical"
  30. android:layout_width="10dip"
  31. android:layout_height="wrap_content"
  32. android:src="@drawable/layout04_split"/>
  33. <TextView android:text="博客"
  34. android:layout_weight="1"
  35. android:gravity="center"
  36. android:layout_gravity="center_vertical"
  37. android:layout_width="wrap_content"
  38. android:layout_height="wrap_content"
  39. />
  40. <ImageView android:gravity="center"
  41. android:layout_gravity="center_vertical"
  42. android:layout_width="10dip"
  43. android:layout_height="wrap_content"
  44. android:src="@drawable/layout04_split"/>
  45. <TextView android:text="图片"
  46. android:layout_weight="1"
  47. android:gravity="center"
  48. android:layout_gravity="center_vertical"
  49. android:layout_width="wrap_content"
  50. android:layout_height="wrap_content"
  51. />
  52. <ImageView android:gravity="center"
  53. android:layout_gravity="center_vertical"
  54. android:layout_width="10dip"
  55. android:layout_height="wrap_content"
  56. android:src="@drawable/layout04_split"/>
  57. <TextView android:text="论坛"
  58. android:layout_weight="1"
  59. android:gravity="center"
  60. android:layout_gravity="center_vertical"
  61. android:layout_width="wrap_content"
  62. android:layout_height="wrap_content"
  63. />
  64. </LinearLayout>

复制代码

模型五:垂直三行天地式
      效果图:
<ignore_js_op> 
      说明:类似于水平三列双耳式,上下固定,中间自适应(自填充),不多说。
      方法:同水平三列双耳式,使用RelativeLayout布局
      layout代码:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent">
  5. <TextView android:id="@+id/top_text"
  6. android:layout_alignParentTop="true"
  7. android:layout_width="fill_parent"
  8. android:layout_height="wrap_content"
  9. android:gravity="center"
  10. android:text="上海车展"
  11. android:textColor="#ffffff"/>
  12. <LinearLayout android:id="@+id/bottom_linear"
  13. android:layout_width="fill_parent"
  14. android:layout_height="wrap_content"
  15. android:gravity="center"
  16. android:layout_alignParentBottom="true"
  17. android:background="#123456"
  18. android:orientation="horizontal">
  19. <Button  android:layout_width="wrap_content"
  20. android:layout_height="wrap_content"
  21. android:text="上一张"/>
  22. <Button  android:layout_width="wrap_content"
  23. android:layout_height="wrap_content"
  24. android:layout_gravity="center"
  25. android:text="下一张"/>
  26. </LinearLayout>
  27. <!-- 下面部分是中间主体部分,我特意用LinearLayout包裹起来,表示这里面可以填充其他任何组合的控件 -->
  28. <LinearLayout android:id="@+id/center_linear"
  29. android:layout_below="@id/top_text"
  30. android:layout_above="@id/bottom_linear"
  31. android:layout_width="fill_parent"
  32. android:layout_height="fill_parent"
  33. android:background="#ffffff"
  34. android:gravity="center">
  35. <ImageView android:layout_width="fill_parent"
  36. android:layout_height="fill_parent"
  37. android:src="@drawable/shanhai" />
  38. </LinearLayout>
  39. </RelativeLayout>

复制代码

模型六:垂直三行弹簧式
      效果图:
<ignore_js_op> 
      说明:这种模型很简单,类似于弹簧,最下面的一行能伸能屈,中间部分随内容固定。
      方法:类似于模式五。
      layout代码:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent">
  5. <!-- 顶部 -->
  6. <TextView android:id="@+id/top_text"
  7. android:layout_alignParentTop="true"
  8. android:layout_width="fill_parent"
  9. android:layout_height="wrap_content"
  10. android:gravity="center"
  11. android:text="上海车展"
  12. android:textColor="#ffffff"/>
  13. <!-- 顶部的下面是中间导航部分 -->
  14. <LinearLayout android:id="@+id/center_linear"
  15. android:layout_below="@id/top_text"
  16. android:layout_width="fill_parent"
  17. android:layout_height="wrap_content"
  18. android:gravity="center"
  19. android:background="#123456"
  20. android:orientation="horizontal">
  21. <Button  android:layout_width="wrap_content"
  22. android:layout_height="wrap_content"
  23. android:text="上一张"/>
  24. <Button  android:layout_width="wrap_content"
  25. android:layout_height="wrap_content"
  26. android:layout_gravity="center"
  27. android:text="下一张"/>
  28. </LinearLayout>
  29. <!-- 最后部分填充剩下的区域 -->
  30. <LinearLayout android:id="@+id/bottom_linear"
  31. android:layout_below="@id/center_linear"
  32. android:layout_width="fill_parent"
  33. android:layout_height="fill_parent"
  34. android:background="#ffffff"
  35. android:gravity="center"
  36. android:layout_alignParentBottom="true">
  37. <ImageView android:layout_width="fill_parent"
  38. android:layout_height="fill_parent"
  39. android:src="@drawable/shanhai" />
  40. </LinearLayout>
  41. </RelativeLayout>

复制代码

   初探之下,列举了简单的6中模型,除此之外,本人发现受限于手机屏幕大小的限制和高宽的固定,有很多web的布局其实在手机上的实现是很难的。
      希望看了文章的人,能支持一下,有什么好的经典的布局,给我留言,一起探讨,一起分享。
      最后公布一个大概布局的三字文:
上中下,左中右,多行列,用相对。
线性局,紧凑排,无方向,可居中。
帧布局,定位准,相关弱,代码少。
本文作者:谦虚的天下

Android学习系列(5)--App布局初探之简单模型的更多相关文章

  1. Android学习系列(23)--App主界面实现

    在上篇文章<Android学习系列(22)--App主界面比较>中我们浅略的分析了几个主界面布局,选了一个最大众化的经典布局.今天我们就这个经典布局,用代码具体的实现它. 1.预览图先看下 ...

  2. Android学习系列(15)--App列表之游标ListView(索引ListView)

    游标ListView,提供索引标签,使用户能够快速定位列表项.      也可以叫索引ListView,有的人称也为Tweaked ListView,可能更形象些吧.      一看图啥都懂了: 1. ...

  3. Android学习系列(11)--App列表之拖拽ListView(下)

    接着上篇Android学习系列(10)--App列表之拖拽ListView(上)我们继续实现ListView的拖拽效果. 7.重写onTouchEvent()方法.     在这个方法中我们主要是处理 ...

  4. Android学习系列(10)--App列表之拖拽ListView(上)

     研究了很久的拖拽ListView的实现,受益良多,特此与尔共飨.      鉴于这部分内容网上的资料少而简陋,而具体的实现过程或许对大家才有帮助,为了详尽而不失真,我们一步一步分析,分成两篇文章. ...

  5. Android学习系列(3)--App自动更新之自定义进度视图和内部存储

    友好的视觉感知和稳定的不出错表现,来自于我们追求美感和考虑的全面性,博客园从技术的角度,一直我都很欣赏.这篇文章是android开发人员的必备知识,是我特别为大家整理和总结的,不求完美,但是有用. 这 ...

  6. Android学习系列(37)--App调试内存泄露之Context篇(下)

    接着<Android学习系列(36)--App调试内存泄露之Context篇(上)>继续分析. 5. AsyncTask对象 我N年前去盛大面过一次试,当时面试官极力推荐我使用AsyncT ...

  7. Android学习系列(7)--App轮询服务器消息

    这篇文章是android开发人员的必备知识. 1.轮询服务器     一般的应用,定时通知消息可以采用轮询的方法从服务器拿取消息,当然实时消息通知的话,建议采用推送服务.    其中需要注意轮询的频率 ...

  8. Android学习系列(17)--App列表之圆角ListView(续)

    http://www.cnblogs.com/qianxudetianxia/archive/2011/09/19/2068760.html   本来这篇文章想并到上篇Android学习系列(16)- ...

  9. Android学习系列(18)--App工程结构搭建

     本文算是一篇漫谈,谈一谈关于Android开发中工程初始化的时候如何在初期我们就能搭建一个好的架构.      关于android架构,因为手机的限制,目前我觉得也确实没什么大谈特谈的,但是从开发的 ...

随机推荐

  1. eclipse oracle Database Manager plugin oracle数据库连接插件

    在eclipseIDE中开发项目需要经常连接oracle数据库,装一些oracle client 去连接数据库,界面来回切换比较麻烦,所以专门找了一个eclipse插件专门连接oracle,跟大家分享 ...

  2. Informatica 常用组件Aggregator之三 使用排序输入

    可以使用排序输入选项改善聚合转换性能.使用排序输入时,PowerCenter 会假定所有数据已按组排序.PowerCenter 读取某组的行时,它将执行聚合计算.需要时,它会将组信息存储在存储器中.要 ...

  3. Geolocation地理定位

    地理位置(Geolocation)是 HTML5 的重要特性之一,提供了确定用户位置的功能,借助这个特性能够开发基于位置信息的应用.今天这篇文章向大家介绍一下 HTML5 地理位置定位的基本原理及各个 ...

  4. 对SingleTask和TaskAffinity的理解

    最近研究微信调起自己客户端的事情,对于SingleTask和TaskAffinity的理解又多了一些理解. 以前对于Android的四种LaunchMode有一些了解,其中比较有意思的就是Single ...

  5. 升级mojave后的小问题解决

    首先是xcode没了,我到苹果软件市场上重新下载了一个,可以了. 然后是virtualbox无法打开了,现实版本不兼容,我到官网重新下载了一个最新的6.0.然后就可以正常打开了,并且是无感升级,原来的 ...

  6. bash參考手冊之六(Bash特性)

    6 Bash 特性 这部分描写叙述Bash独有的特性. *  调用Bash : Bash能够接受的命令行选项. *  Bash启动文件 : Bash何时及怎样运行脚本. *  交互Shell : 什么 ...

  7. Graphical vi-vim Cheat Sheet and Tutorial

    主要内容: VIM编辑器的快捷命令cheat sheet(小抄),一共七张图,简单明了地介绍了vim的快捷命令,相比于满满的图表,分成七小块更易于记住. 更多关于vim的cheat sheet以及相关 ...

  8. Centos6.6系统root用户密码恢复案例(转)

    原文:http://www.centoscn.com/CentOS/Intermediate/2015/0131/4604.html 通过单用户模式恢复root用户密码 重新启动主机后,在出现Grub ...

  9. HTML一(简介)

    什么是 HTML? HTML 是用来描述网页的一种语言. HTML 指的是超文本标记语言 (Hyper Text Markup Language) HTML 不是一种编程语言,而是一种标记语言 (ma ...

  10. window下redis nosql初试

    1:redis官方下载地址http://redis.io/download   下载下来,有32位的,有64位的,自己选择. 2:将redis文件夹放到D盘:D:\redis watermark/2/ ...