前言

  关键字: android.view.ViewStub,版本为Android 2.2 r1

  本章翻译来自唐明 ,这里本博负责整理和发布,欢迎其他译者一起参与Android API 的中文翻译行动,联系我over140@gmail.com。

声明

  欢迎转载,但请保留文章原始出处:)

    博客园:http://www.cnblogs.com

    农民伯伯: http://www.cnblogs.com/over140/

正文

  一、结构

    public final class ViewStub extends View

    

    java.lang.Object

     android.view.View

     android.view.ViewStub

  二、类概述

    ViewStub 是一个隐藏的,不占用内存空间的视图对象,它可以在运行时延迟加载布局资源文件。当ViewStub可见,或者调用 inflate()函数时,才会加载这个布局资源文件。 该ViewStub在加载视图时在父容器中替换它本身。因此,ViewStub会一直存在于视图中,直到调用setVisibility(int) 或者inflate()为止。ViewStub的布局参数会随着加载的视图数一同被添加到ViewStub父容器。同样,你也可以通过使用inflatedId属性来定义或重命名要加载的视图对象的Id值。例如:

    

    通过"stud"id可以找到被定义的ViewStub对象。加载布局资源文件"mySubTree "后, ViewStub对象从其父容器中移除。可以通过id"subTree"找到由布局资源"mySubTree"创建的View。这个视图对象最后被指定为宽120dip,高40dip。执行加载布局资源文件的推荐方式如下:

    

    当inflate()被调用, 这个ViewStub被加载的视图替代并且返回这个视图对象。这使得应用程序不需要额外执行findViewById()来获取加载视图的引用。
    (译者注:这个类大概意思是用ViewStub类和在XML文件里面指定的布局资源文件关联起来,让布局资源文件在需要使用的时候再加载上去。主要作用是性能优化,什么时候用什么时候加载,不用在开始启动的时候一次加载,既可以加快程序的启动速度,又可以节省内存资源。)

  三、嵌套类

    接口    ViewStub.OnInflateListener        一个用于接收ViewStub已经成功加载布局资源文件的通知的监听器。

  四、XML属性

属性名称

相关方法

描述

android:inflatedId

setInflatedId(int)

覆盖待加载视图的id值。

android:layout

setLayoutResource(int)

为待加载的资源视图提供一个标识,在ViewStub变为可见或获取焦点时使用它。(译者注:要引用的布局资源文件id)

  五、构造函数

    ViewStub(Context context, int layoutResource)

    创建一个与指定的布局资源文件关联的ViewStub对象。

  参数

    layoutResource   要加载的布局资源文件的id值。

  六、公共方法

public void draw (Canvas canvas)

手动在指定的画布绘制这个视图(及所有其子视图)。这个视图必须在调用这个函数之前做好了整体布局。当要自己实现一个视图时,不要重载这个方法;相反,你应该重载onDraw(Canvas)方法。(译者注:主要用于自定义的视图组件的方法。)

参数

canvas    这个画布传到那个已渲染的视图对象。

public int getInflatedId ()

返回加载的布局资源文件的ID,如果加载的布局资源文件的id是NO_ID,那么这个加载的View将保留它原来的id值。

相关XML 属性

android:inflatedId

返回值

一个正整数来标识这个要加载的视图或者NO_ID将保持加载视图原来的id。

参见

setInflatedId(int)

public int getLayoutResource ()

返回加载的布局资源文件的id值。

相关XML 属性

android:layout

返回值

加载到视图对象的布局资源文件id值。

参见

setLayoutResource(int)

setVisibility(int)

inflate()

public View inflate ()

加载getLayoutResource()方法标识的布局资源,并通过加载布局资源替换父容器中它自己。

返回值

这个已加载的布局资源文件.

public void setInflatedId (int inflatedId)

设置加载视图的ID。如果这个id为NO_ID,这个加载视图保持它原来的id不变。

相关XML 属性

android:inflatedId

参数

inflatedId         一个正整数来标识这个加载视图或者NO_ID将保持加载视图原来的id。

参见

getInflatedId()

public void setLayoutResource (int layoutResource)

设置待加载的布局资源文件,当ViewStub被设置为visible或invisible或调用inflate()时使用。这个在加载布局资源文件时创建的视图用来在父容器中替换它自己。

相关XML 属性

android:layout

参数

layoutResource       一个有效的布局资源文件id值(不等于0)。

参见

getLayoutResource()

setVisibility(int)

inflate()

public void setOnInflateListener (ViewStub.OnInflateListener inflateListener)

      设置成功加载布局资源文件后事件通知的监听器。

  参数

inflateListener         该OnInflateListener在成功加载后得到事件通知。

  参见

ViewStub.OnInflateListener

public void setVisibility (int visibility)

当可见性设置为VISIBLE或INVISIBLE,inflate()将被调用,并且加载视图资源在父容器中替换ViewStub。

参数

visibility 设置为VISIBLE(显示), INVISIBLE(隐藏), 或 GONE(完全隐藏,不暂用布局位置).

参见

   inflate()

  七、受保护方法

protected void dispatchDraw (Canvas canvas)

调用这个函数去绘制这个控件的子视图。可以通过派生类重写在绘制子类之前获取控制(但是是在他自己的视图已经被绘制完之后)

参数

canvas    这个画布传到那个已渲染的视图对象。

protected void onMeasure (int widthMeasureSpec, int heightMeasureSpec)

测量这个视图以确定其内容的高度和宽度。通过measure(int, int)来调用这个方法,并且应该由子类重写以提高内容测量的效率和精确度。

    约定:当该方法被重写时,你必须调用setMeasuredDimension(int, int)来存储已测量视图的高度和宽度。否则将通过measure(int, int)抛出一个IllegalStateException异常。调用父类的onMeasure(int, int)方法是一个有效的办法。

    父类的实现是以背景大小为默认大小,除非MeasureSpec(测量细则)允许更大的背景。为了更好测量内容子类应该重写onMeasure(int, int)。

    如果这个方法被重写,子类有责任确保测量它的高度和宽度至少是视图的最小宽度和高度(getSuggestedMinimumHeight()和getSuggestedMinimumWidth())。

      参数

  widthMeasureSpec         由于父类有横向空间要求,参见View.MeasureSpec。

  heightMeasureSpec        由于父类有纵向空间要求,参见View.MeasureSpec。

  八、下载

    CSDN:http://download.csdn.net/source/2764163

  九、补充

    文章链接

       【译】使用ViewStub(Layout Tricks: Using ViewStubs)

结束

  比较抱歉,上周唐明就已经把稿件交给我了,并叮嘱我帮忙校稿,由于自己这边比较忙一直耽误到现在才发布,再次感谢他!也欢迎大家提出意见,翻译不准确的地方也欢迎批评指正。

Android API 中文(14) —— ViewStub相关推荐

  1. Android API 中文 (51) —— ZoomButtonsController

    一.结构 public class ZoomButtonsController extends View implements View.OnTouchListener java.lang.Objec ...

  2. Android API 中文(77)——AdapterView.OnItemSelectedListener

    前言 本章内容是android.widget.AdapterView.OnItemSelectedListener,版本为Android 2.3 r1,翻译来自"cnmahj",欢 ...

  3. Android API 中文(13) —— ToggleButton

    原文地址为: Android API 中文(13) -- ToggleButton 前言 关键字: Android API 中文,Android 中文 API,android sdk 中文 本章翻译的 ...

  4. android api 中文 (73)—— AdapterView

    前言 本章内容是android.widget.AdapterView,版本为Android 2.3 r1,翻译来自"cnmahj",欢迎大家访问他的博客:http://androi ...

  5. Android API 中文 (53) —— BaseAdapter

    前言 本章内容是 android.widget.BaseAdapter,版本为Android 2.2 r1,翻译来自"德罗德",欢迎大家访问他的博客:http://sparkric ...

  6. Android API 中文 (52) —— ZoomButtonsController.OnZoomListener

    正文 一.结构 public static interface ZoomButtonsController.OnZoomListener android.widget.ZoomButtonsContr ...

  7. Android API中文系列总结

    Android2.2 API 中文文档系列:http://www.cnblogs.com/over140/category/277077.html Android2.2 API 中文文档系列(1) - ...

  8. Android ListView 中文API

    Android API 中文 (42) -- ListView 前言 关键字:Android API 中文 , Android 中文 API , android.widget.ListView 本章内 ...

  9. android api (83) —— InputMethodSession [输入法]

    前言 本章内容是android.view.inputmethod.InputMethodSession,为输入法相关章节,版本为Android 2.3 r1,翻译来自"六必治",欢 ...

最新文章

  1. linux 不接显示器不启动_不知道这十项Linux常识,就别说自己玩过Linux
  2. 企业网站SEO优化的四大原则
  3. python heap_python topN max heap,使用heapq还是自己实现?
  4. matlab 矩阵加减乘除运算
  5. Linux vi 中移动光标 命令
  6. Linux防火墙设置IP端口白名单
  7. 学习分享|量化风控从入门到放弃
  8. Python-18-类的内置属性
  9. java判断是否为linux,java判断是否Linux操作系统,判断OS操作系统类型工具类
  10. oracle excute call,oracle – EXECUTE识别存储过程,CALL不识别
  11. Windwows7 下安装mysql5
  12. oracle 11g rac进程起停
  13. 微软模拟飞行2020 数字化建模分析
  14. 纯js制作的XML在线编辑器(支持修改本地文件)
  15. 阿里巴巴29个屌炸天的开源项目,你用过几个?
  16. 系统操作手册_辽宁高考志愿填报系统2019操作手册(考生版)
  17. 我的世界服务器自动刷矿机,我的世界空岛刷矿机制作教程
  18. 微信小助手简版 WeChatSeptet for Mac安装教程!
  19. 浏览器安全——Web页面安全浏览器网络安全(HTTPS)浏览器系统安全
  20. Matlab绘图(二)—变色散点图二维、三维绘制

热门文章

  1. Android中的音频播放(MediaPlayer和SoundPool)
  2. cop2000计算机组成原理,COP2000计算机组成原理实验系统
  3. 语法分析器c语言 递归子程序,RecursiveSubroutine
  4. ruijie交换机lacp动态_Server2016和华为s5720交换机链路聚合增加带宽
  5. 二手手机交易平台使用MYSQL的方法_安卓Android校园淘(二手交易)APP设计与实现(MySQL)...
  6. SpringCloud和SprigBoot之间的依赖关系怎么看
  7. APP技巧:手机连接WiFi后,移动数据流量要不要关闭,看完你就懂了!
  8. MySQL性能优化知识:长连接、短连接、连接池
  9. MYSQL 定时自动执行任务
  10. python序列化和反序列化_Python 中 json 数据序列化和反序列化