Button是事件源,当Click事件发生后Button把事件丢给监听器来处理。
方法一
下面的代码是最易懂,最直白的表示方法:
1 package zcy.app;
2
3 import android.app.Activity;
4 import android.os.Bundle;
5 import android.view.View;
6 import android.widget.Button;
7
8 public class MyEvent extends Activity {
9 private Button bt;
10 /** Called when the activity is first created. */
11 @Override
12 public void onCreate(Bundle savedInstanceState) {
13 super.onCreate(savedInstanceState);
14 bt=new Button(this);
15 setContentView(bt);
16 bt.setText("按我");
17 MyListener ml=new MyListener();
18 bt.setOnClickListener(ml);
19 }
20 }
21 class MyListener implements Button.OnClickListener{
22
23 @Override
24 public void onClick(View v) {
25 // TODO Auto-generated method stub
26 Button b=(Button)v;
27 b.setText("事件已触发");
28 }
29
30 }
我们自定义了一个类MyListener实现了Button.OnClickListener接口(因为重写了接口中的onClick方法),然后创建了一个MyListener实例ml,最后在按钮bt上安装ml监听器(也就是bt.setOnClickListener(ml)这句话)。
实际上从面向对象的角度上讲,接口和类没有什么本质的不同。
Interface A{//....}
Interface B extends A{//....} 接口B继承了接口A
class C imlements A{//....} 类C继承了接口A(在C++和C#中就是这么叫,从面向对象的思想上去理解我觉得这样更准确些)
两个“继承”有什么区别呢?使用extends,B不用实现A中的抽象方法,相反B中可以添加更多的抽象方法。使用implements,C就必须把A中的抽象方法全部实现。那我们C理解成继承了A有什么好处呢?在第三种方法中你会看到。
此外可能你对26行感到有点新奇,让我们来看一下View.OnClickListener中的onClick方法是如何定义的:
public abstract void onClick (View v)
Called when a view has been clicked.
Parameters
v | The view that was clicked. |
---|
方法二
1 package zcy.app;
2
3 import android.app.Activity;
4 import android.os.Bundle;
5 import android.view.View;
6 import android.widget.Button;
7
8 public class MyEvent extends Activity {
9 private Button bt;
10 /** Called when the activity is first created. */
11 @Override
12 public void onCreate(Bundle savedInstanceState) {
13 super.onCreate(savedInstanceState);
14 bt=new Button(this);
15 bt.setText("按我");
16 bt.setOnClickListener(new Button.OnClickListener(){
17
18 @Override
19 public void onClick(View v) {
20 // TODO Auto-generated method stub
21 bt.setText("事件已触发");
22 }
23
24 });
25 setContentView(bt);
26 }
27 }
在方法一中,我们可以说ml是MyListener类型的一个实例,也可以说ml是OnClickListener类型的一个实例(因为MyListener继承了OnClickListener嘛)。而在方法二中我们直接创建了一个匿名的OnClickListener实例。
方法二代码中的
Button.OnClickListener(){
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
bt.setText("事件已触发");
}
相当于方法一中的
class MyListener implements Button.OnClickListener{
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
Button b=(Button)v;
b.setText("事件已触发");
}
}
前面再加个new,就相当于方法一中ml。
方法三
1 package zcy.app;
2
3 import android.app.Activity;
4 import android.os.Bundle;
5 import android.view.View;
6 import android.view.View.OnClickListener;
7 import android.widget.Button;
8
9 public class MyEvent extends Activity implements OnClickListener {
10 private Button bt;
11 /** Called when the activity is first created. */
12 @Override
13 public void onCreate(Bundle savedInstanceState) {
14 super.onCreate(savedInstanceState);
15 bt=new Button(this);
16 setContentView(bt);
17 bt.setText("按我");
18 bt.setOnClickListener(this);
19 }
20 @Override
21 public void onClick(View v) {
22 // TODO Auto-generated method stub
23 bt.setText("事件已触发");
24 }
25 }
这个方法有点奇怪,我们已经知道setOnClickListener()中的参数应该是个OnClickListener的实例,那18行的“this"是OnClickListener的一个实例吗?是的!应为this是MyEvent的一个实例,而MyEvent又继承了OnClickListener,也就是说MyEvent是OnClickListener的一个子类,那this自然也是OnClickListener的一个实例。
本文来自博客园,作者:高性能golang,转载请注明原文链接:https://www.cnblogs.com/zhangchaoyang/articles/1796820.html