小猪的Android入门之路 Day 4 - part 1

小猪的Android入门之路 Day 4 - part 1

Android事件处理机制之——基于监听的事件处理机制



本节引言:

在开始本个章节前,我们先回顾下,现在我们已经知道了android的一些相关背景,一些常用的UI组件,

六大布局,现在的我们已经可以做出一个简单的app界面了,下一步就是逻辑与业务的实现了;在前面

的例子中我们曾经看到过setXXXListener这些东东,这个就是android 的事件处理,而这个方法是基于监听的

Android为我们提供了两套功能强大的事件处理机制:

①基于监听的事件处理机制

②基于回调的事件处理机制

我们将会分成几个部分来讲解Android的事件处理机制,而在这一part中我们会详细地解析

基于监听的事件处理机制大笑



本节学习路线图:




正文:



基于监听的时间处理机制模型:


流程模型图:




文字表述:

事件监听机制中由事件源,事件,事件监听器三类对象组成

处理流程:

step 1:为某个事件源(组件)设置一个监听器,用于监听用户操作

step 2:用户的操作,触发了事件源的监听器

step 3:生成了对应的事件对象

step 4:将这个事件源对象作为参数传给事件监听器

step 5:事件监听器对事件对象进行判断,执行对应的事件处理器(对应事件的处理方法)



归纳:

事件监听机制是一种委派式的事件处理机制,事件源(组件)事件处理委托给事件监听器

当事件源发生指定事件时,就通知指定事件监听器,执行相应的操作






监听机制的使用形式:


这里演示的是一个简单的按钮点击,提示Toast信息的程序

但是使用不同的形式来实现:


效果图:





不同实现:



①直接用匿名内部类


平时最常用的一种:直接setXxxListener后,重写里面的方法即可;

通常是临时使用一次,复用性不高!


代码:

MainActivity.java

[java]   view plain copy print ?
  1. package com.jay.example.innerlisten;    
  2.     
  3. import android.os.Bundle;    
  4. import android.view.View;    
  5. import android.view.View.OnClickListener;    
  6. import android.widget.Button;    
  7. import android.widget.Toast;    
  8. import android.app.Activity;    
  9.     
  10.     
  11. public class MainActivity extends Activity {    
  12.     
  13.     private Button btnshow;    
  14.         
  15.     @Override    
  16.     protected void onCreate(Bundle savedInstanceState) {    
  17.         super.onCreate(savedInstanceState);    
  18.         setContentView(R.layout.activity_main);    
  19.             
  20.         btnshow = (Button) findViewById(R.id.btnshow);    
  21.         btnshow.setOnClickListener(new OnClickListener() {    
  22.             //重写点击事件的处理方法onClick()    
  23.             @Override    
  24.             public void onClick(View v) {    
  25.                 //显示Toast信息    
  26.                 Toast.makeText(getApplicationContext(), "你点击了按钮", Toast.LENGTH_SHORT).show();    
  27.             }    
  28.         });    
  29.     }        
  30. }    


                                                                                                                                                                           





②使用内部类


和上面的匿名内部类不同哦!

使用优点:可以在该类中进行复用,可直接访问外部类的所有界面组件!


代码:

MainActivity.java

[java]   view plain copy print ?
  1. package com.jay.example.innerlisten;    
  2.     
  3. import android.os.Bundle;    
  4. import android.view.View;    
  5. import android.view.View.OnClickListener;    
  6. import android.widget.Button;    
  7. import android.widget.Toast;    
  8. import android.app.Activity;    
  9.     
  10.     
  11. public class MainActivity extends Activity {    
  12.     
  13.     private Button btnshow;    
  14.         
  15.     @Override    
  16.     protected void onCreate(Bundle savedInstanceState) {    
  17.         super.onCreate(savedInstanceState);    
  18.         setContentView(R.layout.activity_main);    
  19.             
  20.         btnshow = (Button) findViewById(R.id.btnshow);    
  21.         //直接new一个内部类对象作为参数    
  22.         btnshow.setOnClickListener(new BtnClickListener());    
  23.             
  24.     }     
  25.         
  26.         
  27.     //定义一个内部类,实现View.OnClickListener接口,并重写onClick()方法    
  28.     class BtnClickListener implements View.OnClickListener    
  29.     {    
  30.         @Override    
  31.         public void onClick(View v) {    
  32.                 
  33.             Toast.makeText(getApplicationContext(), "按钮被点击了", Toast.LENGTH_SHORT).show();    
  34.         }    
  35.             
  36.     }    
  37. }  


                                                                                                                                                                           



③使用外部类

就是另外创建一个处理事件的Java文件,这种形式用的比较少!

因为外部类不能直接访问用户界面类中的组件,要通过构造方法将组件传入使用;

这样导致的结果就是代码不够简洁!


ps:为了演示传参,这里用TextView代替Toast提示!





代码:

MyClick.java

[java]   view plain copy print ?
  1. package com.jay.example.innerlisten;    
  2.     
  3. import android.view.View;    
  4. import android.view.View.OnClickListener;    
  5. import android.widget.TextView;    
  6.     
  7. public class MyClick implements OnClickListener {    
  8.     
  9.     private TextView textshow;    
  10.     //把文本框作为参数传入    
  11.     public MyClick(TextView txt)    
  12.     {    
  13.         textshow = txt;    
  14.     }    
  15.         
  16.     @Override    
  17.     public void onClick(View v) {    
  18.         //点击后设置文本框显示的文字    
  19.         textshow.setText("点击了按钮!");    
  20.     }    
  21.     
  22. }    


MainActivity.java

[java]   view plain copy print ?
  1. package com.jay.example.innerlisten;    
  2. import android.os.Bundle;    
  3. import android.widget.Button;    
  4. import android.widget.TextView;    
  5. import android.app.Activity;    
  6.     
  7.     
  8. public class MainActivity extends Activity {    
  9.     
  10.     private Button btnshow;    
  11.     private TextView txtshow;    
  12.         
  13.     @Override    
  14.     protected void onCreate(Bundle savedInstanceState) {    
  15.         super.onCreate(savedInstanceState);    
  16.         setContentView(R.layout.activity_main);    
  17.             
  18.         btnshow = (Button) findViewById(R.id.btnshow);    
  19.         txtshow = (TextView) findViewById(R.id.textshow);    
  20.         //直接new一个外部类,并把TextView作为参数传入    
  21.         btnshow.setOnClickListener(new MyClick(txtshow));    
  22.             
  23.     }         
  24. }    


                                                                                                                                                                           




④直接使用Activity作为事件监听器

只需要让Activity类实现XxxListener事件监听接口,在Activity中定义重写对应的事件处理器方法

eg:Actitity实现了OnClickListener接口,重写了onClick(view)方法

在为某些组建添加该事件监听对象时,直接setXxx.Listener(this)即可


还是一开始的那个布局效果;


代码:

MainActivity.java

[java]   view plain copy print ?
  1. package com.jay.example.innerlisten;    
  2. import android.os.Bundle;    
  3. import android.view.View;    
  4. import android.view.View.OnClickListener;    
  5. import android.widget.Button;    
  6. import android.widget.Toast;    
  7. import android.app.Activity;    
  8.     
  9. //让Activity方法实现OnClickListener接口    
  10. public class MainActivity extends Activity implements OnClickListener{    
  11.     
  12.     private Button btnshow;    
  13.         
  14.     @Override    
  15.     protected void onCreate(Bundle savedInstanceState) {    
  16.         super.onCreate(savedInstanceState);    
  17.         setContentView(R.layout.activity_main);    
  18.             
  19.         btnshow = (Button) findViewById(R.id.btnshow);    
  20.         //直接写个this    
  21.         btnshow.setOnClickListener(this);    
  22.             
  23.     }    
  24.     
  25.     //重写接口中的抽象方法    
  26.     @Override    
  27.     public void onClick(View v) {    
  28.         Toast.makeText(getApplicationContext(), "点击了按钮", Toast.LENGTH_SHORT).show();            
  29.     }         
  30. }    


                                                                                                                                                                           



⑤直接绑定到标签:

就是直接在xml布局文件中对应得Activity中定义一个事件处理方法

eg:public void myClick(View source)   source对应事件源(组件)

接着布局文件中对应要触发事件的组建,设置一个属性:onclick = "myclick"即可


同样是哪个点击后提示toast信息的例子:


代码:


MainActivity.java

[java]   view plain copy print ?
  1. package com.jay.example.caller;    
  2.     
  3. import android.app.Activity;    
  4. import android.os.Bundle;    
  5. import android.view.View;    
  6. import android.widget.Toast;    
  7.     
  8.     
  9. public class MainActivity extends Activity {    
  10.     
  11.     
  12.     @Override    
  13.     protected void onCreate(Bundle savedInstanceState) {    
  14.         super.onCreate(savedInstanceState);    
  15.         setContentView(R.layout.activity_main);     
  16.     }    
  17.         
  18.     //自定义一个方法,传入一个view组件作为参数    
  19.     public void myclick(View source)    
  20.     {    
  21.         Toast.makeText(getApplicationContext(), "按钮被点击了", Toast.LENGTH_SHORT).show();    
  22.     }    
  23. }    


main.xml布局文件:

[html]   view plain copy print ?
  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    
  2.     xmlns:tools="http://schemas.android.com/tools"    
  3.     android:id="@+id/LinearLayout1"    
  4.     android:layout_width="match_parent"    
  5.     android:layout_height="match_parent"    
  6.     android:orientation="vertical" >    
  7.         
  8.     <Button     
  9.         android:layout_width="wrap_content"    
  10.         android:layout_height="wrap_content"    
  11.         android:text="按钮"    
  12.         android:onClick="myclick"        
  13.     />    
  14.         
  15. </LinearLayout>   
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值