LayoutInflater.inflate的用法总结

2023-10-20 02:58

本文主要是介绍LayoutInflater.inflate的用法总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

LayoutInflater.inflate的用法总结

1、inflate是Android开发中经常使用到的将布局作为一个view而引进的一个方法。我们知道inflate具有两个可以使用重载方法,他们的方法签名分别是:

inflate(int resource, ViewGroup root)
inflate(int resource, ViewGroup root, boolean attachToRoot)

第一个参数指向的是你想要引进的布局资源ID。第二个参数表示该布局的大小限制在root这个Viewgroup中。第三个参数则表示是否将root作为该布局的Viewgroup。true表示该布局是附着在root中的,false表示该布局不附着在root中。

2、在Android开发当中,我们经常使用如下的方法引进一个布局:

inflate(resource, null);

虽然这样做在很多情况下都没什么错误,但是还是有一些情况,如果将null作为第二个参数传递过去,会导致一些意想不到的情况发生。我们通过一个实际的例子来说明。

适配器Adapter是最常见的使用inflate的例子。那么我们看看下面的代码,先预估一下它会产生什么样的效果。

item_row.xml:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="100dp"android:gravity="center_vertical"android:orientation="horizontal">
<TextViewandroid:id="@+id/text1"android:layout_width="wrap_content"android:layout_height="wrap_content"android:paddingRight="15dp"android:text="Text1" />
</LinearLayout>

main.xml:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"><ListViewandroid:id="@+id/listview"android:layout_width="match_parent"android:layout_height="wrap_content" /></RelativeLayout>

MainActivity.java:

package com.example.runningh.myapplication;import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ListView;public class MainActivity extends AppCompatActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);ListView listview = (ListView) findViewById(R.id.listview);MyAdapter adapter = new MyAdapter();listview.setAdapter(adapter);}class MyAdapter extends BaseAdapter {@Overridepublic int getCount() {return 10;}@Overridepublic Object getItem(int position) {return null;}@Overridepublic long getItemId(int position) {return 0;}@Overridepublic View getView(int position, View convertView, ViewGroup parent) {if (convertView == null) {convertView = MainActivity.this.getLayoutInflater().inflate(R.layout.item_row, null);}return convertView;}}
}

如果你将null作为第二个参数传递过去,得到的效果就是下面这样子的:

这里写图片描述
看一下好像没有什么不对啊,但是仔细地看一下你就会发现我们在item_row.xml中设定的布局高度明明是100dp啊,为什么现在给我们的第一感觉这个100dp被wrap_content代替了呢?好,那我们将参数修改一下看看100dp的效果会不会出现。将MainActivity.java中getView方法作如下修改:

convertView = MainActivity.this.getLayoutInflater().inflate(R.layout.item_row, parent, false);

这里写图片描述

经过参数的修改后,我们终于看到了100dp的效果了。下面这张图和上面那张图明显不一样吧。到底是什么原因会造成这样的结果呢?

3、在我们将null作为第二个参数时,即表明inflate中的第一个参数传递进来的布局没有可以参考的parent viewGroup,那么这就相当于告诉系统说我不知道该布局的parent viewGroup是谁。但是我们知道该布局中的根元素的宽度和高度(LayoutParams)是根据该布局所处的parent viewGroup来决定的。所以当我们将null作为parent viewGroup时,那么系统就会为我们默认生成一个LayoutParams,通过generateDefaultLayoutParams 来生成。我们去看一下generateDefaultLayoutParams的实现:

protected LayoutParams generateDefaultLayoutParams() {return new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
}

看到这里我们就明白了为什么上面第一种情况的效果是怎么出现的。就是因为我们在inflate中将null作为parent viewGroup传递过去,而系统找不到相应的parent viewGroup时,便使用generateDefaultLayoutParams对布局中的根元素的宽度和高度都设置成了wrap_content。

4、通过上述实验,我们总结一下LayoutInflate.inflate的使用方法。

  • 在使用inflate的时候,如果方法中有可以viewGroup,我们尽量去使用inflate(resource, parent, false)或者inflate(resource, parent, true)去替换inflate(resource, null)。例如在Fragment的onCreateView或者在Adapter的getView方法中都可以这样使用。
  • 如果方法中没有viewGroup时,有时候我们会将当前Activity所处的viewGroup作为参数传递过去,这要根据实际的功能来决定。
  • 还有一种情况是当你创建一个AlertDialog时,我们是不必将任何viewGroup传递过去的,这个时候你可以使用inflate(resource, null)是完全没问题的。因为AlertDialog会重写任何的LayoutParams为match_parent,这个时候的viewGroup的意义就没有那么明显了。通过查看源码AlertController的setupContent方法可有看到contentPanel.addView的确是将content的LayoutParams设置成了LinearLayout.LayoutParams(MATCH_PARENT, MATCH_PARENT))

这篇关于LayoutInflater.inflate的用法总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/244138

相关文章

关于C++中的虚拟继承的一些总结(虚拟继承,覆盖,派生,隐藏)

1.为什么要引入虚拟继承 虚拟继承是多重继承中特有的概念。虚拟基类是为解决多重继承而出现的。如:类D继承自类B1、B2,而类B1、B2都继承自类A,因此在类D中两次出现类A中的变量和函数。为了节省内存空间,可以将B1、B2对A的继承定义为虚拟继承,而A就成了虚拟基类。实现的代码如下: class A class B1:public virtual A; class B2:pu

#error用法

/* *检查编译此源文件的编译器是不是C++编译器 *如果使用的是C语言编译器则执行#error命令 *如果使用的是 C++ 编译器则跳过#error命令 */ #ifndef __cplusplus #error 亲,您当前使用的不是C++编译器噢! #endif #include <stdio.h> int main() {

十五.各设计模式总结与对比

1.各设计模式总结与对比 1.1.课程目标 1、 简要分析GoF 23种设计模式和设计原则,做整体认知。 2、 剖析Spirng的编程思想,启发思维,为之后深入学习Spring做铺垫。 3、 了解各设计模式之间的关联,解决设计模式混淆的问题。 1.2.内容定位 1、 掌握设计模式的"道" ,而不只是"术" 2、 道可道非常道,滴水石穿非一日之功,做好长期修炼的准备。 3、 不要为了

人工智能机器学习算法总结神经网络算法(前向及反向传播)

1.定义,意义和优缺点 定义: 神经网络算法是一种模仿人类大脑神经元之间连接方式的机器学习算法。通过多层神经元的组合和激活函数的非线性转换,神经网络能够学习数据的特征和模式,实现对复杂数据的建模和预测。(我们可以借助人类的神经元模型来更好的帮助我们理解该算法的本质,不过这里需要说明的是,虽然名字是神经网络,并且结构等等也是借鉴了神经网络,但其原型以及算法本质上还和生物层面的神经网络运行原理存在

Java注解详细总结

什么是注解?         Java注解是代码中的特殊标记,比如@Override、@Test等,作用是:让其他程序根据注解信息决定怎么执行该程序。         注解不光可以用在方法上,还可以用在类上、变量上、构造器上等位置。 自定义注解  现在我们自定义一个MyTest注解 public @interface MyTest{String aaa();boolean bbb()

SQL Server中,isnull()函数以及null的用法

SQL Serve中的isnull()函数:          isnull(value1,value2)         1、value1与value2的数据类型必须一致。         2、如果value1的值不为null,结果返回value1。         3、如果value1为null,结果返回vaule2的值。vaule2是你设定的值。        如

tensorboard-----summary用法总结

Tensorflow学习笔记——Summary用法         最近在研究tensorflow自带的例程speech_command,顺便学习tensorflow的一些基本用法。 其中tensorboard 作为一款可视化神器,可以说是学习tensorflow时模型训练以及参数可视化的法宝。 而在训练过程中,主要用到了tf.summary()的各类方法,能够保存训练过程以及参数分布图并在

vscode-创建vue3项目-修改暗黑主题-常见错误-element插件标签-用法涉及问题

文章目录 1.vscode创建运行编译vue3项目2.添加项目资源3.添加element-plus元素4.修改为暗黑主题4.1.在main.js主文件中引入暗黑样式4.2.添加自定义样式文件4.3.html页面html标签添加样式 5.常见错误5.1.未使用变量5.2.关闭typescript检查5.3.调试器支持5.4.允许未到达代码和未定义代码 6.element常用标签6.1.下拉列表

七种排序方式总结

/*2018.01.23*A:YUAN*T:其中排序算法:冒泡排序,简单排序,直接插入排序,希尔排序,堆排序,归并排序,快速排序*/#include <stdio.h>#include <math.h>#include <malloc.h>#define MAXSIZE 10000#define FALSE 0#define TRUE 1typedef struct {i

YTKKeyValueStore用法

iOS端的尝试 后来我从后台转做iOS端的开发,我就尝试了在iOS端直接使用Key-Value式的存储。经过在粉笔网、猿题库、小猿搜题三个客户端中的尝试后,我发现Key-Value式的存储不但完全能够满足大多数移动端开发的需求,而且非常适合移动端采用。主要原因是:移动端存储的数据量不会很大: 如果是单机的应用(例如效率工具Clear),用户自己一个人创建的数据最多也就上万条。 如果