在實際開發中LayoutInflater這個類還是非常有用的,它的作用類似於findViewById()。不同點是LayoutInflater是用來找res/layout/下的xml佈局檔,並且實例化;而findViewById()是找xml佈局檔下的具體widget控制項(如 Button、TextView等)。
具體作用:
1、對於一個沒有被載入或者想要動態載入的介面,都需要使用LayoutInflater.inflate()來載入;

 

2、對於一個已經載入的介面,就可以使用Activiyt.findViewById()方法來獲得其中的介面元素。

 

LayoutInflater 是一個抽象類,在文檔中如下聲明:




JAVA代碼 收藏代碼
public abstract class LayoutInflater extends Object

 

獲得 LayoutInflater 實例的三種方式:




JAVA代碼 收藏代碼
1. LayoutInflater inflater = getLayoutInflater(); //調用Activity的getLayoutInflater()

 

2. LayoutInflater localinflater = (LayoutInflater)coNtext.getSystemService

 

(CoNtext.LAYOUT_INFLATER_SERVICE);

 

3. LayoutInflater inflater = LayoutInflater.from(coNtext);




其實,這三種方式本質是相同的,從源碼中可以看出:

 

getLayoutInflater():

 

Activity 的 getLayoutInflater() 方法是調用 PhoneWindow 的getLayoutInflater()方法,看一下該源代碼:




JAVA代碼 收藏代碼
public PhoneWindow(CoNtext coNtext)
{
super(coNtext);
mLayoutInflater = LayoutInflater.from(coNtext);
}

 

可以看出它其實是調用 LayoutInflater.from(coNtext)。

 

LayoutInflater.from(coNtext):




JAVA代碼 收藏代碼
public static LayoutInflater from(CoNtext coNtext)
{
LayoutInflater LayoutInflater =
(LayoutInflater) coNtext.getSystemService(CoNtext.LAYOUT_INFLATER_SERVICE);
if (LayoutInflater == null)
{
throw new AssertionError("LayoutInflater not found.");
}
return LayoutInflater;
}




可以看出它其實調用 coNtext.getSystemService()。




結論:所以這三種方式最終本質是都是調用的CoNtext.getSystemService()。




inflate 方法
通過 sdk 的 api 文檔,可以知道該方法有以下幾種過載形式,傳回值均是 View 對象,如下:




JAVA代碼 收藏代碼
public View inflate (int resource, ViewGroup root)
public View inflate (XmlPullParser parser, ViewGroup root)

 

public View inflate (XmlPullParser parser, ViewGroup root, boolean attachToRoot)

 

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

 

1:

 

public View inflate (int resource, ViewGroup root)
reSource:View的layout的ID
root:如果為null,則將此View作為根,此時既可以應用此View中的其他控制項了。
如果!null, 則將默認的layout作為View的根。

 

2:

 

public View inflate ( XmlPullParser parser, ViewGroup root)
parser:你需要解析xml的解析介面
root:如果null,則將此View作為根,此時既可以應用此View中的其他控制項了。
如果!null, 則將默認的layout作為View的根。

 

3:

 

public View inflate ( XmlPullParser parser, ViewGroup root, boolean attachToRoot)
parser:你需要解析View的xml的解析介面
root:如果null,則將此View作為根,此時既可以應用此View中的其他控制項了。
如果!null, 則將默認的layout作為View的根。
attachToRoot:
ture:也就將此解析的xml作為View根
fase:則為默認的xml,做為根視圖View

 

4:

 

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



resource:View的layout的ID

 

root:如果null,則將此View作為根,此時既可以應用此View中的其他控制項了。

 

如果!null, 則將默認的layout作為View的根。

 

attachToRoot:

 

ture:也就將此解析的xml作為View根
fase:則為默認的xml,做為根視圖View




示意代碼:




JAVA代碼 收藏代碼
LayoutInflater inflater = (LayoutInflater)getSystemService(LAYOUT_INFLATER_SERVICE);

 

View view = inflater.inflate(R.layout.custom, (ViewGroup)findViewById(R.id.test));

 

//EditText editText = (EditText)findViewById(R.id.content);// error
EditText editText = (EditText)view.findViewById(R.id.content);

 

同時在此講講讓我去API中去理解這四個函數的原因吧!
在Activity中:
大家是否知道,在setContentView(new MySurfaceView(this))後,此Activity中聲明的View控制項,
如:TextView 為什麼引用不到layout佈局檔中的控制項ID呢!初一看能夠應用到,但是為什麼編譯就報空指針呢!原因:在setContentView(new MySurfaceView(this))後,此時的View變為了根視圖了,雖然能應用到TextView對應的ID,但是我在 MySurfaceView中根本就沒有這個對象,所以就報空指針咯!解決辦法:
View view = LayoutInflater.from(this).inflate(R.layout.passover, null);注:每解析一次都會產生不同的對象
 
 
From:CSDN
創作者介紹
創作者 shadow 的頭像
shadow

資訊園

shadow 發表在 痞客邦 留言(0) 人氣()