(注意:本文基于UI Automator版本为2.2.2)
在UiDevice类中只有一个内部类,就是静态内部类EventForwardingFilter,这个静态内部类是做什么的呢?我们一起学习一下
类结构
private static class EventForwardingFilter implements AccessibilityEventFilter {
private EventCondition<?> mCondition;
public EventForwardingFilter(EventCondition<?> condition) {
mCondition = condition;
}
@Override
public boolean accept(AccessibilityEvent event) {
// Guard against nulls
return Boolean.TRUE.equals(mCondition.apply(event));
}
}
1、实现了AccessibilityEventFilter接口
public static interface AccessibilityEventFilter {
public boolean accept(AccessibilityEvent event);
}
AccessibilityEventFilter接口定义在UiAutomation类中,只定义了一个抽象方法accept()
2、抽象方法accept(AccessibilityEvent)
这个API规定了过滤服务事件方式,传入的AccessibilityEvent对象表示监听事件
3、持有一个EventCondtion对象
EventForwardingFilter对象持有了一个EventCondtion对象,表示条件对象
4、初始化EventCondition对象
在构造方法中,对持有的EventConditon对象进行了初始化
accept()方法分析
@Override
public boolean accept(AccessibilityEvent event) {
// Guard against nulls
return Boolean.TRUE.equals(mCondition.apply(event));
}
用于表示过滤的方法,返回值为true表示需要过滤、false表示不需要过滤
EventForwardingFilter对象持有一个EventConditioin对象mCondition
1、处理传入的AccessibilityEvent对象
将传入的AccessibilityEvent对象再传入到EventCondition对象mCondition的apply()方法中
2、判断mCondition的apply()方法的结果
使用Boolean的TRUE对象,调用equals()方法进行判断
3、返回最终的结果给调用方
谁在使用EventForwardingFilter对象
唯一使用EventForwardingFilter对象的方法是UiDevice中的performActionAndWait()方法
performActionAndWait()方法分析
public <R> R performActionAndWait(Runnable action, EventCondition<R> condition, long timeout) {
AccessibilityEvent event = null;
try {
event = getUiAutomation().executeAndWaitForEvent(
action, new EventForwardingFilter(condition), timeout);
} catch (TimeoutException e) {
// Ignore
}
if (event != null) {
event.recycle();
}
return condition.getResult();
}
使用了 EventForwardingFilter对象的方法,用于等待某个事件满足后,才会做一个动作的方法,我增加在分析UiDevice的等待功能方法中分析过此方法,此处不再细说!
可以在代码中看到new EventForwardingFilter(condition)这一行代码创建了EventForwardingFilter对象!