一、基于监听的事件处理机制

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

事件监听机制中由事件源,事件,事件监听器三类对象组成 处理流程如下:

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

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

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

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

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

  1. 五种不同的使用形式

1)       直接使用匿名内部类

平时最常用的一种:直接setXxxListener后,重写里面的方法即可; 通常是临时使用一次,复用性不高!

2)       使用内部类

和上面的匿名内部类不同哦! 使用优点:可以在该类中进行复用,可直接访问外部类的所有界面组件!

3)       使用外部类

另外创建一个处理事件的Java文件,这种形式用的比较少!因为外部类不能直接访问用户界面类中的组件,要通过构造方法将组件传入使用;这样导致的结果就是代码不够简洁!

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

让Activity类实现XxxListener事件监听接口,在Activity中定义重写对应的事件处理器方法 eg:Actitity实现了OnClickListener接口,重写了onClick(view)方法在为某些组建添加该事件监听对象时,直接setXxx.Listener(this)即可

5)       直接绑定到标签

直接在xml布局文件中对应得Activity中定义一个事件处理方法 eg:public void myClick(View source) source对应事件源(组件) ,接着布局文件中对应要触发事件的组建,设置一个属性:onclick = "myclick"即可

二、基于回调的事件处理机制

当发生点击事件后不需要我们在Java文件中进行事件监听器的绑定就可以完成回调,即组件会处理对应的事件,即事件由事件源(组件)自身处理!

  1. 回调方法

1)       将功能定义与功能分开的一种手段,一种解耦合的设计思想;

2)       在Java中回调是通过接口来实现的, 作为一种系统架构,必须要有自己的运行环境,且需要为用户提供实现接口;

3)       实现依赖于客户,这样就可以达到接口统一,实现不同;

4)       系统通过在不同的状态下“回调”我们的实现类,从而达到接口和实现的分离!

  1. 两个使用场景

1)       自定义View(组件)

当用户在GUI组件上激发某个事件时,组件有自己特定的方法会负责处理该事件。

通常用法:继承基本的GUI组件,重写该组件的事件处理方法,即自定义View 。

常见View的回调方法:

①   在该组件上触发屏幕事件: boolean onTouchEvent(MotionEvent event);

②   在该组件上按下某个按钮时: boolean onKeyDown(int keyCode,KeyEvent event);

③   松开组件上的某个按钮时: boolean onKeyUp(int keyCode,KeyEvent event);

④   长按组件某个按钮时: boolean onKeyLongPress(int keyCode,KeyEvent event);

⑤   键盘快捷键事件发生::boolean onKeyShortcut(int keyCode,KeyEvent event);

⑥   在组件上触发轨迹球屏事件: boolean onTrackballEvent(MotionEvent event);

⑦   当组件的焦点发生改变,和前面的6个不同,这个方法只能够在View中重写哦! protected void onFocusChanged(boolean gainFocus, int direction, Rect previously FocusedRect)

注意:在xml布局中使用自定义的view时,需要使用“全限定类名”

2)       基于回调的事件传播

View的回调方法的返回值都是boolean类型,返回值是用来标识这个方法是否已经完全处理完该事件。如果为false的话,说明没处理完,那么就传播出去,出发组件所在的Activity的相关回调方法;为true就不会传播。

事件的传播顺序:监听器--->view组件的回调方法--->Activity的回调方法

三、Handler消息传递机制

Handler的使用:

  1. Handler写在主线程中

在主线程中,因为系统已经初始化了一个Looper对象,所以我们直接创建Handler对象,就可以进行信息的发送与处理。

  1. Handler写在子线程中

如果是Handler写在了子线程中的话,我们就需要自己创建一个Looper对象了。创建的流程如下:

1 )     直接调用Looper.prepare()方法即可为当前线程创建Looper对象,而它的构造器会创建配套的MessageQueue

2 )     创建Handler对象,重写handleMessage( )方法就可以处理来自于其他线程的信息

3 )     调用Looper.loop()方法启动Looper

事件处理机制与Handler消息传递机制的更多相关文章

  1. Android中的消息机制:Handler消息传递机制

    参考<疯狂android讲义>第2版3.5 P214 一.背景 出于性能优化考虑,Android的UI操作并不是线程安全的,这意味着如果有多个线程并发操作UI组件,可能导致线程安全问题.为 ...

  2. Android中的消息机制:Handler消息传递机制 分类: H1_ANDROID 2013-10-27 22:54 1755人阅读 评论(0) 收藏

    参考<疯狂android讲义>第2版3.5 P214 一.背景 出于性能优化考虑,Android的UI操作并不是线程安全的,这意味着如果有多个线程并发操作UI组件,可能导致线程安全问题.为 ...

  3. Android学习笔记-事件处理之Handler消息传递机制

    内容摘要:Android Handler消息传递机制的学习总结.问题记录 Handler消息传递机制的目的: 1.实现线程间通信(如:Android平台只允许主线程(UI线程)修改Activity里的 ...

  4. 安卓开发_深入理解Handler消息传递机制

    一.概述 因为子线程的run()方法无法修改UI线程(主线程)的UI界面,所以Android引入了Handler消息传递机制,实现在新创建的线程中操作UI界面 二.消息类(Message) 消息类是存 ...

  5. Handler消息传递机制

    引言: 出于性能优化考虑,Android的UI操作并不是线程安全的,这意味着如果有多个线程并发操作UI组件,可能导致线程安全问题. 为了解决这个问题,Android制定了一条简单的规则:只允许UI线程 ...

  6. Android学习之Handler消息传递机制

    Android只允许UI线程修改Activity里的UI组件.当Android程序第一次启动时,Android会同时启动一条主线程(Main Thread),主线程主要负责处理与UI相关的事件,如用户 ...

  7. Handler消息传递机制——Handler、Loop、MessageQueue的工作原理

    为了更好地理解Handler的工作原理,先介绍一下与Handler一起工作的几个组件. Message:Handler接收和处理的消息对象. Looper:每个线程只能拥有一个Looper.它的loo ...

  8. Handler消息传递机制——Handler类简洁

    Handler类的主要作用有两个: 在新启动的线程中发送消息. 在主线程中获取.处理消息. 上面的说法很简单,只要分成两步即可:在新启动的线程中发送消息:然后在主线程上获取.并处理消息.但这个过程涉及 ...

  9. 3.3 线程---Handler消息传递机制浅析

    Handler的执行流程图: 当我们的子线程想修改Activity中的UI组件时,我们可以新建一个Handler对象,通过这个对象向主线程发送信息;而我们发送的信息会先到主线程的MessageQueu ...

随机推荐

  1. select into from与insert into select区别

    创建一个table2  向table2中插入 table1中name为11的所有行(前提table2不存在) select * into table2 from table1 where name=‘ ...

  2. SCRUM 是一个用于开发和维护复杂产品的框架

    转自:http://www.scrumcn.com/agile/scrum-knowledge-library/scrum.html#tab-id-1 Scrum 是一个用于开发和维护复杂产品的框架 ...

  3. Lab3 Report

  4. python小知识-sys.argv

    sys.argv 就是一个从程序外部获取参数的桥梁 1.t1.py import sys a = sys.argv b = len(sys.argv) print(a) print(b) 在pytho ...

  5. STM32工程模版

    STM32工程模版,看过来 ST库源码去官方下载 创建工程目录 doc:存放说明文档 lib:存放库文件 listing:存放编译产生的中间文件 output:存放生成的文件 project:存放工程 ...

  6. SpringCloud之Hystrix容错保护原理及配置

    1 什么是灾难性雪崩效应? 如下图的过程所示,灾难性雪崩形成原因就大致如此: 造成灾难性雪崩效应的原因,可以简单归结为下述三种: 服务提供者不可用.如:硬件故障.程序BUG.缓存击穿.并发请求量过大等 ...

  7. 14.SpringMVC核心技术-类型转换器

    类型转换器 在前面的程序中,表单提交的无论是 int 还是 double 类型的请求参数,用于处理该请求 的处理器方法的形参, 均可直接接收到相应类型的相应数据,而非接收到 String 再手工转换. ...

  8. 学java编程软件开发,非计算机专业是否能学

    近几年互联网的发展越来越好,在国外,java程序员已经成为高薪以及稳定职业的代表,虽然国内的有些程序员很苦逼,但是那只是少数,按照国外的大方向来看,程序员还是一个很吃香的职业.根据编程语言的流行程度, ...

  9. spark streaming消费kafka: Java .lang.IllegalStateException: No current assignment for partition

    1 原因是: 多个相同的Spark Streaming同时消费同一个topic,导致的offset问题.关掉多余的任务,就ok了.

  10. linux 设备驱动与应用程序异步通知

    一.异步通知机制简介 异步通知机制的意思:一旦设备准备就绪,可以主动的通知应用程序进行相应的操作,从而使得应用程序不必去查询设备的状态. 异步通知比较准确的称谓是"信号驱动的异步IO&quo ...