Android Inflater

在 实际开发中LayoutInflater这个类还是非常有用的,它的作用类似于findViewById()。不同点是LayoutInflater是用 来找res/layout/下的xml布局文件,并且实例化;而findViewById()是找xml布局文件下的具体widget控件(如 Button、TextView等)。 具体作用: 1、对于一个没有被载入或者想要动态载入的界面,都需要使用LayoutInflater.inflate()来载入;

2、对于一个已经载入的界面,就可以使用Activiyt.findViewById()方法来获得其中的界面元素。

LayoutInflater 是一个抽象类,在文档中如下声明:

public abstract class LayoutInflater extends Object

获得 LayoutInflater 实例的三种方式

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()方法,看一下该源代码:

 

 public PhoneWindow(Context context) {  
        super(context);  
        mLayoutInflater = LayoutInflater.from(context);  
}

 

可以看出它其实是调用 LayoutInflater.from(context)。

LayoutInflater.from(context):

复制代码
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 对象,如下

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)

示意代码:

 

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);

 

对于上面代码,指定了第二个参数 ViewGroup root,当然你也可以设置为 null 值。

注意:

  • ·inflate 方法与 findViewById 方法不同;
  • ·inflater 是用来找 res/layout 下的 xml 布局文件,并且实例化;
  • ·findViewById() 是找具体 xml 布局文件中的具体 widget 控件(如:Button、TextView 等)。

##############

http://blog.sina.com.cn/s/blog_48a45b950100u8ax.html

Android 学习 碎片的生命周期

【reference】

《第一行代码-第二版》 GuoLin

【Prior knowledge/先备知识】

BaiDu or Google it…= =

 

【碎片的状态和回调】

1.每个活动在其生命周期内可能会有四种状态.

-运行状态

-暂停状态

-停止状态

-销毁状态

类似的,碎片也可能会经历这几种状态,不过会有一些细小的地方的部分区别.

2.运行状态

当一个碎片是可见的,并且他所关联的活动正处于运行状态时,该碎片也处于运行状态.

3.暂停状态

当一个活动进入暂停状态时(由于另一个未占满屏幕的活动被添加到了栈顶),与他相关联的可见碎片就会进入到暂停状态.

4.停止状态

当一个活动进入停止状态时,与他相关联的碎片就会进入到停止状态,或者通过调用FragmentTrasaction的remove(),replace()方法把碎片从活动移除,但如果在事务提交之前调用addToBackStack()方法,这时的碎片也会进入到停止状态。总的来说,进入停止状态的碎片对用户来说是完全不可见的,有可能会被系统回收.

5.销毁状态

碎片总是依附于活动而存在的,因此当活动被销毁时,与他相关联的碎片也就会进入到销毁态.

或者通过调用FragmentTransaction 的remove()、replace()方法将碎片从活动中移除,

在事务提交之前并没有调用addToBackStack()方法,这时的碎片也会进入到销毁状态。

 

Fragment提供的附加回调方法:

①onAttach()
当碎片和活动建立关联的时候调用。


②onCreateView()
为碎片创建视图(加载布局)时调用。


③ onActivityCreated()
确保与碎片相关联的活动一定已经创建完毕的时候调用。


④onDestroyView()
当与碎片关联的视图被移除的时候调用。

⑤onDetach()
当碎片和活动解除关联的时候调用。

 

【碎片的完整生命周期】

 

 

附上github源码(这一篇的project是FragmentTest):  clone这个项目

 

Android 学习 抽象类

【Tip】

抽象类只是一个面向对象的概念,所以可以用在诸如.net,jave EE,PY…..

【在Android中概念】

   抽象类

我们都知道在面向对象的领域一切都是对象,同时所有的对象都是通过类来描述的,但是并不是所有的类都是来描述对象的。如果一个类没有足够的信息来描述一个具体的对象,而需要其他具体的类来支撑它,那么这样的类我们称它为抽象类。比如new Animal(),我们都知道这个是产生一个动物Animal对象,但是这个Animal具体长成什么样子我们并不知道,它没有一个具体动物的概念,所以他就是一个抽象类,需要一个具体的动物,如狗、猫来对它进行特定的描述,我们才知道它长成啥样。

Continue reading “Android 学习 抽象类”