不管是桌面应用还是手机应用程序,面对最多的就是用户,经常需要处理的就是用户动作-----也就是需要为用户动作提供响应,这种用户动作提供响应的机制就是事件处理。
Android基于事件的监听处理主要介绍下面的3种形式:
①内部类形式:将事件监听器类定义成当前类的内部类。
②Activity本身作为事件监听器类:让Activity本身实现监听接口,并实现事件的处理方法。
③匿名内部类形式:使用匿名内部类创建事件监听器对象。
一、内部类形式
使用内部类可以在当前类中复该监听器类;因为监听器类是外部类的内部类,所以可以自由的访问外部类的所有界面组件
<?xml version="1.0" encoding="utf-8"?>
<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"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="lh.example.administrator.myapp1.MainActivity"
android:orientation="vertical">
<EditText
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/mainEditText" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text=""单击我""
android:id="@+id/mainButton" />
</LinearLayout>
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//获取应用中的Button按钮
Button bt = (Button)findViewById(R.id.mainButton);
//为按钮绑定事件监听器
bt.setOnClickListener(new MyClickListener());
}
//定义一个单击事件的监听器(这是一个内部类)
class MyClickListener implements View.OnClickListener
{
//实现监听器类必须实现的方法,该方法为作为事件处理器
@Override
public void onClick(View view)
{
EditText txt = (EditText)findViewById(R.id.mainEditText);
txt.setText("bt按钮被点击了");
}
}
}
从上面程序中可以看出,基于监听的事件处理模型的编程步骤如下
1、获取普通界面组件(事件源),也就是被监听的对象。
2、实现监听器类,该监听器类是一个特殊的JAVA类,必须实现一个XXXListener接口。
3、调用事件源的setXXXListener方法将事件监听器对象注册给普通组件(事件源)
事件源:就是程序中的bt按钮,应用程序中任何组件都可作为事件源。
事件监听器:就是程序中的MyClickListener类,监听器类由程序员负责实现,实现监听器类的关键就是实现处理器方法
注册监听器:只要调用serXxxListener(XxxListener)方法即可。
对于上面三件事情,事件源可以使任何界面组件,注册监听器也只要一行代码即可,因此事件编程的关键就是实现事件
监听器类。
二、Activity本身作为事件监听器类
这种形式使用Activity本身作为监听器类,可以直接在Activity类中定义事件处理方法。这种形式非常简洁但这种做法
有两个缺点:
①这种形式可能造成程序结构混乱,Activity的主要职责应该是完成界面的初始化工作,但此时还需要包含事件的处理器方法,从而引起混乱。
②如果Activity界面类需要实现监听器接口,让人感觉比较怪异。
public class MainActivity extends Activity implements OnClickListener { //明确声明要成为“”单击“”事件的监听对象
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//获取应用中的Button按钮
Button bt = (Button)findViewById(R.id.mainButton);
//直接使用Activity作为事件监听器
bt.setOnClickListener(this);
}
//实现事件处理方法
@Override
public void onClick(View view)
{
EditText txt = (EditText)findViewById(R.id.mainEditText);
txt.setText("bt按钮被点击了");
}
}
三、匿名内部类作为事件监听器类
大部分时候,事件处理器都没有什么复用价值(可复用代码通常都被抽象成了业务逻辑方法),因此大部分事件监听器只是临时使用一次,所以使用匿名内部类形式的事件监听器更合适。实际上,这种形式是目前使用最广泛的事件监听器形式。
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//获取应用中的Button按钮
Button bt = (Button)findViewById(R.id.mainButton);
//为按钮绑定事件监听器
bt.setOnClickListener(new OnClickLstener()
{
@Override
public void onClick(View view)
{
EditText txt = (EditText)findViewById(R.id.mainEditText);
txt.setText("bt按钮被点击了");
}
});
}
}