作为一个新的蜜蜂,我再次无法理解inflate()的一些基础知识。
这是我的xml文件 -
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity"
android:id="@+id/linearlayout"
android:orientation="vertical">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/hello_world"
android:id="@+id/textview" />
</LinearLayout>
下面是一些基本代码 -
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
LinearLayout ly = (LinearLayout)findViewById(R.id.linearlayout);
Log.i("System.out ","linear layout = " + ly);
View view=getLayoutInflater().inflate(R.layout.activity_main,null);
LinearLayout ly1 = (LinearLayout)findViewById(R.id.linearlayout);
Log.i("System.out ","linear layout = " + view);
Log.i("System.out ","linear layout = " + ly1);
}
和输出:
05-10 14:30:33.446: I/System.out(26806): linear layout = android.widget.LinearLayout@41e28848
05-10 14:30:33.446: I/System.out(26806): linear layout = android.widget.LinearLayout@41e29740
05-10 14:30:33.446: I/System.out(26806): linear layout = android.widget.LinearLayout@41e28848
我从输出的第1行和第3行了解到,一旦我们调用setContentView()
它就会膨胀,因此在调用此方法后,视图对象将在内存中。因此,在调用findViewById()
时,它返回linearlayout的同一对象查看代码块中的两个时间。 (ly isequalto ly1)
但是,为什么第二行输出中的LinearLayout对象的地址不同,
linear layout = android.widget.LinearLayout@41e29740
?
负责此事的代码是 -
View view=getLayoutInflater().inflate(R.layout.activity_main,null);
我认为这将返回根视图,在本例中为LinearLayout。
R.layout.activity_main
已经膨胀且布局没有变化(既不添加或删除任何View / ViewGroup),那么为什么对象的地址(view&amp; ly1)不匹配?我试过了 -
View view=getLayoutInflater().inflate(R.layout.activity_main,null);
setContentView(view);
LinearLayout ly1 = (LinearLayout)findViewById(R.id.linearlayout);
Log.i("System.out ","linear layout = " + view);
Log.i("System.out ","linear layout = " + ly1);
得到了这个 -
I/System.out(2603): linear layout = android.widget.LinearLayout@41e09e10
I/System.out(2603): linear layout = android.widget.LinearLayout@41e09e10
为什么ly1和view对象在这种情况下代表相同的地址?
答案 0 :(得分:3)
inflate()
将始终返回一个新的View
对象。 ly
和ly1
是同一个对象。为什么你的期望不同?
来自inflate doc
从指定的xml资源中扩充新的视图层次结构。
答案 1 :(得分:2)
这是我测试的 -
View view=getLayoutInflater().inflate(R.layout.activity_main,null);
Log.i("System.out ","view = " + view + "id = "+ view.getId());
setContentView(view);
ly = (LinearLayout)findViewById(R.id.linearlayout);
Log.i("System.out ","linear layout = " + ly + "id="+ly.getId());
View view1=getLayoutInflater().inflate(R.layout.activity_main,null);
Log.i("System.out ","view1 = " + view1 + "id = "+ view1.getId());
setContentView(view1);
ly = (LinearLayout)findViewById(R.id.linearlayout);
Log.i("System.out ","linear layout = " + ly + "id="+ly.getId());
在这两种情况下,ly对象都有不同的地址 -
05-10 19:00:36.486: I/System.out(27233): view = android.widget.LinearLayout@41e0ef70id = 2131230720
05-10 19:00:36.731: I/System.out(27233): linear layout = android.widget.LinearLayout@41e0ef70id=2131230720
和
05-10 19:00:36.731: I/System.out(27233): view1 = android.widget.LinearLayout@41e2a5d0id = 2131230720
05-10 19:00:36.736: I/System.out(27233): linear layout = android.widget.LinearLayout@41e2a5d0id=2131230720
因此,上述输出将推断以下结论: -
[1。] inflate()方法将始终返回表示xml层次结构的新根视图对象
[2。]在调用setContentView(view)时,'view'将与activity相关联。
所以,现在基于这些关系,让我们在这个帖子中理解问题的输出。
在调用时 - setContentView(R.layout.activity_main),
android系统会做通货膨胀。这意味着它将为xml中的所有元素创建视图对象。然后这些视图显示在屏幕上。因此,此时内存中的视图对象是 LinearLayout @ 41e28848 。因为它代表了根视图(线性布局),因此在调用 - 时LinearLayout ly =(LinearLayout)findViewById(R.id.linearlayout)
ly也会指向同一视图 LinearLayout @ 41e28848 ,这是在调用setContentView()时创建的。所以, ly = LinearLayout @ 41e28848 。
这证明了第一条输出线。
转到查看视图= getLayoutInflater()。inflate(R.layout.activity_main,null), 这将再次创建一个具有不同地址位置的新视图( LinearLayout @ 41e29740 )。这是xml的手动膨胀。但是这个视图对象与当前活动没有关联,因为我们没有调用setContentView(view)。这里 view = LinearLayout @ 41e29740
下一行 - LinearLayout ly1 =(LinearLayout)findViewById(R.id.linearlayout), 再次获取当前活动的活动视图。这是( LinearLayout @ 41e28848 ),它也是根视图。这实际上是在 setContentView()方法中创建的。因此, ly1 = LinearLayout @ 41e28848 。
并且,接下来的两个印刷语句只打印它们所代表的对象,即view和ly1。
感谢。
答案 2 :(得分:1)
您的测试程序似乎无效。因为您没有正确比较对象。也许您的ly1
应该按如下方式检索:
LinearLayout ly1 = (LinearLayout)view.findViewById(R.id.linearlayout);
我相信它应该返回与view
相同的日志输出。
无论如何,给视图充气会返回一个新对象,并且它不可能等于 setContentView 下定义的视图。
答案 3 :(得分:1)
View inflate(int resource, ViewGroup root)
将返回膨胀层次结构的根视图。如果提供了root,则这是根视图;否则它是膨胀的XML文件的根。
答案 4 :(得分:0)
我认为第二行是它返回查看内存方向,而不是它自己的布局。
他们是不同的东西。
我认为你是在误解事物。有一个Hierarchy,遵循这个一般方案:“View - &gt; ViewGroup - &gt; Layout”。
有一件事是引用View(它是Activity的父级),它包含ViewGroup - &gt; LayoutView,其他的东西是指LayoutView,它是View的子 - &gt; ViewGroup中。
所以,它们是不同的东西,存储分开,以为View会指向LayoutView。
这是对第2行的解释。
第1行和第3行显示相同的方向,因为它们被定义为同一个对象。
答案 5 :(得分:0)
因为你有setContentView(R.layout.activity_main);并在同一视图层次结构中引用(R.id.linearlayout)并将ly1初始化为相同的LinearLayout。感谢@laalto澄清
View view=getLayoutInflater().inflate(R.layout.activity_main,null);
public View inflate(int资源,ViewGroup根目录)
从指定的xml资源中膨胀新的视图层次结构。如果出现错误,则抛出InflateException。
参数
resource ID for an XML layout resource to load (e.g., R.layout.main_page)
root Optional view to be the parent of the generated hierarchy.
返回
膨胀层次结构的根视图。如果提供了root,则这是根视图;否则它是膨胀的XML文件的根。
所以getLayoutInflater()。inflate(R.layout.activity_main,null);返回一个新的视图对象。