LayoutInflater填充布局inflate()不同参数的
1.三个方法参数
1.1第三个参数
View view = inflater.inflate(R.layout.activity_ll, parent, false);
先写一个父容器的布局,和一个需要添加到父容器中的子view的布局。
父容器布局
子view布局
图二OK,我们现在需要把子view添加到父容器中。
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main2);
LinearLayout parent = (LinearLayout) findViewById(R.id.ll_main2);
LayoutInflater inflater = LayoutInflater.from(this);
View view = inflater.inflate(R.layout.activity_ll, parent, false);
parent.addView(view);
}
这种填充方式使我们使用做多的一种方式,先看看效果。
图三添加子view的时候的布局方式采用父容器xml文件中的方式,是线性布局。
我们现在把第三个参数从false改为true,再次运行,这样就会直接报错。
提示,我们要添加的这个view已经有了父容器,所以parent.addView(view);导致重复添加。
从这两个例子的对比中我们看出了这三个参数分别代表的含义。
图五
参数1是要被添加进来的子view的布局文件,参数2是父容器,参数3是是否要添加到父容器中。
如果第三个参数为true,我们就不需要再次手动addView(view),因为true就代表了添加到父容器中。
注解掉addView后就能正常显示达到图三的效果。
1.2第二个参数
由上面我们知道第二个参数是用来添加子view的父容器,但是当父容器为null的时候又会怎么样呢?
图七我们可以看到添加是失败的,我们分析一下原因,true代表会自动添加到父容器中,但是我们这里父容器为null,又怎么能添加到父容器成功呢?,所以这里的true也会是false的效果,我们要自己手动添加。 图八
Ok,添加成功,但是有没有感觉和前面的效果差别很大,我们来对比一下:
图九这样就一目了然了,我们再来看看xml文件中的配置。
图十可以得出结论当父容器为null的时候子view的跟布局的参数失效,宽度会match_parent,高度是它的孩子的高度。这里先引出一个问题:给控件指定的layout_width和layout_height属性的含义,它们表示一个控件在一个容器中的大小,必须要在一个容器中这个属性才会有意义。上图我们的父容器为null,表示我们填充进来的子View是不在容器中的,那它的跟节点的宽度和高度就会失效,所以会出现图九左侧的效果。只用当父容器不为null是被添加的子View的跟节点的参数才会有效。
大家一定经常会用到RecyclerView,其中的Adapter中就要经常用到这个方法:
在图十一中我们想让item的根节点有效,又不想让其处于某个容器中,就设置parent不为null,第三个参数设置为false。因为一旦View有了父布局,就不能添加到RecyclerView中。
2.两个参数
inflater.inflate(R.layout.activity_ll,parent);
图十二
2.1 parent不为null
两个参数的和三个参数的就很类似了,图十二我们可以看到我们并不用设置布尔值就可以自动添加成功,这里是自动添加吗?如果我们手动添加会怎么样呢?
图十三果然是自动添加,我们如果再次手动添加也会爆出重复添加的错。
2.2 parent为null
图十四可以看出当parent为null时,子view的根节点也会失效。
总结
- inflate()方法两个参数会默认添加到父容器中,而三个参数如果为true则表示自动添加到父容器中,自动添加后就不能手动添加了,如果手动添加会报错。
- 如果父容器为null怎添加的子view的根节点的属性就会失效。
参考文章:http://blog.csdn.net/u012702547/article/details/52628453