LayoutInflater中inflate方法参数区别

本文主要记录inflate的一些方法的区别,闲话少说,直奔主题,目前一般得到LayoutInflate的方法有以下几种:
1.getSystemService(Context.LAYOUT_INFLATER_SERVICE)
2.LayoutInflater.from(mContext).inflater()
3.View.inflater()
本质就是利用的systemService


LayoutInflater中inflate方法参数区别_第1张图片
image.png

image.png

ok,下面重点来说说inflater方法,一般inflater()方法接收2个或者三个参数


image.png

区别就是第三个参数
,其中两个参数的inflater()方法调用的和View.inflater()调用的一样
image.png
LayoutInflater中inflate方法参数区别_第2张图片
image.png

就是说以上三种方法最终都到了这里然后继续调用infalter。。。
然后就是吧啦吧啦的解析resourse的过程,贴重点


LayoutInflater中inflate方法参数区别_第3张图片
image.png

如果root为null,直接result = temp,返回当前inflater的UI;
如果root不为null,有两种情况,分别是attachToRoot为false和true,
false:temp.setLayoutParams(params)
true:root.addView(temp,params),就是直接把inflater的view给add到root里面去。
可能我表达不清楚,下面结合例子来分析几种不同情况:
inflater的UI布局


LayoutInflater中inflate方法参数区别_第4张图片
image.png

root为null:

LayoutInflater中inflate方法参数区别_第5张图片
image.png

不论attachToRoot为true还是为false,显示效果都是一样的。当root为null表示我不需要将第一个参数所指定的布局添加到任何容器中,同时也表示没有任何容器来来协助第一个参数所指定布局的根节点生成布局参数。
当第二个参数为null,第三个参数为false时(即使为true显示效果也是一样的,这里以false为例),由于在inflate方法中没有将view添加到某一个容器中,所以我需要手动添加,另外由于view并没有处于某一个容器中,所以它的根节点的宽高属性会失效,显示效果如下:

LayoutInflater中inflate方法参数区别_第6张图片
image.png

root不为null,attachToRoot为true:

LayoutInflater中inflate方法参数区别_第7张图片
image.png

按照之前的分析,root会调用addview,在这里若我们继续调用addview,作死秀


image.png

注释掉addview


LayoutInflater中inflate方法参数区别_第8张图片
image.png

可以看到我们resource指定的布局添加到root中,添加的过程中resource所指定的的布局的根节点的各个属性都是有效的。

root不为null,attachToRoot为false:

按照之前的分析,如果root不为null,而attachToRoot为false的话,表示不将第一个参数所指定的View添加到root中,那么这个时候有的小伙伴可能就有疑问了,既然不添加到root中,那我还写这么多干嘛?我第二个参数直接给null不就可以了?其实不然,这里涉及到另外一个问题:我们在开发的过程中给控件所指定的layout_width和layout_height到底是什么意思?该属性的表示一个控件在容器中的大小,就是说这个控件必须在容器中,这个属性才有意义,否则无意义。这就意味着如果我直接将view加载进来而不给它指定一个父布局,则inflate布局的根节点的layout_width和layout_height属性将会失效(因为这个时候view将不处于任何容器中,那么它的根节点的宽高自然会失效)。如果我想让view的根节点有效,又不想让其处于某一个容器中,那我就可以设置root不为null,而attachToRoot为false。这样,指定root的目的也就很明确了,即root会协助view的根节点生成布局参数,只有这一个作用,并且我们的属性是没有带入的,是addview到root后,root去测量子view的属性,然后给temp设置的,所以这种情况应该和为true时一样

最后:

inflate方法我们已经说完了,小伙伴们可能有另外一个疑问,那为什么Activity布局的根节点的宽高属性会生效?其实原因很简单,大部分情况下我们一个Activity页面由两部分组成(Android的版本号和应用主题会影响到Activity页面组成,这里以常见页面为例),我们的页面中有一个顶级View叫做DecorView,DecorView中包含一个竖直方向的LinearLayout,LinearLayout由两部分组成,第一部分是标题栏,第二部分是内容栏,内容栏是一个id为content的FrameLayout,我们在Activity中调用setContentView就是将View添加到这个FrameLayout中,所以给大家一种错觉仿佛Activity的根布局很特殊,其实不然。ok,算是自己跟着源码走了遍,然后自己写了遍各种情况熟悉了下,希望对不明白的小伙伴能有所帮助。

你可能感兴趣的:(LayoutInflater中inflate方法参数区别)