AccessibilityService是用来帮助残疾人使用安卓设备和app的。AccessibilityService在后台运行,可以接收窗口变化、焦点变化、点击等事件。
使用时需要继承AccessibilityService,并实现onAccessibilityEvent(AccessibilityEvent event)方法。绑定service的时候,会调用onServiceConnected方法,调用disableSelf可以停止service。
和其他Service一样,需要在AndroidManifest.xml中进行声明,
<application
..........>
<service
android:name=".GetRedPacketService"
android:enabled="true"
android:exported="true"
android:label="抢红包"
android:permission="android.permission.BIND_ACCESSIBILITY_SERVICE">
<intent-filter>
<action android:name="android.accessibilityservice.AccessibilityService" />
</intent-filter>
<meta-data
android:name="android.accessibilityservice"
android:resource="@xml/accessibility_config" />
</service>
</application>
//需要添加的权限
<uses-permission android:name="android.permission.BIND_ACCESSIBILITY_SERVICE" />
accessibility_config.xml可以配置service的一些信息,
<accessibility-service xmlns:android="http://schemas.android.com/apk/res/android"
android:description="@string/description"//描述信息
android:packageNames="com.tencent.mm"//监听哪些app的事件,例如这里设置的是微信
android:accessibilityEventTypes="typeAllMask|typeViewClicked|typeViewFocused|typeNotificationStateChanged|typeWindowStateChanged"//监听哪些事件
android:accessibilityFlags="flagDefault"
android:accessibilityFeedbackType="feedbackSpoken"
android:notificationTimeout="100"
android:canRetrieveWindowContent="true"
/>
配置完以后,运行app,打开设置—辅助功能,找到自己的app,开启。打开微信,触发点击、打开新页面等操作,就可以在onAccessibilityEvent接收到事件了。
AccessibilityService提供了很多方法帮助我们获取事件源信息,
检索窗口内容相关方法:
获取一个事件的事件源
AccessibilityEvent#getSource(),该方法返回一个AccessibilityNodeInfo类型的对象,表示窗口内容的节点。AccessibilityNodeInfo定义了可以执行的动作,例如点击public static final int ACTION_CLICK = 0x00000010;长按public static final int ACTION_LONG_CLICK = 0x00000020;等。我们可以调用performAction(int action)来模拟对应的事件。
AccessibilityWindowInfo findAccessibilityNodeInfosByText(String text)根据text查找AccessibilityNodeInfo
AccessibilityWindowInfo getWindow() 返回节点所在的窗口
AccessibilityNodeInfo getParent() 获取当前节点的父节点
public boolean isCheckable() 节点是否可点击
public boolean isChecked() 节点是否被选中
获取屏幕上的窗口
AccessibilityService#public List getWindows() 返回当前可见并且可交互的窗口
获取当前活动窗口的根节点
AccessibilityService#AccessibilityNodeInfo getRootInActiveWindow()
AccessibilityEvent 事件
getEventType() 事件类型
getSource() 事件源
getClassName() 事件的类名,例如打开一个页面,获取到的是页面的类名
getPackageName() 获取包名