Skip to content

基于 Autojs 的 APP、小程序自动化测试 SDK,支持:判断存在、等待出现、文本或颜色点击、循环点击、坐标拾取、语音播报等数十项能力。

License

Notifications You must be signed in to change notification settings

kangour/autojs_sdk

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

autojs sdk

基于 Autojs 的 APP、小程序自动化测试 SDK,支持:启动应用、停留等待、判断存在、文本点击、颜色点击、循环点击、坐标拾取、语音播报、通知栏提示、音量调节、震动等数十项能力。

autojs sdk 在 Auto.js 的基础上,通过大量接口优化提升了模块的通用性,并进行丰富的功能扩展。

运行环境下载

下载方式:sdk 测试阶段请加群下载 autojs 运行环境。

群号:984025847

能干啥

使用 autojs sdk,一行代码就能完成 语音播报/任意类型文本点击/循环点击/坐标拾取/自动权限控制/自动类型识别/自动按键监听/通知栏实时提示/自动移除最近任务/自动解锁 等数十项能力,更多能力陆续开放中。

简单上手

编写基于 auto sdk 的应用前,请将 lib.js 放在脚本目录。

分为三个步骤,用 require('lib.js') 引入 auto_sdk,编写主函数 main(),然后传入 start_app()

这里展示仅用 5 行代码(主函数)开发一个音乐播放应用,实现的功能有 自动解锁/启动网易云音乐/播放每日推荐歌曲/调节音量/通知栏提示操作状态

// 导入:从 auto sdk 导入需要的方法
let lib = require('lib.js')
start_app = lib.start_app
click_item = lib.click_item
set_volume = lib.set_volume
wait_befor_click = lib.wait_befor_click

// 编写主函数:程序启动后执行的逻辑代码。
function main() {
    wait_befor_click('发现', '跳过')
    click_item('发现')
    click_item('每日推荐')
    click_item('播放全部')
    set_volume(30)
}

// 启动应用:传入参数依次为:主函数,要启动的 App 名称,当前应用描述,是否语音播报执行状态。
start_app(main, '网易云音乐', '播放日推', true)

开放的方法

    start_app: start_app, // 脚本运行的前置+后置自动化操作,包括屏幕解锁,自动按键监听,移出最近任务,启动 App,执行脚本,结束进程等。
    wait_for: wait_for, // 等待文本出现
    has_text: has_text, // 当前屏幕是否存在文本
    vibrate: vibrate, // 设备震动
    say_hi: say_hi, // 获取问候语
    log: log, // 普通日志
    warn: warn, // 警告日志
    error: error, // 错误日志
    verbose: verbose, // 调试日志
    time2str: time2str, // 时间转字符串
    time2date: time2date, // 时间转日期
    random_sleep: random_sleep, // 0 到 200 s 随机睡眠
    total_seconds_delta: total_seconds_delta, // 获取倒计时
    click_item: click_item, // 任意类型的文本点击
    click_color: click_color, // 颜色点击
    click_id: click_id,
    click_item_each: click_item_each, // 任意类型的文本循环点击
    click_color_each: click_color_each, // 颜色循环点击
    wait_befor_click: wait_befor_click, // 接口描述:等待某文本出现之前的点击。 场景举例:启动网易云音乐时,等待首页出现之前,点击跳过按钮 wait_befor_click('我的', '跳过')
    get_coord_by_color: get_coord_by_color, // 通过颜色获取坐标
    get_coord_by_text: get_coord_by_text, // 获取文本坐标,文本点击时自动调用
    get_last_month: get_last_month, // 获取上个月月份
    get_year: get_year, // 获取年份
    get_month: get_month, // 获取月份
    get_date: get_date, // 返回日期
    get_day: get_day, // 返回星期
    get_hours: get_hours, // 返回小时
    get_minutes: get_minutes, // 返回分钟
    get_seconds: get_seconds, // 返回秒
    set_volume: set_volume, // 设置设备音量
    set_runing_tip: set_runing_tip, // 通知栏提示内容设置
    key_event: key_event, // 音量加结束脚本
    string2date: string2date, // 字符串转日期
    get_last_month_year: get_last_month_year, // 获取上个月的年份
    count_work_day: count_work_day, // 获取工作天数
    set_runing_tip_position: set_runing_tip_position, // 设置状态栏位置

高频函数介绍

入口函数

start_app(callback, op_app, this_app, use_tts)

程序入口函数,自动完成解锁、启动 App、权限控制、按键监听、通知栏提示等操作。

  • callback:软件启动后执行的函数,如 main
  • operation_app:需要启动的软件,如 网易云音乐
  • this_app:当前程序的描述,如 播放每日推荐
  • use_tts:执行完毕后是否使用语音提示(默认不启用)

文本点击

click_item(_text, tip_type)

自动识别文本类型,并点击文本。

  • _text: 待点击的文本
  • tip_type:提示类型,如果传入 no_tip,则不会在文字寻找失败后给出提示弹窗(默认启用)

颜色点击

click_color(_color, x, y, w, h)

在指定的区域点击传入的颜色

  • _color:待点击的颜色
  • x:区域左上角的 x 坐标
  • y:区域左上角的 y 坐标
  • w:区域宽度
  • h:区域高度

等待前点击

    wait_befor_click(target, source)

在 target 出现前,如果出现 source,就点击。

例如进入有开屏广告的应用前,点击 “跳过广告” 文本,有效节约启动时间:

wait_befor_click('首页', '跳过')

开发者的话

还有很多函数等待你去发掘,比如日期时间处理,日志,坐标处理,震动,音量调节等能力,均可参考 auto_sdk/lib.js 的函数注释,同时也希望你能和我一起来完善它,一起构建一个最流行、最好用的工具;你可以将自己基于 auto_lib 编写的应用提交到 example 目录下。

项目交流群

auto_lib 群:984025847

项目主页

https://github.com/laobingm/autojs_sdk

About

基于 Autojs 的 APP、小程序自动化测试 SDK,支持:判断存在、等待出现、文本或颜色点击、循环点击、坐标拾取、语音播报等数十项能力。

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published