Android实现微信自动向附近的人打招呼(AccessibilityService)

学习功能强大的AccessibilityService!!!
以下是本人根据自动抢红包的实现思路敲的用于微信自动向附近的人打招呼的核心代码

public class AutoService extends AccessibilityService implements View.OnClickListener {
 private static final String TAG = "test";
 /**
 * 微信的包名
 */
 static final String WECHAT_PACKAGENAME = "com.tencent.mm";
 /**
 * 推送消息在通知栏的关键字,设置为推送账号名,如【十点读书】
 */
 static final String PUSH_TEXT_KEY = "十点读书";
 /**
 * 推送链接的关键字,所有推送链接的标题都需要包含此关键字:如【深度好文】
 */
 private static final String URL_TEXT_KEY = "深度好文";
 /**
 * 向附近的人自动打招呼的内容
 */
 private String hello = "测试APP自动打招呼功能,这是一条测试信息";
 boolean startFunc2 = false;//标记是否开启自动添加附近的人为好友的功能;
 int i = 0;//记录已打招呼的人数
 int page=1;//记录附近的人列表页码,初始页码为1
 int prepos = -1;//记录页面跳转来源,0--从附近的人页面跳转到详细资料页,1--从打招呼页面跳转到详细资料页

 @Override
 public void onAccessibilityEvent(final AccessibilityEvent event) {
 int eventType = event.getEventType();
 //通知栏事件
 //自动打开推送的链接
 if (eventType == AccessibilityEvent.TYPE_NOTIFICATION_STATE_CHANGED) {
 List<CharSequence> texts = event.getText();
 if (!texts.isEmpty()) {
 for (CharSequence t : texts) {
  String text = String.valueOf(t);
  if (text.contains(PUSH_TEXT_KEY)) {
  openNotification(event);
  openDelay(1000, URL_TEXT_KEY);
  }
 }
 }
 }
 //自动加人
 if (!startFunc2) {
 return;
 }
 if (eventType == AccessibilityEvent.TYPE_WINDOW_STATE_CHANGED && event.getClassName().equals("com.tencent.mm.ui.LauncherUI")) {
 //记录打招呼人数置零
 i = 0;
 //当前在微信聊天页就点开发现
 openNext("发现");
 //然后跳转到附近的人
 openDelay(1000, "附近的人");
 } else if (event.getClassName().equals("com.tencent.mm.plugin.nearby.ui.NearbyFriendsUI") && eventType == AccessibilityEvent.TYPE_WINDOW_STATE_CHANGED) {
 prepos = 0;
 //当前在附近的人界面就点选人打招呼
 AccessibilityNodeInfo nodeInfo = getRootInActiveWindow();
 List<AccessibilityNodeInfo> list = nodeInfo.findAccessibilityNodeInfosByText("米以内");
 Log.d("name", "附近的人列表人数: " + list.size());
 if (i < (list.size()*page) ){
 list.get(i%list.size()).performAction(AccessibilityNodeInfo.ACTION_CLICK);
 list.get(i%list.size()).getParent().performAction(AccessibilityNodeInfo.ACTION_CLICK);
 } else if (i == list.size()*page) {
 //本页已全部打招呼,所以下滑列表加载下一页,每次下滑的距离是一屏
 for (int i = 0; i < nodeInfo.getChild(0).getChildCount(); i++) {
  if (nodeInfo.getChild(0).getChild(i).getClassName().equals("android.widget.ListView")) {
  AccessibilityNodeInfo node_lsv = nodeInfo.getChild(0).getChild(i);
  node_lsv.performAction(AccessibilityNodeInfo.ACTION_SCROLL_FORWARD);
  page++;
  new Thread(new Runnable() {
  @Override
  public void run() {
  try {
   Thread.sleep(1000);
  } catch (InterruptedException mE) {
   mE.printStackTrace();
  }
  AccessibilityNodeInfo nodeInfo_ = getRootInActiveWindow();
  List<AccessibilityNodeInfo> list_ = nodeInfo_.findAccessibilityNodeInfosByText("米以内");
  Log.d("name", "列表人数: "+list_.size());
  //滑动之后,上一页的最后一个item为当前的第一个item,所以从第二个开始打招呼
  list_.get(1).performAction(AccessibilityNodeInfo.ACTION_CLICK);
  list_.get(1).getParent().performAction(AccessibilityNodeInfo.ACTION_CLICK);
  }
  }).start();
  }
 }
 }
 } else if (event.getClassName().equals("com.tencent.mm.plugin.profile.ui.ContactInfoUI") && eventType == AccessibilityEvent.TYPE_WINDOW_STATE_CHANGED) {
 if (prepos == 1) {
 //从打招呼界面跳转来的,则点击返回到附近的人页面
 performGlobalAction(AccessibilityService.GLOBAL_ACTION_BACK);
 i++;
 } else if (prepos == 0) {
 //从附近的人跳转来的,则点击打招呼按钮
 AccessibilityNodeInfo nodeInfo = getRootInActiveWindow();
 if (nodeInfo == null) {
  Log.w(TAG, "rootWindow为空");
  return;
 }
 List<AccessibilityNodeInfo> list = nodeInfo.findAccessibilityNodeInfosByText("打招呼");
 if (list.size() > 0) {
  list.get(list.size() - 1).performAction(AccessibilityNodeInfo.ACTION_CLICK);
  list.get(list.size() - 1).getParent().performAction(AccessibilityNodeInfo.ACTION_CLICK);
 } else {
  //如果遇到已加为好友的则界面的“打招呼”变为“发消息",所以直接返回上一个界面并记录打招呼人数+1
  performGlobalAction(AccessibilityService.GLOBAL_ACTION_BACK);
  i++;
 }
 }
 } else if (event.getClassName().equals("com.tencent.mm.ui.contact.SayHiEditUI") && eventType == AccessibilityEvent.TYPE_WINDOW_STATE_CHANGED) {
 //当前在打招呼页面
 prepos = 1;
 //输入打招呼的内容并发送
 inputHello(hello);
 openNext("发送");
 }
 //自动从桌面打开微信,利用微信多开助手可实现多个微信账号之间的切换
// if(topActivity.equals("com.huawei.android.launcher.Launcher")){
// openNext(event,"微信");
// AccessibilityNodeInfo nodeInfo = getRootInActiveWindow();
// nodeInfo.getChildCount();
// for (int i=0;i<nodeInfo.getChildCount();i++){
// String name=nodeInfo.getChild(i).getViewIdResourceName();
// }
// }
 }

 /**
 * 打开通知栏消息
 */
 private void openNotification(AccessibilityEvent event) {
 if (event.getParcelableData() == null || !(event.getParcelableData() instanceof Notification)) {
 return;
 }
 //以下是精华,将微信的通知栏消息打开
 Notification notification = (Notification) event.getParcelableData();
 PendingIntent pendingIntent = notification.contentIntent;
 try {
 pendingIntent.send();
 } catch (PendingIntent.CanceledException e) {
 e.printStackTrace();
 }
 }

 /**
 * 点击匹配的nodeInfo
 * @param str text关键字
 */
 private void openNext(String str) {
 AccessibilityNodeInfo nodeInfo = getRootInActiveWindow();
 if (nodeInfo == null) {
 Log.w(TAG, "rootWindow为空");
 return;
 }
 List<AccessibilityNodeInfo> list = nodeInfo.findAccessibilityNodeInfosByText(str);
 Log.d("name", "匹配个数: " + list.size());
 if (list.size() > 0) {
 list.get(list.size() - 1).performAction(AccessibilityNodeInfo.ACTION_CLICK);
 list.get(list.size() - 1).getParent().performAction(AccessibilityNodeInfo.ACTION_CLICK);
 }
// if ("com.tencent.mm.plugin.luckymoney.ui.LuckyMoneyReceiveUI".equals(event.getClassName())) {
// //点中了红包,下一步就是去拆红包
// checkKey1();
// } else if ("com.tencent.mm.plugin.luckymoney.ui.LuckyMoneyDetailUI".equals(event.getClassName())) {
// //拆完红包后看详细的纪录界面
// } else if ("com.tencent.mm.ui.LauncherUI".equals(event.getClassName())) {
// //在聊天界面,去点中红包
// checkKey2();
// }
 }

 //延迟打开界面
 private void openDelay(final int delaytime, final String text) {
 new Thread(new Runnable() {
 @Override
 public void run() {
 try {
  Thread.sleep(delaytime);
 } catch (InterruptedException mE) {
  mE.printStackTrace();
 }
 openNext(text);
 }
 }).start();
 }

 //自动输入打招呼内容
 private void inputHello(String hello) {
 AccessibilityNodeInfo nodeInfo = getRootInActiveWindow();
 //找到当前获取焦点的view
 AccessibilityNodeInfo target = nodeInfo.findFocus(AccessibilityNodeInfo.FOCUS_INPUT);
 if (target == null) {
 Log.d(TAG, "inputHello: null");
 return;
 }
 ClipboardManager clipboard = (ClipboardManager) getSystemService(CLIPBOARD_SERVICE);
 ClipData clip = ClipData.newPlainText("label", hello);
 clipboard.setPrimaryClip(clip);
 if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN_MR2) {
 target.performAction(AccessibilityNodeInfo.ACTION_PASTE);
 }
 }

 @Override
 public void onInterrupt() {
 Toast.makeText(this, "服务已中断", Toast.LENGTH_SHORT).show();
 }

 @Override
 protected void onServiceConnected() {
 super.onServiceConnected();
 Toast.makeText(this, "连接服务", Toast.LENGTH_SHORT).show();
 }

 @Override
 public void onCreate() {
 super.onCreate();
 createFloatView();
 }

 WindowManager wm;
 Button floatbtn;

 //创建悬浮按钮
 private void createFloatView() {
 WindowManager.LayoutParams pl = new WindowManager.LayoutParams();
 wm = (WindowManager) getSystemService(getApplication().WINDOW_SERVICE);
 pl.type = WindowManager.LayoutParams.TYPE_PHONE;
 pl.format = PixelFormat.RGBA_8888;
 pl.flags = WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE;
 pl.gravity = Gravity.RIGHT | Gravity.BOTTOM;
 pl.x = 0;
 pl.y = 0;

 pl.width = 200;
 pl.height = 200;

 LayoutInflater inflater = LayoutInflater.from(this);
 floatbtn = (Button) inflater.inflate(R.layout.floatbtn, null);
 wm.addView(floatbtn, pl);

 floatbtn.setOnClickListener(this);

 }

 @Override
 public void onClick(View v) {
 if (startFunc2) {
 floatbtn.setText("启用加人");
 } else {
 floatbtn.setText("停止加人");
 }
 startFunc2 = !startFunc2;
 }
}

启用这个服务的代码:

//打开系统设置中辅助功能
Intent intent = new Intent(android.provider.Settings.ACTION_ACCESSIBILITY_SETTINGS);
startActivity(intent);

添加权限:

<uses-permission android:name="android.permission.BIND_ACCESSIBILITY_SERVICE" />

demo地址:点击打开链接

本文已被整理到了《Android微信开发教程汇总》,《java微信开发教程汇总》欢迎大家学习阅读。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android Service的启动过程分析

    Android Service的启动过程分析 刚开始学习Service的时候以为它是一个线程的封装,也可以执行耗时操作.其实不然,Service是运行在主线程的.直接执行耗时操作是会阻塞主线程的.长时间就直接ANR了. 我们知道Service可以执行一些后台任务,是后台任务不是耗时的任务,后台和耗时是有区别的喔. 这样就很容易想到音乐播放器,天气预报这些应用是要用到Service的.当然如果要在Service中执行耗时操作的话,开个线程就可以了. 关于Service的运行状态有两种,启动状态和绑

  • Android AccessibilityService实现微信抢红包插件

    在你的手机更多设置或者高级设置中,我们会发现有个无障碍的功能,很多人不知道这个功能具体是干嘛的,其实这个功能是为了增强用户界面以帮助残障人士,或者可能暂时无法与设备充分交互的人们 它的具体实现是通过AccessibilityService服务运行在后台中,通过AccessibilityEvent接收指定事件的回调.这样的事件表示用户在界面中的一些状态转换,例如:焦点改变了,一个按钮被点击,等等.这样的服务可以选择请求活动窗口的内容的能力.简单的说AccessibilityService就是一个后

  • Android IntentService详解及使用实例

    Android IntentService详解 一.IntentService简介 IntentService是Service的子类,比普通的Service增加了额外的功能.先看Service本身存在两个问题: Service不会专门启动一条单独的进程,Service与它所在应用位于同一个进程中: Service也不是专门一条新线程,因此不应该在Service中直接处理耗时的任务: 二.IntentService特征 会创建独立的worker线程来处理所有的Intent请求: 会创建独立的wor

  • Android Service类与生命周期详细介绍

    Android  Service类与生命周期 Service是Android四大组件与Activity最相似的组件,都代表可执行的程序,区别在于Service一直在后台运行且没有用户界面. 1.Service的类图和生命周期 先来看看Service的类图: 接下来看看Service的生命周期: 2.开发Service (1)开发Service需要两步: 第1步:定义子类,继承Service 第2步:在AndroidManifest.xml文件中配置Service (2)创建Service pub

  • android使用NotificationListenerService监听通知栏消息

    NotificationListenerService是通过系统调起的服务,在应用发起通知时,系统会将通知的应用,动作和信息回调给NotificationListenerService.但使用之前需要引导用户进行授权.使用NotificationListenerService一般需要下面三个步骤. 注册服务 首先需要在AndroidManifest.xml对service进行注册. <service android:name=".NotificationCollectorService&q

  • 详解Android中的Service

    Service简介: Service是被设计用来在后台执行一些需要长时间运行的操作. Android由于允许Service在后台运行,甚至在结束Activity后,因此相对来说,Service相比Activity拥有更高的优先级. 创建Service: 要创建一个最基本的Service,需要完成以下工作:1)创建一个Java类,并让其继承Service 2)重写onCreate()和onBind()方法 其中,onCreate()方法是当该Service被创建时执行的方法,onBind()是该S

  • Android 如何保证service在后台不被kill

    Android 其实无法做多绝对的不被后台kill掉,我们只能尽量使用一些操作提升不被kill的机会. 一.onStartCommand方法,返回START_STICKY START_STICKY 在运行onStartCommand后service进程被kill后,那将保留在开始状态,但是不保留那些传入的intent.不久后service就会再次尝试重新创建,因为保留在开始状态,在创建     service后将保证调用onstartCommand.如果没有传递任何开始命令给service,那将

  • Android Service中使用Toast无法正常显示问题的解决方法

    本文实例讲述了Android Service中使用Toast无法正常显示问题的解决方法.分享给大家供大家参考,具体如下: 在做Service简单练习时,在Service中的OnCreate.OnStart.OnDestroy三个方法中都像在Activity中同样的方法调用了Toast.makeText,并在Acitivy中通过两个按钮来调用该服务的onStart和onDestroy方法: DemoService代码如下: @Override public void onCreate() { su

  • Android基于service实现音乐的后台播放功能示例

    本文实例讲述了Android基于service实现音乐的后台播放功能.分享给大家供大家参考,具体如下: Service是一个生命周期长且没有用户界面的程序,当程序在各个activity中切换的时候,我们可以利用service来实现背景音乐的播放,即使当程序退出到后台的时候,音乐依然在播放.下面我们给出具体例子的实现: 当然,首先要在资源文件夹中添加一首MP3歌曲: 要实现音乐的播放,需要在界面中放置两个按钮,用来控制音乐的播放和停止,通过使用startService和stopService来实现

  • Android实现微信自动向附近的人打招呼(AccessibilityService)

    学习功能强大的AccessibilityService!!! 以下是本人根据自动抢红包的实现思路敲的用于微信自动向附近的人打招呼的核心代码 public class AutoService extends AccessibilityService implements View.OnClickListener { private static final String TAG = "test"; /** * 微信的包名 */ static final String WECHAT_PAC

  • Android实现微信自动抢红包的程序

    简单实现了微信自动抢红包的服务,原理就是根据关键字找到相应的View, 然后自动点击.主要是用到AccessibilityService这个辅助服务,基本可以满足自动抢红包的功能,但是有些逻辑需要优化,比如,拆完一个红包后,必须手动点击返回键,才能进行下一次自动抢红包. AndroidManifest.xml <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="h

  • Android微信自动抢红包插件优化和实现

    又是兴趣系列 网上有很多自动强红包的例子和代码,笔者也是做了一些优化. 先说说自己的两个个优势 1.可以在聊天界面自动强不依赖于通知栏推送 2.可以在屏幕熄灭的时候的时候点亮屏幕自动抢(目前只测过flyme) 先上图: 代码传送门: https://github.com/AndroidMsky/WXhongbao 欢迎点星星~ 原理: 通过AccessibilityService监听到状态栏通知,进行模拟点击,获取屏幕中view节点为领取红包的list并且点击最后一个. 如果不通过状态栏通知,通

  • 教你一步步实现Android微信自动抢红包

    本文介绍微信自动抢红包的实现方法,主要实现以下几个功能: 1.自动拆开屏幕上出现的红包 2.处于桌面或聊天列表时接收到红包信息时自动进入聊天界面并拆红包 3.日志功能,记录抢红包的详细日志 实现原理 1.利用AccessibilityService辅助服务,监测屏幕内容,实现自动拆红包的目的. 2.利用ActiveAndroid数据库简单记录红包日志 3.利用preference实现监控选项纪录 最终界面 抢红包核心代码 AccessibilityService配置 android:access

  • Android中微信抢红包插件原理解析及开发思路

    一.前言 自从去年中微信添加抢红包的功能,微信的电商之旅算是正式开始正式火爆起来.但是作为Android开发者来说,我们在抢红包的同时意识到了很多问题,就是手动去抢红包的速度慢了,当然这些有很多原因导致了.或许是网络的原因,而且这个也是最大的原因.但是其他的不可忽略的因素也是要考虑到进去的,比如在手机充电锁屏的时候,我们并不知道有人已经开始发红包了,那么这时候也是让我们丧失了一大批红包的原因.那么关于网络的问题,我们开发者可能用相关技术无法解决(当然在Google和Facebook看来的话,他们

  • Android版微信跳一跳小游戏利用技术手段达到高分的操作方法

    本文主要来讲个个好玩的东西,近来微信刚出的跳一跳微信小程序的游戏很火,看到很多人都达到了二三百分就各种刷朋友圈了. 甩手一个表情 最终我们达到的分数却是这样的: 羡慕吧 一定会有人拍手叫好,"黄金右手"!说真的,我已经不用右手好多年,而且我玩这个游戏压根就没用手,而是意念!哈哈,别喷我,开个玩笑而已,肯定是利用技术手段啦,什么技术?python喽-哈哈,不过不是我写的,我自己是做Android开发的,我对于python从来没有接触,只是恰好在蛋哥公众号看到关于这个游戏的文章,觉得有意思

  • Android 类似微信登录输入框效果

    微信的登录输入框效果如下 进入自动打开自动启动软键盘 点击下一个输入框,下划线颜色改变 怎么实现这样的效果呢,其实非常简单! 简单的布局我就不说了,直接上干货. 1.实现进入自动弹出软键盘,在根文件中的Activity中设置 windowSoftInputMode 属性为 stateVisible|adjustResize 例如 <activity android:name=".SetLoginPasswordActivity" android:windowSoftInputMo

  • Android仿微信底部按钮滑动变色

    Android仿微信底部按钮滑动变色,这里只针对使用Fragment为Tab页的滑动操作,进行简单的变色讲解. 首先说下OnPageChangeListener这个监听 //这个监听有三个方法 public abstract void onPageScrollStateChanged (int state) public abstract void onPageScrolled (int position, float positionOffset, int positionOffsetPixe

  • Android 实现微信,微博,微信朋友圈,QQ分享的功能

    Android 实现微信,微博,微信朋友圈,QQ分享的功能 一.去各自所在的开发者平台注册相应的Key值:引入相关jar包.权限等 二.ShareUtil工具类 import android.app.Activity; import android.content.Context; import android.content.pm.PackageInfo; import android.content.pm.PackageManager; import android.graphics.Bit

  • Android开发微信APP支付功能的要点小结

    基本概念 包名值得是你APP的包,在创建工程时候设置的,需要在微信支付平台上面设置. 签名指的是你生成APK时候所用的签名文件的md5,去掉:全部小写,需要在微信支付平台上面设置. 调试阶段,签名文件可以使用调试用的debug.keystore,签名可以直接在eclipse上面查看,或者用工具查看 ,安装打开输入包名即可查看. 发布的时候一定需要在微信支付平台上面设置成发布用的签名值. 官方的Demo里面的内容并不是全是必须的,甚至只需要有libammsdk.jar就够了,AndroidMani

随机推荐