前言
LayoutInflater用法
LayoutInflater是一個用來實例化XML布局為View對象
應用程序運行時會預先加載資源中的布局文件,如果layout布局中的資源比較多,會影響性能,所以可以選擇LayoutInflater方式用的時候加載,這樣減輕了應用程序運行時很多負擔
public View inflate (int resource, ViewGroup root)
從指定的XML資源中填充一個新的視圖
參數resource:將要加載的XML布局id,例如R.layout.list_item
參數root:父視圖,可選項,一般為Null
public static LayoutInflater from (Context context)
從給定的context獲取LayoutInflater
可以通過如下三種方式獲取LayoutInflater
第一種:
LayoutInflater inflater = (LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
View myView = inflater.inflate(R.layout.main, null);
第二種:與第一種方法相同,即from方法封裝了getSystemService(...)等
LayoutInflater inflater = LayoutInflater.from(context);
View myView = inflater.inflate(R.layout.main, null);
第三種:getLayoutInflater()方法是Activity的方法,歸根到底還是第一種方式
LayoutInflater inflater = getLayoutInflater();
View myView = inflater.inflate(R.layout.main, null);
所以我們在加載布局的時候可以用setContentView直接設置,然后通過findViewById()來獲取控件的id
例如:我們可以用4種方式加載main.xml布局文件,不過LayoutInflater一般多用於ListView等地方,
如BaseAdapter的getView()方法會用到:http://www.cnblogs.com/loulijun/archive/2011/12/28/2305016.html
package com.loulijun.demo6;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
public class Demo6Activity extends Activity {
private Button btn;
private TextView tv;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//----------第一種方式----------
// setContentView(R.layout.main);
// btn = (Button)findViewById(R.id.btn);
// tv = (TextView)findViewById(R.id.tv);
//----------第二種方式----------
// LayoutInflater inflater = getLayoutInflater();
//----------第三種方式----------
// LayoutInflater inflater = LayoutInflater.from(this);
//----------第四種方式----------
LayoutInflater inflater = (LayoutInflater)this.getSystemService(
Context.LAYOUT_INFLATER_SERVICE);
View view = inflater.inflate(R.layout.main, null);
setContentView(view);
btn = (Button)view.findViewById(R.id.btn);
tv = (TextView)view.findViewById(R.id.tv);
btn.setOnClickListener(new Button.OnClickListener()
{
@Override
public void onClick(View v) {
//...
}
});
}
使用setContentView(R.layout.main)設置布局后布局會立刻顯示,而使用inflate()方法加載的布局文件得到的是一個View視圖對象,在需要的時候再setContentView(view)即可。在Activity中一般只需要setContentView即可,如果是非Acitivity,則需要使用LayoutInflater來動態加載控制控件
MenuInflater用法
MenuInflater是用來加載menu布局文件的,與上面的類似
與LayoutInflater類似,應用程序運行時會預先加載資源中的布局文件,如果Menu布局中的資源比較多,會影響性能,所以可以選擇MenuInflater方式用的時候加載,這樣減輕了應用程序運行時很多負擔
與LayoutInflater相比,MenuInflater用法要簡單很多,它只有Activity.getMenuInflater()方法。
例如:
1、在res目錄下創建menu文件夾,在里面創建mymenu.xml
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android" >
<item
android:title="打電話"
android:icon="@android:drawable/ic_menu_call"
android:id="@+id/action_call"/>
<item
android:title="照相"
android:icon="@android:drawable/ic_menu_camera"
android:id="@+id/action_camera"/>
<item
android:title="添加"
android:icon="@android:drawable/ic_menu_add"
android:id="@+id/action_add"/>
<item
android:title="刪除"
android:icon="@android:drawable/ic_menu_delete"
android:id="@+id/action_delete"/>
</menu>
2、重寫onCreateOptionsMenu方法和onOptionsItemSelected方法之后,在onCreateOptionsMenu中使用MenuInflater加載布局
package com.loulijun.demo6;
import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.widget.Button;
import android.widget.TextView;
public class Demo6Activity extends Activity {
private Button btn;
private TextView tv;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
MenuInflater inflater = getMenuInflater();
//填充菜單
inflater.inflate(R.menu.mymenu, menu);
return super.onCreateOptionsMenu(menu);
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch(item.getItemId())
{
case R.id.action_add:
//操作
break;
case R.id.action_call:
break;
case R.id.action_camera:
break;
case R.id.action_delete:
break;
}
return super.onOptionsItemSelected(item);
}
}
運行結果: