从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


相关文章
|
7月前
|
小程序 索引 容器
微信小游戏制作工具中的滚动列表插件如何使用?
微信小游戏制作工具中的滚动列表插件如何使用?
175 1
|
7月前
|
JavaScript 前端开发 测试技术
移动端(APP)自动化脚本工具详细列举(autojs、easyclick、hamibot、ctrljs ...)
移动端(APP)自动化脚本工具详细列举(autojs、easyclick、hamibot、ctrljs ...)
2342 0
|
2月前
|
移动开发 小程序 数据可视化
DIY可视化导出源码整合uniapp环境搭建+调试+运行发布
DIY可视化导出源码整合uniapp环境搭建+调试+运行发布
71 0
|
4月前
|
数据可视化 API 开发工具
影创SDK☀️三、工程默认配置,及基础测试建议
影创SDK☀️三、工程默认配置,及基础测试建议
|
4月前
|
图形学 iOS开发
Unity与IOS⭐最基础的交互演示
Unity与IOS⭐最基础的交互演示
|
7月前
|
数据可视化 测试技术 API
阅读源码有哪些好方式与好步骤
阅读源码是理解软件工作原理的关键。首先,了解背景、目的和技术栈。从文件头部的文档注释开始,逐步深入到复杂代码。利用Git、调试器和分析工具辅助理解。保持批判性思维,质疑代码设计并验证理解。拆分代码块,画图展示结构,使用版本控制追踪变更。搜索、阅读文档、API和单元测试以深化理解。参与讨论,做笔记,回顾历史版本,了解上下文,并通过实践加强领悟。每个人的方法可能不同,关键是持续学习和适应。
68 1
|
7月前
|
前端开发 数据库 Nacos
|
JavaScript
移动端也能兼容的web页面制作1:MDBootstrap演示Demo运行演示
移动端也能兼容的web页面制作1:MDBootstrap演示Demo运行演示
275 0
|
开发工具 iOS开发 git
iOS 开发 - 亲身经历告诉你如何把自己的库通过pod导入(详细步骤)
iOS 开发 - 亲身经历告诉你如何把自己的库通过pod导入(详细步骤)
326 0
iOS 开发 - 亲身经历告诉你如何把自己的库通过pod导入(详细步骤)