Android开发中监听器的实现有三种方法,对于初学者来说,能够很好地理解这三种方法,将能更好地增进自己对android中监听器的理解。
一、什么是监听器。
监听器是一个存在于View类下的接口,一般以On******Llistener命名,实现该接口需要复写相应的on****(View v)方法(如onClick(View v))。
二、监听器的三种实现方法
(以OnClickListener为例)
方法一:在Activity中定义一个内部类继承监听器接口(这里是OnClickListener)。常见的继承方法如下:
class MyListener implements View.OnClickListener{ @Override public void onClick(View v) { Toast.makeText(MainActivity.this,"you have clicked Button2",Toast.LENGTH_SHORT).show(); } }
或者可以用另外一种方式,即new一个该监听器(OnClickListener)的对象,这个方式与上面的直接继承有异曲同工之妙。
// 或者,这里是创建一个OnClickListener 的对象,与上面的直接复写接口有异曲同工之妙 private View.OnClickListener MyListener = new View.OnClickListener() { @Override public void onClick(View v) { Toast.makeText(MainActivity.this,"you have clicked Button2",Toast.LENGTH_SHORT).show(); } };
以上两个实现的监听器在onCreate(Bundle savedInstanceState
)方法中的调用都是一样的,即使用setOnClickListener()方法。
bt2.setOnClickListener(new MyListener());
方法二:实现匿名内部类。这种方法适合只希望对监听器进行一次性使用的情况,在该代码块运行完毕之后,该监听器也就不复存在了。
bt1.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Toast.makeText(MainActivity.this,"you have clicked Button1",Toast.LENGTH_SHORT).show(); } });
方法三:利用布局文件中的onClick属性,并在实现文件中实现该方法。注意的是这里的方法名应该和布局文件中onClick属性的方法名相同,该方法必须是public方法。
// 方法三,注意需要public方法 public void onButtonClick (View view){ Toast.makeText(MainActivity.this,"you have clicked Button3",Toast.LENGTH_SHORT).show(); } }
在布局文件中的设置
<Button android:layout_below="@id/button2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/button3" android:text="Button3" android:onClick="onButtonClick"/>
以上就是android中实现监听器的三种方法。
下面是整个项目的完整代码
布局文件:
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout 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="com.example.jeffrey.listener.MainActivity"><span style="color: #0000ff;"><</span><span style="color: #800000;">TextView </span><span style="color: #ff0000;">android:layout_width</span><span style="color: #0000ff;">="wrap_content"</span><span style="color: #ff0000;"> android:layout_height</span><span style="color: #0000ff;">="wrap_content"</span><span style="color: #ff0000;"> android:id</span><span style="color: #0000ff;">="@+id/text"</span><span style="color: #ff0000;"> android:text</span><span style="color: #0000ff;">="OnClickListener"</span> <span style="color: #0000ff;">/></span> <span style="color: #0000ff;"><</span><span style="color: #800000;">Button </span><span style="color: #ff0000;">android:layout_below</span><span style="color: #0000ff;">="@id/text"</span><span style="color: #ff0000;"> android:layout_width</span><span style="color: #0000ff;">="wrap_content"</span><span style="color: #ff0000;"> android:layout_height</span><span style="color: #0000ff;">="wrap_content"</span><span style="color: #ff0000;"> android:text</span><span style="color: #0000ff;">="Button1"</span><span style="color: #ff0000;"> android:id</span><span style="color: #0000ff;">="@+id/button1"</span><span style="color: #0000ff;">/></span> <span style="color: #0000ff;"><</span><span style="color: #800000;">Button </span><span style="color: #ff0000;">android:layout_below</span><span style="color: #0000ff;">="@id/button1"</span><span style="color: #ff0000;"> android:layout_width</span><span style="color: #0000ff;">="wrap_content"</span><span style="color: #ff0000;"> android:layout_height</span><span style="color: #0000ff;">="wrap_content"</span><span style="color: #ff0000;"> android:text</span><span style="color: #0000ff;">="Button2"</span><span style="color: #ff0000;"> android:id</span><span style="color: #0000ff;">="@+id/button2"</span><span style="color: #0000ff;">/></span> <span style="color: #0000ff;"><</span><span style="color: #800000;">Button </span><span style="color: #ff0000;">android:layout_below</span><span style="color: #0000ff;">="@id/button2"</span><span style="color: #ff0000;"> android:layout_width</span><span style="color: #0000ff;">="wrap_content"</span><span style="color: #ff0000;"> android:layout_height</span><span style="color: #0000ff;">="wrap_content"</span><span style="color: #ff0000;"> android:id</span><span style="color: #0000ff;">="@+id/button3"</span><span style="color: #ff0000;"> android:text</span><span style="color: #0000ff;">="Button3"</span><span style="color: #ff0000;"> android:onClick</span><span style="color: #0000ff;">="onButtonClick"</span><span style="color: #0000ff;">/></span>
</RelativeLayout>
实现文件:
package com.example.jeffrey.listener; import android.content.DialogInterface;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.Toast; public class MainActivity extends AppCompatActivity {bt1.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Toast.makeText(MainActivity.this,"you have clicked Button1",Toast.LENGTH_SHORT).show(); } });@Override </span><span style="color: #0000ff;">protected</span> <span style="color: #0000ff;">void</span><span style="color: #000000;"> onCreate(Bundle savedInstanceState) { </span><span style="color: #0000ff;">super</span><span style="color: #000000;">.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Button bt1 </span>= (Button)findViewById(R.id.button1);<span style="color: #008000;">//</span><span style="color: #008000;">对应方法二</span> Button bt2 = (Button)findViewById(R.id.button2);<span style="color: #008000;">//</span><span style="color: #008000;">对应方法一</span>
bt2.setOnClickListener(</span><span style="color: #0000ff;">new</span><span style="color: #000000;"> MyListener()); } </span><span style="color: #0000ff;">class</span> MyListener <span style="color: #0000ff;">implements</span><span style="color: #000000;"> View.OnClickListener{ @Override </span><span style="color: #0000ff;">public</span> <span style="color: #0000ff;">void</span><span style="color: #000000;"> onClick(View v) { Toast.makeText(MainActivity.</span><span style="color: #0000ff;">this</span>,"you have clicked Button2"<span style="color: #000000;">,Toast.LENGTH_SHORT).show(); } } </span><span style="color: #008000;">//</span><span style="color: #008000;"> 或者,这里是创建一个OnClickListener 的对象,与上面的直接复写接口有异曲同工之妙</span> <span style="color: #0000ff;">private</span> View.OnClickListener MyListener = <span style="color: #0000ff;">new</span><span style="color: #000000;"> View.OnClickListener() { @Override </span><span style="color: #0000ff;">public</span> <span style="color: #0000ff;">void</span><span style="color: #000000;"> onClick(View v) { Toast.makeText(MainActivity.</span><span style="color: #0000ff;">this</span>,"you have clicked Button2"<span style="color: #000000;">,Toast.LENGTH_SHORT).show(); } }; </span><span style="color: #008000;">//</span><span style="color: #008000;"> 方法三,注意需要public方法</span> <span style="color: #0000ff;">public</span> <span style="color: #0000ff;">void</span><span style="color: #000000;"> onButtonClick (View view){ Toast.makeText(MainActivity.</span><span style="color: #0000ff;">this</span>,"you have clicked Button3"<span style="color: #000000;">,Toast.LENGTH_SHORT).show(); }
}
输出结果:当点击相应按钮时会出现“you have clicked Button?”的提示。
总结:三种方法可以说各有好处。第一种方法是新手入门必学。相对于第一种方法,后来两种方法在android开发中是比较常见的,也是大神们经常推荐使用的方法。至于自己想要使用那种方法,就看自己兴趣了。