使ViewStub 来提高UI的加载的性能

时间:2022-02-16 18:10:53

首先看下API中的ViewStub

使ViewStub  来提高UI的加载的性能

根据的文档的说明,ViewStub是一种默认不可见的试图,它没有大小,所以不能被改变,也不能通过某些把viewstub添加到布局当中来,

不过我们可以使用inflate()来吧ViewStub中的试图增加进行,这样可以实现动态的添加试图,不必要每次在onCreate()的时候就加载布局,可以提高我们的性能。

Demo中的使用方法:

1:新建布局文件 设置<ViewStub>节点

2: 在Activity中进行按钮点击  viewStub = (ViewStub) findViewById(R.id.mystub);

3: View view = viewStub.inflate();  把ViewStub中的View增添进来

下面Demo源代码:

主Activity类:

  1. package com.jiangqq.viewstubdemo;
  2. import android.app.Activity;
  3. import android.os.Bundle;
  4. import android.view.View;
  5. import android.view.View.OnClickListener;
  6. import android.view.ViewStub;
  7. import android.widget.Button;
  8. public class ViewStubActivity extends Activity {
  9. private Button btn;
  10. private ViewStub viewStub;
  11. @Override
  12. public void onCreate(Bundle savedInstanceState) {
  13. super.onCreate(savedInstanceState);
  14. setContentView(R.layout.main);
  15. btn = (Button) findViewById(R.id.btn);
  16. btn.setOnClickListener(new OnClickListener() {
  17. @Override
  18. public void onClick(View v) {
  19. viewStub = (ViewStub) findViewById(R.id.mystub);
  20. View view = viewStub.inflate();
  21. v.setEnabled(false);
  22. }
  23. });
  24. }
  25. }

布局文件:

main.xml:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent"
  5. android:orientation="vertical" >
  6. <Button
  7. android:id="@+id/btn"
  8. android:layout_width="wrap_content"
  9. android:layout_height="wrap_content"
  10. android:text="点击确定" />
  11. <ViewStub
  12. android:id="@+id/mystub"
  13. android:layout_width="wrap_content"
  14. android:layout_height="wrap_content"
  15. android:layout="@layout/demo_viewstub" >
  16. </ViewStub>
  17. </LinearLayout>

demo_viewstub.xml:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:id="@+id/layout"
  4. android:layout_width="match_parent"
  5. android:layout_height="match_parent"
  6. android:orientation="vertical" >
  7. <TextView
  8. android:id="@+id/tv"
  9. android:layout_width="wrap_content"
  10. android:layout_height="wrap_content"
  11. android:text="ViewStubDemo_Byjiangqq" />
  12. </LinearLayout>

效果截图:

使ViewStub  来提高UI的加载的性能