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

2024-04-26 12:18

本文主要是介绍Android基于监听的事件处理机制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Android提供了强大的事件处理机制,主要包括两大类:

1,基于监听的事件处理机制:主要做法是为Android界面组件绑定特定的事件监听器

2,基于回调的事件处理机制:主要做法是重写Android组件特定的回调方法,或重写Activity的回调方法。也就是说Android的绝大多数的界面组件都提供了事件响应的回调方法,开发者只要重写它们即可


基于监听的事件处理是一种更加面向对象的事件处理,这种事件处理方式与Java的Swing处理方式几乎相同。

监听处理模型:

事件源(Event Source):事件发生的场所,就是各个组件,比如按钮,窗口,菜单等

事件(Event):事件封装了界面组件上发生的特定事情(就是用户操作)。如果程序需要获得界面组件上所发生事件的相关信息,一般通过Event对象来获取

事件监听器(Event Listener):负责监听事件源所发生的时间,并且对各个事件作出响应。

委派式事件处理方法:

  普通组件(事件源)将整个事件处理委派给特定的对象(事件监听器);当该事件源发生指定的时间是,就通知所委派的事件监听器来处理这个事件。

每个组件都可以针对特定的时间指定一个事件监听器,每个事件监听器也可以监听一个或多个事件源。因为同一个事件源上可能发生多个事件,委派式事件处理方式可以吧事件源上所有可能发生的时间分别授权给不同的事件处理器来处理;同时也可以让一类事件都使用同一个事件监听器来处理。


activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:orientation="vertical"android:layout_width="fill_parent"android:layout_height="fill_parent"android:gravity="center_horizontal">
<EditText android:id="@+id/txt"android:layout_width="fill_parent" android:layout_height="wrap_content" android:editable="false"android:cursorVisible="false"android:textSize="12pt"/>
<!-- 定义一个按钮,该按钮将作为事件源 -->
<Button android:id="@+id/bn"android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="单击我"/>	
</LinearLayout>
MainActivity.java

public class <span style="font-size:24px;">MainActivity </span>extends Activity
{@Overridepublic void onCreate(Bundle savedInstanceState){super.onCreate(savedInstanceState);setContentView(R.layout.main);// 获取应用程序中的bn按钮Button bn = (Button) findViewById(R.id.bn);// 为按钮绑定事件监听器。bn.setOnClickListener(new MyClickListener()); // ①}// 定义一个单击事件的监听器class MyClickListener implements View.OnClickListener{// 实现监听器类必须实现的方法,该方法将会作为事件处理器@Overridepublic void onClick(View v){EditText txt = (EditText) findViewById(R.id.txt);txt.setText("bn按钮被单击了!");}}
}
基于监听器的事件处理模型的编程步骤如下:

1,获取普通界面组件(事件源),也就是被监听的对象

2,实现时间监听类,该监听器类是一个特殊的Java类,必须实现一个XxxListener接口

3,调用事件源的setXXXListener方法,将事件监听器对象注册给普通组件(事件源)


事件监听器必须实现事件监听接口,Android的不同界面组件提供了不同的监听器接口,这些接口通常以内部类的形式存在。以View类为例,包含如下监听接口:

   View.OnClickListener单击事件的事件监听器必须时间的接口

   View.OnCreateContextMenuListener:创建上下文菜单时间的事件监听器必须实现的接口

   View.onFocusChangeListener:焦点改变事件的事件监听器必须实现的接口

   View.OnKeyListener:按键事件的时间监听器必须实现的接口

所谓事件监听器,其实就是实现了特定接口的java类的实例。在程序上一般有几种形式:

1,内部类形式:将事件监听器定义成当前类的内部类

public class EventQs extends Activity
{@Overridepublic void onCreate(Bundle savedInstanceState){super.onCreate(savedInstanceState);setContentView(R.layout.main);// 获取应用程序中的bn按钮Button bn = (Button) findViewById(R.id.bn);// 为按钮绑定事件监听器。bn.setOnClickListener(new MyClickListener()); // }// 定义一个单击事件的监听器,内部类形式class MyClickListener implements View.OnClickListener{// 实现监听器类必须实现的方法,该方法将会作为事件处理器@Overridepublic void onClick(View v){EditText txt = (EditText) findViewById(R.id.txt);txt.setText("bn按钮被单击了!");}}
}
因为监听器是内部类,所以可以自由访问外部类的所有界面组件,这也是内部类的优势。

2,外部类形式:将事件监听器类定义成一个外部类

外部类形式的事件监听器不能自由访问创建GUI界面类的组件,使用时需要向监听器类传递GUI界面类的组件的引用 ,所以用的比较少

MainActivity.java

public class MainActivity extends Activity
{EditText address;EditText content;@Overridepublic void onCreate(Bundle savedInstanceState){super.onCreate(savedInstanceState);setContentView(R.layout.main);// 获取页面中收件人地址、短信内容address = (EditText)findViewById(R.id.address);content = (EditText)findViewById(R.id.content);Button bn = (Button)findViewById(R.id.send);bn.setOnLongClickListener(new SendSmsListener(this , address, content));//外部类形式,需要传递本类组件}
}
SendSmsListener.java

public class SendSmsListener implements OnLongClickListener
{private Activity act;private EditText address;private EditText content;public SendSmsListener(Activity act, EditText address, EditText content){this.act = act;this.address = address;this.content = content;}@Overridepublic boolean onLongClick(View source){String addressStr = address.getText().toString();String contentStr = content.getText().toString();// 获取短信管理器SmsManager smsManager = SmsManager.getDefault();// 创建发送短信的PendingIntentPendingIntent sentIntent = PendingIntent.getBroadcast(act, 0, new Intent(), 0);// 发送文本短信smsManager.sendTextMessage(addressStr, null, contentStr, sentIntent, null);Toast.makeText(act, "短信发送完成", Toast.LENGTH_LONG).show();return false;}
}

3,Activity本身作为事件监听器类:让Activity本身实现监听接口,并实现事件处理器方法

// <span style="font-size:24px;">Activity</span>实现事件监听器接口
public class ActivityListener extends Activityimplements OnClickListener
{EditText show;Button bn;@Overridepublic void onCreate(Bundle savedInstanceState){super.onCreate(savedInstanceState);setContentView(R.layout.main);show = (EditText) findViewById(R.id.show);bn = (Button) findViewById(R.id.bn);// 直接使用Activity作为事件监听器bn.setOnClickListener(this);}// 实现事件处理方法@Overridepublic void onClick(View v){show.setText("bn按钮被单击了!");}
}

4,匿名内部类形式:使用匿名内部类创建事件监听器对象。代码简单的情况,只能用一次

public class MainActivity extends Activity
{EditText show;Button bn;@Overridepublic void onCreate(Bundle savedInstanceState){super.onCreate(savedInstanceState);setContentView(R.layout.main);show = (EditText) findViewById(R.id.show);bn = (Button) findViewById(R.id.bn);// 直接使用Activity作为事件监听器bn.setOnClickListener(new OnClickListener(){// 实现事件处理方法@Overridepublic void onClick(View v){show.setText("bn按钮被单击了!");}});}

这篇关于Android基于监听的事件处理机制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/937566

相关文章

Android协程高级用法大全

《Android协程高级用法大全》这篇文章给大家介绍Android协程高级用法大全,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友跟随小编一起学习吧... 目录1️⃣ 协程作用域(CoroutineScope)与生命周期绑定Activity/Fragment 中手

基于Redis自动过期的流处理暂停机制

《基于Redis自动过期的流处理暂停机制》基于Redis自动过期的流处理暂停机制是一种高效、可靠且易于实现的解决方案,防止延时过大的数据影响实时处理自动恢复处理,以避免积压的数据影响实时性,下面就来详... 目录核心思路代码实现1. 初始化Redis连接和键前缀2. 接收数据时检查暂停状态3. 检测到延时过

Redis中哨兵机制和集群的区别及说明

《Redis中哨兵机制和集群的区别及说明》Redis哨兵通过主从复制实现高可用,适用于中小规模数据;集群采用分布式分片,支持动态扩展,适合大规模数据,哨兵管理简单但扩展性弱,集群性能更强但架构复杂,根... 目录一、架构设计与节点角色1. 哨兵机制(Sentinel)2. 集群(Cluster)二、数据分片

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按

深入理解go中interface机制

《深入理解go中interface机制》本文主要介绍了深入理解go中interface机制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前言interface使用类型判断总结前言go的interface是一组method的集合,不

C# async await 异步编程实现机制详解

《C#asyncawait异步编程实现机制详解》async/await是C#5.0引入的语法糖,它基于**状态机(StateMachine)**模式实现,将异步方法转换为编译器生成的状态机类,本... 目录一、async/await 异步编程实现机制1.1 核心概念1.2 编译器转换过程1.3 关键组件解析

Go语言使用select监听多个channel的示例详解

《Go语言使用select监听多个channel的示例详解》本文将聚焦Go并发中的一个强力工具,select,这篇文章将通过实际案例学习如何优雅地监听多个Channel,实现多任务处理、超时控制和非阻... 目录一、前言:为什么要使用select二、实战目标三、案例代码:监听两个任务结果和超时四、运行示例五

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、