首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >【Auto.js】使用Pro 8.0 API优化图色或无障碍的耗电问题

【Auto.js】使用Pro 8.0 API优化图色或无障碍的耗电问题

作者头像
红目香薰
发布2022-11-29 10:34:50
发布2022-11-29 10:34:50
1.5K0
举报
文章被收录于专栏:CSDNToQQCodeCSDNToQQCode

由于Auto.js目前的API都是同步的,要在屏幕中搜索某张图色或者某个控件时,必须无限循环查找,这实际上非常耗电。由于Rhino的限制,Auto.js无法直接提供异步API,这让Auto.js的脚本天生有一些缺陷。

为了解决这些问题,Auto.js Pro 8.0.0-3引入了两个新的API,来尽量减少图色模块和控件模块使用时的耗电。

图色模块的耗电优化

requestScreenCapture(options)

  • options {Object}
    • async {Boolean} 是否以异步事件的形式提供截图
    • width {Number} 截图宽度
    • height {Number}} 截图高度
    • orientation {String} 屏幕方向,"landscape"为横屏,"portrai"为竖屏,"auto"为自动

请求截图权限的参数中,增加了async的参数,这个参数运行我们以异步的方式,来获取屏幕截图。在以前,我们通过captureScreen()函数来获取截图,并无限循环地寻找目标图片,比如:

代码语言:javascript
复制
// 请求截图权限
requestScreenCapture();
// 读取目标图片
let target = $images.read("./test.png");
while (true) {
    // 获取屏幕截图
    let capture = $images.captureScreen();
    // 找图
    let pos = $images.findImage(capture, target);
    // 打印
    console.log(pos);
}

而使用async参数后,我们可以在"screen_capture"事件中获取到图片,例如:

代码语言:javascript
复制
// 请求截图权限, 注意参数 async: true
requestScreenCapture({async: true});
// 监听屏幕截图
$images.on("screen_capture", capture => {
    // 找图
    let pos = $images.findImage(capture, target);
    // 打印
    console.log(pos);
});

使用这样的方式,我们可以只在屏幕刷新时通过事件screen_capture唤醒代码,获取到最新的屏幕截图,并寻找目标图片。

实测在普通软件界面的找图中,CPU使用率减少了75%左右。

无障碍功能的耗电优化

与找图找色类似,在以前,Auto.js也一直只能通过无限循环去判断当前界面、寻找控件,这实际上对省电优化十分不友好。在Pro 8.0.0-3版本,我们引入了监听无障碍事件的API。

auto.registerEvents(events)

  • events {Array} 要监听的事件数组
  • 返回 {EventEmitter}

auto.registerEvent(event, callback)

  • event {String} 要监听的事件
  • callback {Function} 事件回调
  • 返回 {EventEmitter}

以上两个函数用于监听一个或多个无障碍事件。所谓无障碍事件,即(其他软件)窗口发送变化、控件发送变化时的事件,包括:

  • view_clicked 控件被点击
  • view_long_clicked 控件被长按点击
  • view_selected 控件被选中
  • view_focused 控件成为焦点
  • view_text_changed 控件文本改变
  • view_scrolled 控件被滑动
  • window_state_changed 窗口状态变化
  • window_content_changed 窗口内容变化
  • window_changed 屏幕上显示窗口的变化(增加,删除,子窗口变化等)
  • notification_state_changed 通知状态变化

例如,我们要监听Auto.js的打开,可以用以下代码监听:

代码语言:javascript
复制
// 监听窗口变化
auto.registerEvent('windows_changed', e => {
    // 判断是否有新窗口打开
    if (e.windowChanges.indexOf('add') >= 0) {
        // 获取新窗口的id
        let wid = e.windowId;
        // 遍历窗口,获取新窗口
        let window = auto.windows.filter(w => w.id == wid);
        // 判断新窗口是Auto.js
        if (window.length >= 0 && window[0].title == 'Auto.js') {
            toast("Auto.js被打开了!");
        }
    }
});
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-03-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 图色模块的耗电优化
    • requestScreenCapture(options)
  • 无障碍功能的耗电优化
    • auto.registerEvents(events)
    • auto.registerEvent(event, callback)
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档