Android 辅助功能(无障碍)自定义开发类似微信抢红包插件

背景:

通常在无人值守的Android智能设备或不能触摸交互的设备中,当系统运行异常时, 系统有可能会弹出应用程序无响应(ANR)对话框,提示是否终止当前进程或等待,或应用程序异常退出时系统偶尔也会有弹窗,那么对于无人值守的设备,我们可以通过Android 辅助功能,监听到有异常时, 自动帮用户点掉窗口。辅助功能需要用到 AccessibilityService  , AccessibilityService是系统提供的无障碍辅助服务接口,我们可以通过继承AccessibilityService 来实现自定义无障碍服务。

实现:

1.继承AccessibilityService

public class MyAccessibilityService extends AccessibilityService {


    private static final String TAG = "MyAccessibilityService";
 

    @Override
    public void onCreate() {
        super.onCreate();
        Log.d(TAG, "onCreate");
        //从系统设置里面开启辅助功能时回调1
    }
 

    @Override
    protected void onServiceConnected() {
        super.onServiceConnected();
        Log.d(TAG, "onServiceConnected");
         //从系统设置里面开启辅助功能时回调2
    }

    @Override
    public void onAccessibilityEvent(AccessibilityEvent event) {
        int eventType = event.getEventType();
        // 输出事件的字符串type
        String typeStr = event.eventTypeToString(eventType);
        Log.d(TAG, "typeStr:" + typeStr);
        

        //当有事件被监听到时,会回调该方法,AccessibilityEvent 里包含事件类型,发生源头等,
    }

   

    @Override
    public void onInterrupt() {
        Log.d(TAG, "onInterrupt");
    }

    @Override
    public boolean onUnbind(Intent intent) {

        Log.d(TAG, "onUnbind");
        return super.onUnbind(intent);
        //从系统辅助功能里关闭该服务时回调1
    }


     @Override
    public void onDestroy() {
        Log.d(TAG, "onDestroy");
        super.onDestroy();
        //从系统辅助功能里关闭该服务时回调2 ,即服务会被销毁
    }
}

2.不要忘记在AndroidManifest.xml 中注册服务

       <service
            android:name=".MyAccessibilityService"
            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/my_service_config" />
                
        </service>

其中

                <meta-data
                android:name="android.accessibilityservice"
                android:resource="@xml/my_service_config" />

要固定这样写,android:resource 指定一个accessibilityservice 的配置项

3. 创建 res/xml/my_service_config

<?xml version="1.0" encoding="utf-8"?>
<accessibility-service xmlns:android="http://schemas.android.com/apk/res/android"
    android:accessibilityEventTypes="typeWindowStateChanged"
    android:accessibilityFeedbackType="feedbackGeneric"
    android:accessibilityFlags="flagDefault|flagRetrieveInteractiveWindows|flagReportViewIds|flagIncludeNotImportantViews"
    android:canRetrieveWindowContent="true"
    android:description="@string/accessibility_description"
    android:notificationTimeout="50"
    android:packageNames="android"
    />

    <!--typeAllMask是设置响应事件的类型,typeAllMask当然就是响应所有类型的事件-->
    <!--feedbackGeneric是设置回馈给用户的方式,有语音播出和振动。可以配置一些TTS引擎,让它实现发音。-->
    <!--com.tencent.mm微信的包名,便可以监听微信产生的事件-->
<!--    android:packageNames="com.tmall.ighwa.accessibility" -->
    <!--android:packageNames="com.android.settings"-->
android:accessibilityEventTypes="typeWindowStateChanged" 这里指定的是监听窗体状态变化
android:packageNames="android"   指定要监听那个进程,指定其报名,  这里我监听的是android, 也就是系统进程,ANR 是由系统进程弹出的
android:description="@string/accessibility_description"   指定的是服务的描述,就是用户在系统设置界面辅助功能列表里看到的服务描述

 

4.启动

安装完成后到系统设置辅助功能选项里面将服务打开,辅助服务就启动了,当你想要监听的事件有变化时,系统就会回调服务的onAccessibilityEvent方法,事件原因,类型,等都会包含在event中。

 

-------示例,监听系统ANR 并自动点掉对话框,其余参考上面的配置

 @Override
    public void onAccessibilityEvent(AccessibilityEvent event) {
        int eventType = event.getEventType();
        // 输出事件的字符串type
        String typeStr = event.eventTypeToString(eventType);
        Log.d(TAG, "typeStr:" + typeStr);
        AccessibilityNodeInfo nodeInfo = event.getSource();
        if (nodeInfo == null) {
            return;
        }

        try {
            parserTree(nodeInfo);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }


   private void parserTree(AccessibilityNodeInfo node) {
        List<AccessibilityNodeInfo> buttonNode = new ArrayList<>();
        if (node != null) {
            int childCount = node.getChildCount();
            if (childCount >= 1) {
                for (int i = 0; i < childCount; i++) {
                    AccessibilityNodeInfo child = node.getChild(i);
                    parserTree(child);
                }
            } else {
                CharSequence text = node.getText();
                if (TextUtils.isEmpty(text)) {

                } else {
                    if (text.equals("等待")) {
                        // ANR                   
                        node.performAction(AccessibilityNodeInfo.ACTION_CLICK);
                        return;
                    }
                    if (text.equals("取消") || text.equals("确定") || text.equals("确认")) {
                        buttonNode.add(node);
                    }
                }
            }
        } else {
            Log.d(TAG, "node is null");
        }

        if (buttonNode != null & buttonNode.size() == 1) {
            Log.d(TAG, "命中");
            buttonNode.get(0).performAction(AccessibilityNodeInfo.ACTION_CLICK);
        }
    }
应用安装好后,你也可以通过如下命令通过adb开启服务
adb shell settings put secure enabled_accessibility_services com.aaa.bbb.ccc/com.aaa.bbb.ccc.MyAccessibilityService
adb shell settings put secure accessibility_enabled 1

当然如果你的设备是root的,你也可以通过代码通过su直接开启

su settings put secure enabled_accessibility_services com.aaa.bbb.ccc/com.aaa.bbb.ccc.MyAccessibilityService

su settings put secure accessibility_enabled 1

还需要权限

<uses-permission android:name="android.permission.WRITE_SETTINGS"
    tools:ignore="ProtectedPermissions"></uses-permission>
<uses-permission android:name="android.permission.WRITE_SECURE_SETTINGS"
    tools:ignore="ProtectedPermissions"></uses-permission>

说到ANR ,系统在检测到应用发生ANR时,会发出广播,如果你想做ANR监控,也可以监听这个广播来处理

<intent-filter>
     <action android:name="android.intent.action.ANR"></action>
</intent-filter>

 

参考:

https://www.jianshu.com/p/959217070c87

https://blog.csdn.net/qq_24800377/article/details/78283662

https://blog.csdn.net/seu_calvin/article/details/51912738

http://www.cnblogs.com/popfisher/archive/2017/08/30/7455754.html

 

 

 

 

 

 

 

 

 

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
iOS企业微信红包是指在企业微信中进行红包活动的行为。企业微信是基于微信平台的一款专门为企业打造的应用软件,包含了组织架构管理、通讯录、消息通知、会议管理等多种功能。 在企业微信红包活动是一种促进团队凝聚力和员工活跃度的活动方式。通过发送红包以及其他方式(例如答题、抽奖等)发放红包,员工在企业微信中参与红包的过程中可以增加期待感和参与度,同时也能够加强员工之间的交流和互动。 在进行企业微信红包活动时,员工可以通过打开企业微信应用,在红包活动发布的时间和位置,点击相应的红包,即可参与红包。通常,企业微信红包是限时的,员工需要在规定的时间内参与活动,并在红包的瞬间进行操作,以便更快地争取到红包。 企业微信红包活动除了能够增加员工的积极性和参与度,还可以在特定的节日或者庆典活动中增加团队的凝聚力和向心力。通过红包活动,员工之间可以互相祝福和互动,加强距离感和友情。同时,企业也可以利用红包活动来进行员工福利和奖励的发放,提高企业文化和员工满意度。 总而言之,iOS企业微信红包是一种通过企业微信平台进行的红包活动,可以有效增加员工之间的互动、团队的凝聚力和员工的活跃度,是一种有益于企业文化和员工关系的活动方式。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值