为了解决这些问题,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()函数来获取截图,并无限循环地寻找目标图片,比如:
// 请求截图权限
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"事件中获取到图片,例如:
// 请求截图权限, 注意参数 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的打开,可以用以下代码监听:
// 监听窗口变化
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被打开了!")
}
}
})
点击阅读全文
打开CSDN APP,看更多技术内容
autojs手机端截图取色助手.apk
青咖脚本autojs多功能截图取色识别颜色工具青咖网auto.js免root引流脚本专用找图找色工具分享
zulu8.33.0.1-jdk8.0.192-win_x64.msi
zulu8.33.0.1-jdk8.0.192-win_x64.msi
最新发布 AUTOJS】9.0去限制找控件
autojs去限制
继续访问
MySql.Data.dll8.0类库
用于mysql8.0版本的MySql.Data.dll类库,直接引用使用
用于mysql8.0版本的MySql.Data.dll类库,直接引用使用
用于mysql8.0版本的MySql.Data.dll类库,直接引用使用
app_autojs_4_1_1.zip
1) autojs 安装 apk 版本 4_1_1 2) 包含 autojs 本身安装apk 和 打包 脚本成apk 文件的插件
Auto.JS函数requestScreenCapture()采坑小结一requestScreenCapture()不能多次调用
今天写了一个脚本,遇到些问题与大家分享。脚本需要找图代码如下(注意标识位置) function zhaotu(tpname,regx,regy ,regwidth,regheight){ requestScreenCapture()//注意这个位置 pd=nullvar tp = images.read(tpname) toast("tupian:"+tp)sleep(3000)pd =findImage( cap
继续访问
Auto.js实现自动授权截屏权限
写在前面: 本文章记录自己在开发过程中,遇到的基础问题,也同样便于在以后的开发中获得便利。 如果你是初学Auto.js开发,建议可以读这篇文章Auto.js入门【超基础】,该文章是我入门时拜读的作品,整体感觉很好,基本内容都有所讲到,完全可以适合新手做出一些简单的脚本自用。 一、开发文档 在开发文档中该方法也提到,有些系统是没有保持始终允许的选项的,题主也是遇到了这个问题,因为写的脚本时定时运行的,不可能自己再手动授权,所以自己写了一个能够自动授权方法,还有很多不足的地方,希望大家可以斧正。 二、进阶方法
继续访问
Android 9.0 Auto及m4 core倒车逻辑--基于imx8qm
新板子car版本android系统收不到m4发送的资源释放消息,屏不亮,先分析一下逻辑关系。 上图就是car版本AP核和M41核之间的倒车逻辑。 阶段1 系统启动完毕 mek_8q.mk 63: $(IMX_DEVICE_PATH)/init_car_m4.rc:$(TARGET_COPY_OUT_VENDOR)/etc/init/hw/init.car_additional.rc 68: $(IMX_DEVICE_PATH)/init_car_no_m4.rc:$(TARGET_COPY_O.
继续访问
【Auto.js】[系统Intent]_系统设置页面的相关intent跳转
收集了一些系统设置界面的Intent跳转,只收集了不传值,可直接调用一些参数 var intent = new Intent()// vpnIntent.setAction("android.net.vpn.SETTINGS")intent.setAction("android.settings.ACCESSIBILITY_SETTINGS")//辅助功能 intent.setAction("android.settings.ADD_ACCOUNT_SETTINGS")//添加账户 in
继续访问
Auto.js找图找色常用功能
1. 颜色的表示方法 颜色表示方式一:"#AARRGGBB",需要表示透明度的时候用这种方法。 颜色表示方式二:"#RRGGBB",不需要表示透明度的时候用这种方法。 AA 是Alpha通道(透明度)的值; RR 是R通道(红色)的值; GG 是G通道(绿色)的值; BB 是B通道(蓝色)的值; 2. 颜色的转换方法 1. 返回颜色值的字符串; 2. 返回颜色的整数值; .....................
继续访问
Auto.js Pro_Pro 7.0.4-1.apk
兼容性说明 不支持安卓10以上和华为手机调试运行,推荐在小米手机上调试运行。 但是打包的脚本不分手机型号都能运行。
auto.js脚本大全
收集2000余个脚本
autojs-clipboard
本仓库主要为了, 方便手机和电脑剪贴板, 在局域网同步 同步原理 手机autojs运行mobile.js, 监听到剪贴板变化, 就发送http请求 在vscode中, 按 ctrl + shift + p, 输入clip, 点击autojs: Clipboard synchronization 剪贴板同步, 开启服务 服务开启后, vscode会监听7101端口的请求, 并提取get请求中的clipboard的值 用clipboardy设置剪贴板内容 牙叔出品, mobile.js用抠脚代码改的.
热门推荐 mysql8.0.25安装配置教程(windows 64位)最详细
目录1.官网下载MySQL2.配置初始化文件my.ini3.初始化MySQL4.安装mysql服务并启动+修改密码5.配置环境变量6.部分疑难杂病7.使用连接工具连接mysql 1.官网下载MySQL 下载Mysql点击下载mysql. 下载完成后解压到某一个文件夹(记住这个路径,一会要用到) 2.配置初始化文件my.ini 在根目录下创建一个txt文件,名字叫my,文件后缀为ini 之后复制下面这个代码放在文件下 (新解压的文件没有my.ini文件,需自行创建) 以下代码除安装目录和数据的存放目录需修
继续访问
auto js实现自动截屏
// 请求允许自动录屏 //请求截图 if(!requestScreenCapture()){ toast("请求截图失败")exit()} 连续截图 //连续截图10张图片(间隔1秒)并保存到存储卡目录 for(var i = 0i <10i++){ captureScreen("/sdcard/img" + i + ".png")...
继续访问
AutojsPro 华为手机设置
Autojs 华为手机 设置
继续访问
Auto.js Pro使用Intent跳转详细介绍
说明:此方法需要手机root。如果没有root也想使用需要用adb,给手机app一些权限才可以(此方法没测试,我直接root了。权限看我另外一篇文章)autojs无root自动无障碍启动------华为_shuishen49的博客-CSDN博客 以下是我抓的包 代码需要这么写 其实最主要的是这个表要传数据给app,必须先清楚。我也研究了好一会。 extras: {//前面是key,后面是值,class是数据类型不管他。js自己能识别。 key_router_time:
继续访问
对C语言语法复习与关键字auto,register的深度理解,看完保证你惊呼“妈妈有挂!”
首先是最宽宏大量的关键词 auto 先普及几个简单的c语言概念 便于理解 在刚开始学习c语言时 ,我们都会学习打印“helloworld”,如下代码 我们思考一下电脑是如何去编译出代码并且打印helloworld的 首先代码运行以后会通过编译器对代码进行编译与链接,其中编译分为3步,先进行预编译,后进行编译,然后进行汇编,形成。.obj文件 。obj文件再进行链接形成了.exe文件,也就是我们的应用程序。 在windows系统中双击exe文件,运行程序,会将程序加载到内存中(对,就是电..
继续访问
火山pc实现找图找色模块
利用增强位图操作模块的取坐标颜色实现找图、找色 没多少技术含量,高手勿喷 一、首先要引用增强位图类 二、引用风的模块(下载地址:火山pc找图色例子 模块-利快云源码下载 (lkuaiy.com)) 三、使用图色区域找图这个命令就可以实现图色的自动化
js用disabled属性控制input获取页面值,第一种方法: 可以添加隐藏的input标签 <input name="hiddenplanyear" id="hiddenplanyear" type="hidden" class="textfield" value=""第二种方法: <input type="text" class="input4" id="mainChkUserName" name="task.mainChkUserName" value="${sessionScope.QM_LOGIN
有的情况下,需要通过一个字符串快捷获取到 Json 或 数组Json 中指定对象的值,比如:<script>
// -------------------------- Json 测试
// 数据
const json = {
a: 'a',
b: {
c: 'c',
d: [{
e: 'e'
}],
f: [[{
g: 'g'
}]]
}
}
// 调用
console.log(GetValue(json, 'b.d[0]')) // {e: 'e'}
console.log(GetValue(json, 'b.f[0][0].g')) // g
console.log(GetValue(json, 'b.f[0[0.g')) // g
console.log(GetValue(json, 'b.f]0]0.g')) // g
console.log(GetValue(json, 'b.f.0.0.g')) // g
// -------------------------- Array 测试
// 数据
const arr = [
{
a: 'a',
b: [{
c: 'c',
d: {
e: 'e'
}
}]
}
]
// 调用
console.log(GetValue(arr, '[0].b[0].d.e')) // e
console.log(GetValue(arr, '0.b.0.d.e')) // e
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
封装方法
<script>
// 获取值
function GetValue(obj, key) {
// 当前值
var value = undefined
// 是否有值
if (obj &&key) {
// 赋值
value = obj
// 分析大括号
if (key.includes('[') || key.includes(']')) {
// 替换符号
if (key.includes('[')) {
key = key.replace(new RegExp('\\[', "gm"), '.')
key = key.replace(new RegExp('\\]', "gm"), '')
} else {
key = key.replace(new RegExp('\\]', "gm"), '.')
}
}
// 拆分
const keys = key.split('.')
// 过滤出来可用的 keys
const newKeys = []
// 过滤
keys.forEach(itemKey =>{
// 有值则添加
if (itemKey.length) { newKeys.push(itemKey) }
})
// 取值
newKeys.some(itemKey =>{
// 直接取值
if (value) { value = value[itemKey] }
// 是否停止
return !value
})
}
// 返回
return value
}
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
文章知识点与官方知识档案匹配
Python入门技能树首页概览
224156 人正在系统学习中
打开CSDN APP,看更多技术内容
js之字典的学习和使用_Ying(英子)的博客_js 字典
js之字典学习和使用 字典 是一种以键-值对形式存储数据的数据结构,比如:名字-电话号码,通过名字就能找到对应的电话号码,名字就是键(key),电话号就是值(value)。 字典中的键,是值在字典中的索引。 对于javascript来说,字典类(...
继续访问
js 获取字典的key_Python零基础入门之列表与字典_weixin_39580041的博...
字典采用键(key):值(value)形式表达数据 字典中key不允许重复,value允许重复 字典是可修改的,运行时动态调整存储空间 创建字典的两种方式 使用{}创建字典 使用dict函数创建字典 字典的取值操作 ...
继续访问
python实现提取str字符串/json中多级目录下的某个值
字符串多级目录取值: 比如说: 你response接收到的数据是这样的。 你现在只需要取到itemstring 这个字段下的值。其他的都不要! 思路就是:字符串是个json格式(或转为json格式),然后str转为字典dict,然后循环遍历按照key来取值。 你的data是个字典 然后item_list是data的Key ,item_list是个数组,这个里面的数组中的每个元素都是一个字典。 因此就是dict多级路径按key取值。 # 多级目录提取-dict print(type(response)) print(type(response.text)) result = json.loa
JS--数组和字典
JS--数组和字典 定义数组 var my_array= new Array()一、JS数组 JavaScript中的数组类似于Python的列表 https://www.cnblogs.com/bigberg/p/9237856.html 1 a = [11,22,33,44] 常见功能: 1 ...
继续访问
easyui js数据字典中获取值_SZH8023的博客_eyou能得到js...
easyui js数据字典中获取值 var CRUD = { add: function () { var hDialog = top.jQuery.hDialog({ title: '添加', width: 800, height: 600, href: formurl, iconCls: 'icon-add', //初始化添加 onLoad: function ()...
继续访问
js 获取字典的key_一份最通俗易懂的Python字典教程
一、列表的缺点当存储的数据要动态添加、删除的时候,我们一般使用列表,但是列表有时会遇到一些麻烦。# 定义一个列表保存,姓名、性别、职业 nameList = ['xiaoZhang', '男', '木匠']# 当修改职业的时候,需要记忆元素的下标 nameList[2] = '铁匠' # 如果列表的顺序发生了变化,添加年龄 nameList = ['xiaoWang', 18, '男'...
继续访问
JavaScript数据结构——字典(Dictionary)
概念和结构 字典里面的元素都是一个键(key)值(value)对。 字典里面的元素的键(key)不能重复,值(value)可以重复。 字典的操作 集合有八种常用操作,分别为 检查键是否存在 has(key) 添加元素 set(key,value) 通过键移除元素 delete(key) 由键获取值 get(key) 提取字典所有值 values() 获取全部键名 keys() 清除字典 cl...
继续访问
Python 对象与 JSON 字符串的相互转换
JSON 简介 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,它使得人们很容易的进行阅读和编写。同时也方便了机器进行解析和生成。适用于进行数据交互的场景,比如网站前台与后台之间的数据交互。 json 简单说就是 javascript 中的对象和数组,所以这两种结构就是对象和数组两种结构,通过这两种结构可以表示各种复杂的结构。 对象:对象在 js 中表示为{ }括起来的内容,数据结构为 { key:value, key:value, … }的键值对的结构
继续访问
jeesite实战(十三)——JS获取数据字典的值
系列文章目录 文章目录系列文章目录前言一、目标二、实现目标1.步骤总结 前言 本系列文章主要记录项目过程中重点的项目技术 一、目标 通过JS获得数据字典的数据,并根据实际的值获取显示的值,如下图瓦工对应数据字典的值为“0” 二、实现目标 1.步骤 实现步骤: 1.通过DictUtils工具以及数据字典的名称,获得数据字典对象,然后通过for循环的形式获得对应的中文内容 //显示的内容 var carTypevar carTypes = ${@DictUtils.getDictLis
继续访问
JS获取JSON字符串的几种方式
之前有人问了一个问题就是关于js获取json数据value值的几种方式,所以今天把一些比较常见的给总结了一下,希望能帮助到大家 <script>var obj = {id:1,name:'abd'} //js获取json字符串value的第一种方式 console.log(obj.id)//js获取json字符串value的第二种方式 console.log(obj['id'])Obje
继续访问
JavaScript通过下标获取对象(字典)指定键和值
var a = { 姓名: '张三', 性别: '男', 身高: '175cm', 体重: '65kg' } //方式一,分别得到键和值的数组 var keys = Object.keys(a) var values = Object.values(a) console.log(keys[1] + ':' + values[1]) //方式二,直接操作,更简洁一点 console.log(Object.keys(a)[2] + ':' + Object.values(a)[2]) 输出如.
继续访问
通俗易懂讲解JavaScript深拷贝和浅拷贝
基本类型和引用类型 在开始讲解JavaScript的深拷贝和浅拷贝之前,先要认识JavaScript的两种基本数据类型。一种是基本类型(值类型),另外一种是引用类型。其中基本类型包括undefined、null、number、string和boolean,这几种类型在内存中都有固定的大小和空间。引用类型包括object,这种值的大小不固定,可以动态添加属性和方法,而基本类型则不可以。 基本类型的值保存在内存中的栈中,而引用数据类型的值保存在内存中的堆中,在栈内存中保存着指向堆内存的指针。如果此时你对栈或者堆
继续访问
c# 字典排序_Python零基础入门之列表与字典
本篇内容需结合源码,获取方法看末尾数据结构数据结构就是指从计算机存储、组织数据的结构列表(List) 元组(Tuple)字典(Dictionary)集合(Set)列表(List)列表中的数据按顺序排列列表有正序与倒序两种索引列表可存储任意类型数据,且允许重复创建列表变量名 = [元素1,元素2,......] list = ['a','b','c','d',1,2,3,4]list = [ ] #...
继续访问
js中字典的使用
字典是一种以键-值为一队存储的数据结构,key-value key相当于这个value在字典中的索引,所以key不允许重复,查找也会非常快(类似于哈希表) 在JavaScript中字典的基础是Array类,Array在JavaScript中既是数组也是字典 1.定义字典 var dic = new Array()//定义一个字典 dic['one'] = '1'//...
继续访问
热门推荐 C# 如何识别一个字符串是否Json格式
using Systemusing System.Collections.Genericusing System.Textnamespace CYQ.Data.Tool { /// /// 分隔Json字符串为字典集合。 /// internal class JsonSplit { private st
继续访问
列表中有多个字典,如何取字典中的值
列表中有多个字典,如何取字典中的值,如下面的列表中有3个字典: list=[{‘pathname’: ‘nameone’, ‘num’: 1, ‘status’: ‘RUN’}, {‘pathname’: ‘nametwo’, ‘num’: 2, ‘status’: ‘RUN’}, {‘pathname’: ‘namethree’, ‘num’: 3, ‘status’: ‘RUN’}] 现在要取第2个字典中的num对应的值,值为2。 如果按照取列表中第二个字典,字典中的第二个值表示为:list[1][1]
继续访问
python 取json数组的值_pythonjson数组取值
Python 怎么获取json 里的特定的某个值如果孤独的人愿意回头,焦躁的人愿意等候,内向的人愿意开口,也许这才是爱情最真的样子。”首先我们要导入json包,新建一个对象。 真正的爱情并不一定是他人眼中的完美匹配,而是相爱的人彼此心灵的相互契合。接着直接调用json.dumps将对象转化为json格式,所示,这是比较常用的。 朋友是清明理性让你远离危险的人,是开明坦荡给人快乐的人。我们可以输出一...
继续访问
最新发布 JS进阶-字符串提取
JS进阶-字符串提取
继续访问
JavaScript如何从字符串中提取数字?
JavaScript如何从字符串中提取数字?
继续访问
js 在已有字典中存数据_easyui运用js在数据字典中获取值
varCRUD={add:function(){varhDialog=top.jQuery.hDialog({title:'添加',width:800,height:600,href:formurl,iconCls:'icon-add',//初始化添加onLoad:function(){//数据字典中获取值top.$('#txt_fenlei').comb...
继续访问
js去除空格12种方法
JS去除空格的方法目前共有12种: 实现1 String.prototype.trim = function() { return this.replace(/^\s\s*/, '').replace(/\s\s*$/, '')} 看起来不怎么样, 动用了两次正则替换,实际速度非常惊人,主要得益于浏览器的内部优化。一个著名的例子字符串拼接,直接相加比用Array做成的StringBu
继续访问
js 获取字典的key_JS-字典
function Dictionary() {// 字典属性this.items = {}// 字典操作方法// 1.在字典中添加键值对--set方法Dictionary.prototype.set = (key,value)=>{this.items[key]=value}// 2.判断字典中是否有某个keyDictionary.prototype.has=(key...
继续访问
Js 字符串中提取数字
Js 字符串中提取数字一 parseInt()方法: 首先想到的是js提供的parseInt方法,例子: var str ="4500元"var num = parseInt(str)alert(num)//4500 结果就是我们想要的, 以为就这么简单,那就错了。如果字符串前面有非数字字符,上面这种方法就不...
继续访问
js字典取值
python
开发语言
写评论
评论
收藏