从0到1,教你如何使用Tasker+Autojs实现自动打卡功能

简介: 从0到1,教你如何使用Tasker+Autojs实现自动打卡功能

你是否有上下班总会忘记打卡或者迟到的困扰,这篇文章将带你感受一下自动化工具+JS的魅力

首先声明:本文章不针对任何第三方软件,文章中的脚本只做学习,不做商用,侵删

准备工作:


安卓手机或模拟器,最好使用模拟器(推荐夜神模拟器安卓7的64位),因为手机条件会比较苛刻(需要root,和谷歌三件套)

Auto.js软件,或者其衍生产品AutoX.js

Tasker,中文站,原网站

需要自动执行的软件,我用的是 *人薪事

首先,咱们熟悉一下Auto.js的调试,官方文档已经写的很清楚了,我主要概述一下抓取组件调试的过程

以AutoX.js为例,VScode安装Auto.js-VSCodeExt-Fixed插件,按住ctrl+shift+p,输入auto即可进入插件的工具菜单,选择 ‘开启服务’,复制右下角服务ip及端口,就可以等待移动端连接了


1.png1.png


如果是用手机连接,需要开启:开发者工具>USB调试,模拟器则直接打开AutoXjs侧边栏的连接电脑,输入之前复制的服务ip及端口,开启调试模式


1.png1.png


打开悬浮窗,用于应用控件的抓取


1.png1.png


以Tasker为例,点击悬浮窗的 ‘布局分析’ ,选择布局范围分析,AutoXjs会将当前页面中的可操作控件列举出来,此时通过js代码进行事件操作即可实现自动化控制


1.png1.png1.png


以搜索框为例,我们实现一个 模拟搜索 的诉求

1.png


根据官方文档,我们可以简单实现该功能

const appName = "Tasker",
  getSearchBtn = () => desc("搜索 Tasker"), //搜索按钮,desc文本查找控件
  getSearchInput = () => id("filter_text"), //输入框
  startSearchBtn = () => id("search"), //开始查询按钮
  str = "打卡";
console.log("launchApp:" + appName, launchApp(appName)); //打开Tasker app
console.log("getSearchBtn", getElem(getSearchBtn()).click()); //点击搜索按钮
console.log("getSearchInput", getElem(getSearchInput()).setText(str)); //输入关键字
console.log("startSearchBtn", getElem(startSearchBtn()).click()); //点击开始搜索按钮
function getElem(ele) {
  return ele.findOne();
}

效果如下:

1.png

接着,咱们照葫芦画瓢,参照文档使用模拟动作实现操控其他软件的功能,比如每次执行脚本时,都会自动在打卡软件中打卡(源码放在结尾)


image.png


AutoX.js已经帮助我们实现了半自动打卡,距离我们的目标又近了一步


下面我们需要使用Tasker配合AutoX.js达到触发某(些)条件时打卡即可


打开tasker,新建任务test


1.gif


在任务编辑中新建系统操作>发送意图,这里我新建了一个android.intent.action.tasker的广播,用于和AutoX交互


1.png1.png1.png


我们在AutoX中新建一个脚本触发事件,当有应用触发android.intent.action.tasker时,执行这个打卡脚本


1.png1.png1.png1.png


然后我们在Tasker中运行这个任务用来触发AutoX执行脚本


至此,使用Tasker连接AutoX这块已经完成,接下来就是触发任务的条件了

既然是自动打卡,肯定与时间地点有关系。所以,我们在Tasker的配置文件中新建配置,配置时间,和地点(需要谷歌三件套),并选择任务,当达到特定时间地点时,Tasker就会触发打卡脚本


1.png


写在最后:


使用Tasker+Autojs实现打卡固然好用,但是其对手机要求较高,如果你的手机恰好root,并装了谷歌三件套,使用起来会比较方便。其他同学推荐使用安卓模拟器实现。


源码:myCode: 一些小案例 - Gitee.com


相关文章
|
2月前
基于AutoJs的94自动运行脚本
基于AutoJs的94自动运行脚本
58 0
|
2月前
|
JavaScript 前端开发 测试技术
移动端(APP)自动化脚本工具详细列举(autojs、easyclick、hamibot、ctrljs ...)
移动端(APP)自动化脚本工具详细列举(autojs、easyclick、hamibot、ctrljs ...)
1201 0
|
11月前
|
Web App开发 缓存 JavaScript
待补充 | ​Chrome调试工具常用功能整理
待补充 | ​Chrome调试工具常用功能整理
|
前端开发 小程序 数据安全/隐私保护
|
数据可视化 安全 测试技术
Postcat 插件上线,支持 ApiPost 格式导入
最近我们的插件广场上线了一款由我们的社区共建者开发的 ApiPost 插件,安装即可支持导入 ApiPost 格式的数据,操作方法也很简单呢。
Postcat 插件上线,支持 ApiPost 格式导入
|
JavaScript
移动端也能兼容的web页面制作1:MDBootstrap演示Demo运行演示
移动端也能兼容的web页面制作1:MDBootstrap演示Demo运行演示
254 0
|
存储 小程序 Java
【笔记11】uniapp点击复制;mysql数据库存储emoji表情;Java 二维码生成;uniapp引入自定义图标
做公司的项目,给微信小程序体验版添加了新的页面,提交测试的时候没有任何效果。上网搜索了解后,知道:若 pages.json 文件发生了变化,尤其是首页路径发生了变化。代码上传成功后,需要在后台手动设置一下首页路径,或者取消体验版,重新生成体验版二维码。
587 0
【笔记11】uniapp点击复制;mysql数据库存储emoji表情;Java 二维码生成;uniapp引入自定义图标
|
开发工具 Android开发
XQRCode 一个非常方便实用的二维码扫描、解析、生成库
XQRCode 一个非常方便实用的二维码扫描、解析、生成库
528 0
XQRCode 一个非常方便实用的二维码扫描、解析、生成库
|
Web App开发
Chrome插件Vimium的基础用法
Chrome插件Vimium的基础用法
816 0
|
数据库
【自然框架】——Demo的源代码下载(2009-11-2更新)
 最新下载地址:自然框架的源代码、Demo、数据库、配置信息管理程序下载(2010.01.25更新)    数据库是SQLServer2005的,下载解压后附加数据库。 然后需要在web.config里面根据您的情况设置连接字符串。
833 0