LatoutInflate 主要的作用是实例化一个 xml 文件,使得开发者获取一个 View 的实例(也可以看着把一个 xml 文件渲染成一个视图)。在 LayoutInflate 的内部,LayoutInflate 拿到自身的实例,一般通过 android.app.Activity#getLayoutInflater() 方法,或者通过 Context#getSystemService 来拿到已经在应用中的 LayoutInflate 实例(系统早已经配置好了 LayoutInflate 实例)。

[源码 1]
public View inflate(@LayoutRes int resource, @Nullable ViewGroup root, boolean attachToRoot) {final Resources res = getContext().getResources();if (DEBUG) {Log.d(TAG, "INFLATING from resource: \"" + res.getResourceName(resource) + "\" ("+ Integer.toHexString(resource) + ")");}final XmlResourceParser parser = res.getLayout(resource); //返回布局资源解析try {return inflate(parser, root, attachToRoot); // 1} finally {parser.close();}}
复制代码

在 [源码 1] 中,inflate(@LayoutRes int resource, @Nullable ViewGroup root, boolean attachToRoot) 方法里面三个参数分别表示:

  • resource 参数表示需要渲染的 xml 布局资源
  • root 如果 attachToRoot 设置为 true,则生成结构层次的父级; 如果设置为 false,则返回结构层次提供的一组 LayoutParams 值的对象(这个值可能为空); [ViewGroup 是一个包含其他视图的特殊的 View,可以看作一个视图容器]
  • attachToRoot 渲染的视图的结构层次是否捆绑父视图的参数,如果设置为 false,则表示需要捆绑;

在 [源码 1] 中的解析 1处,会调用方法 inflate(parser, root, attachToRoot),下面是查看其源码:

[源码 2]
public View inflate(XmlPullParser parser, @Nullable ViewGroup root, boolean attachToRoot) {synchronized (mConstructorArgs) {...final AttributeSet attrs = Xml.asAttributeSet(parser); //返回 xml 资源布局的属性集合...View result = root;try {// 查找视图的跟视图节点int type;while ((type = parser.next()) != XmlPullParser.START_TAG &&type != XmlPullParser.END_DOCUMENT) {// Empty}if (type != XmlPullParser.START_TAG) {throw new InflateException(parser.getPositionDescription()+ ": No start tag found!");}final String name = parser.getName();if (DEBUG) {System.out.println("**************************");System.out.println("Creating root view: "+ name);System.out.println("**************************");}if (TAG_MERGE.equals(name)) {if (root == null || !attachToRoot) { //根视图为空 || attachToRoot 为 falsethrow new InflateException("<merge /> can be used only with a valid "+ "ViewGroup root and attachToRoot=true");}rInflate(parser, root, inflaterContext, attrs, false);} else {// 把当前 Xml 布局实例化,并且拿到该 View 的实例final View temp = createViewFromTag(root, name, inflaterContext, attrs);ViewGroup.LayoutParams params = null;if (root != null) {  //当根节点不为空的时候,创建根视图的节点的参数// Create layout params that match root, if suppliedparams = root.generateLayoutParams(attrs);  // 2if (!attachToRoot) { //为 false 的时候根视图绑定参数// Set the layout params for temp if we are not// attaching. (If we are, we use addView, below)temp.setLayoutParams(params); // 3}}...//再次渲染根视图下面的子视图rInflateChildren(parser, temp, attrs, true);  ...// We are supposed to attach all the views we found (int temp)// to root. Do that now.if (root != null && attachToRoot) {root.addView(temp, params);}// Decide whether to return the root that was passed in or the// top view found in xml.if (root == null || !attachToRoot) {result = temp;}}} catch (XmlPullParserException e) {} catch (Exception e) {} finally {}return result;}}
复制代码

上面 [源码 2] 主要的逻辑是把从 inflate(XmlPullParser parser, @Nullable ViewGroup root, boolean attachToRoot) {synchronized (mConstructorArgs) 的方法中传进的 root 参数(该参数为需要渲染的 xml 布局),经过 createViewFromTag(root, name, inflaterContext, attrs) 的方法拿到该 root 视图的实例,因为 root 不为空,所以在注释 2、3 处,为该视图布局绑定布局参数,带视图参数返回视图的实例; 如果 root 参数在 inflate 方法传进来的时候为空,侧直接返回该 xml 视图的实例,但没有绑定布局参数;

转载于:https://juejin.im/post/5ac306e9518825557e7893f6

LayoutInflate部分源码解析相关推荐

  1. 谷歌BERT预训练源码解析(二):模型构建

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/weixin_39470744/arti ...

  2. 谷歌BERT预训练源码解析(三):训练过程

    目录 前言 源码解析 主函数 自定义模型 遮蔽词预测 下一句预测 规范化数据集 前言 本部分介绍BERT训练过程,BERT模型训练过程是在自己的TPU上进行的,这部分我没做过研究所以不做深入探讨.BE ...

  3. 谷歌BERT预训练源码解析(一):训练数据生成

    目录 预训练源码结构简介 输入输出 源码解析 参数 主函数 创建训练实例 下一句预测&实例生成 随机遮蔽 输出 结果一览 预训练源码结构简介 关于BERT,简单来说,它是一个基于Transfo ...

  4. Gin源码解析和例子——中间件(middleware)

    在<Gin源码解析和例子--路由>一文中,我们已经初识中间件.本文将继续探讨这个技术.(转载请指明出于breaksoftware的csdn博客) Gin的中间件,本质是一个匿名回调函数.这 ...

  5. Colly源码解析——结合例子分析底层实现

    通过<Colly源码解析--框架>分析,我们可以知道Colly执行的主要流程.本文将结合http://go-colly.org上的例子分析一些高级设置的底层实现.(转载请指明出于break ...

  6. libev源码解析——定时器监视器和组织形式

    我们先看下定时器监视器的数据结构.(转载请指明出于breaksoftware的csdn博客) /* invoked after a specific time, repeatable (based o ...

  7. libev源码解析——定时器原理

    本文将回答<libev源码解析--I/O模型>中抛出的两个问题.(转载请指明出于breaksoftware的csdn博客) 对于问题1:为什么backend_poll函数需要指定超时?我们 ...

  8. libev源码解析——I/O模型

    在<libev源码解析--总览>一文中,我们介绍过,libev是一个基于事件的循环库.本文将介绍其和事件及循环之间的关系.(转载请指明出于breaksoftware的csdn博客) 目前i ...

  9. libev源码解析——调度策略

    在<libev源码解析--监视器(watcher)结构和组织形式>中介绍过,监视器分为[2,-2]区间5个等级的优先级.等级为2的监视器最高优,然后依次递减.不区分监视器类型和关联的文件描 ...

最新文章

  1. spring28: aspectJ--基于xml
  2. jQuery-全选、全不选、反选、提交等功能的实现(试了你就知道)
  3. TCP/IP / 三次握手之状态转换图和原因
  4. Infura Http 客户端 以太坊 交易
  5. java rwd_面向任务的设计-不仅限于Mobile First和RWD
  6. vim学习日志(5):vim下wimrc的配置,解决中文乱码问题
  7. java.awt.api_Java SE 11(18.9)中的API更新
  8. Spring For All 顶级Spring综合社区服务平台
  9. 前端学习(3045):vue+element今日头条管理-创建页面组件
  10. java上传csv文件上传_java处理csv文件上传示例详解
  11. python123-Python123
  12. Java爬虫入门详解(Selenium)
  13. topsis法_topsis法量化多个评价指标,找出最优方案
  14. 国内外各大免费搜索引擎、导航网址提交入口(转载)
  15. 常见分布 的 数学期望以及方差公式
  16. 解决 Ubuntu 22.04 Fractional Scaling 画面伸缩后应用程序模糊
  17. 《Adobe Premiere Pro CS5经典教程》——2.5 导入素材
  18. CDH安装服务和下载parcels包
  19. mysql数据库日志操作
  20. Java如何解析个人或他人微信二维码内的信息

热门文章

  1. C++标准类型库string
  2. C++中的四类强制转换?
  3. C++ 多继承和虚继承的内存布局
  4. 《sql必知必会》读书笔记
  5. [译] 制定良好的路线图:产品负责人的六个实施步骤
  6. Java 基础 之 关系运算符
  7. 信息系统定级与备案工作介绍
  8. Cucumber入门之_World
  9. 在 Android Studio 2.2 中愉快地使用 C/C++
  10. MYSQL 分析表、检查表和优化表