diff --git a/app/build.gradle b/app/build.gradle index 02dbad2c..b39100ec 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -8,8 +8,8 @@ android { applicationId "com.stardust.scriptdroid" minSdkVersion 17 targetSdkVersion 23 - versionCode 230 - versionName "3.0.0 Alpha30" + versionCode 231 + versionName "3.0.0 Alpha31" testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" multiDexEnabled true ndk { diff --git a/app/src/main/assets/docs/all.html b/app/src/main/assets/docs/all.html index dafff867..daefb94c 100644 --- a/app/src/main/assets/docs/all.html +++ b/app/src/main/assets/docs/all.html @@ -2,7 +2,7 @@
-全局变量和函数在所有模块中均可使用。 但以下变量的作用域只在模块内,详见 module文档:
-一些模块中的函数为了使用方便也可以直接全局使用,这些函数在此不再赘述。例如timers模块的setInterval等函数。
-n <number> 毫秒数暂停运行n毫秒的时间。1秒等于1000毫秒。
-packageName <string> 应用包名运行包名为packageName的应用主界面(Launcher)。例如,打开微信为:
-launchPackage("com.tencent.mm");
-如果存在多个应用包名相同的情况(如双开应用),如何处理取决于操作系统。在MIUI中会弹出多开应用的选择界面。
-appName <String> 应用名称运行应用名称为appName的应用主界面。当有应用名称相同时只运行其中某一个。
例如,打开微信为:
launchApp("微信");
-返回最近一次监测到的正在运行的应用的包名,一般可以认为就是当前正在运行的应用的包名。
-返回最近一次监测到的正在运行的Activity的名称,一般可以认为就是当前正在运行的Activity的名称。
-appName <string> 应用名称获取应用的包名。例如getPackageName("QQ")为"com.tencent.mobileqq"。如果有相同名称的应用,只返回其中某一个的包名。如果不存在这个名称的应用,会返回null。
-packageName <string> 应用包名返回对应包名的应用的名称。如果应用不存在,返回null。
-packageName <string> 应用包名打开某个应用的应用详情页,也就是管理应用权限和可以停止其运行的页面。如果应用包名不存在,则返回false;否则返回true。
-text <string> 文本设置剪贴板内容。此剪贴板即系统剪贴板,在一般应用的输入框中"粘贴"既可使用。
-返回系统剪贴板的内容。
-以气泡显示信息message几秒。(具体时间取决于安卓系统,一般都是2秒)
-注意,信息的显示是"异步"执行的(不属于Looper循环),并且,不会等待信息消失程序才继续执行。如果在循环中执行该命令,可能出现脚本停止运行后仍然有不断的气泡信息出现的情况。 -例如:
-for(var i = 0; i < 100; i++){
- toast(i);
-}
-运行这段程序以后,会很快执行完成,且不断弹出消息,在任务管理中关闭所有脚本也无法停止。 -要保证气泡消息才继续执行可以用:
-for(var i = 0; i < 100; i++){
- toast(i);
- sleep(2000);
-}
-或者修改toast函数:
-var _toast_ = toast;
-toast = function(message){
- _toast_(message);
- sleep(2000);
-}
-for(var i = 0; i < 100; i++){
- toast(i);
- sleep(2000);
-}
-相当于toast(message);log(message)。显示信息message并在控制台中输出。参见console.log。
activity Activity名称period 轮询等待间隔(毫秒)等待指定的Activity出现,period为检查Activity的间隔。
-package 包名period 轮询等待间隔(毫秒)等待指定的应用出现。例如waitForPackage("com.tencent.mm")为等待当前界面为微信。
立即停止脚本运行。
-返回一个在[min...max]之间的随机数。例如random(0, 2)可能产生0, 1, 2.
-返回在[0, 1)的随机浮点数。
-全局变量。一个android.content.Context对象。
-注意该对象为ApplicationContext,因此不能用于界面、对话框等的创建。 -
- -SimpleActionAutomator提供了一些模拟简单操作的函数,例如点击文字、模拟按键等。这些函数可以直接作为全局函数使用。
-返回是否点击成功。当屏幕中并未包含该文本,或者该文本所在区域不能点击时返回false,否则返回true。
-该函数可以点击大部分包含文字的按钮。例如微信主界面下方的"微信", "联系人", "发现", "我"的按钮。
通常与while同时使用以便点击按钮直至成功。例如:
while(!click("扫一扫"));
-当不指定参数i时则会尝试点击屏幕上出现的所有文字text并返回是否全部点击成功。
-i是从0开始计算的, 也就是, click("啦啦啦", 0)表示点击屏幕上第一个"啦啦啦", click("啦啦啦", 1)表示点击屏幕上第二个"啦啦啦"。
--文本所在区域指的是,从文本处向其父视图寻找,直至发现一个可点击的部件为止。
-
注意,该函数一般只用于录制的脚本中使用,在自己写的代码中使用该函数一般不要使用该函数。
-点击在指定区域的控件。当屏幕中并未包含与该区域严格匹配的区域,或者该区域不能点击时返回false,否则返回true。
-有些按钮或者部件是图标而不是文字(例如发送朋友圈的照相机图标以及QQ下方的消息、联系人、动态图标),这时不能通过click(text, i)来点击,可以通过描述图标所在的区域来点击。left, bottom, top, right描述的就是点击的区域。
至于要定位点击的区域,可以在悬浮窗使用布局分析工具查看控件的bounds属性。
-通过无障碍服务录制脚本会生成该语句。
-返回是否点击成功。当屏幕中并未包含该文本,或者该文本所在区域不能点击时返回false,否则返回true。
-当不指定参数i时则会尝试点击屏幕上出现的所有文字text并返回是否全部长按成功。
-i <number> 要滑动的控件序号找到第i+1个可滑动控件上滑或左滑。返回是否操作成功。屏幕上没有可滑动的控件时返回false。
-另外不加参数时scrollUp()会寻找面积最大的可滑动的控件上滑或左滑,例如微信消息列表等。
参数为一个整数i时会找到第i + 1个可滑动控件滑动。例如scrollUp(0)为滑动第一个可滑动控件。
i <number> 要滑动的控件序号找到第i+1个可滑动控件下滑或右滑。返回是否操作成功。屏幕上没有可滑动的控件时返回false。
-另外不加参数时scrollUp()会寻找面积最大的可滑动的控件下滑或右滑。
参数为一个整数i时会找到第i + 1个可滑动控件滑动。例如scrollUp(0)为滑动第一个可滑动控件。
返回是否输入成功。当找不到对应的文本框时返回false。
-不加参数i则会把所有输入框的文本都置为text。例如setText("测试")。
这里的输入文本的意思是,把输入框的文本置为text,而不是在原来的文本上追加。
-返回是否输入成功。当找不到对应的文本框时返回false。
-不加参数i则会把所有输入框的文本追加内容text。例如input("测试")。
选择器(UiSelector)是稍微复杂的自动操作脚本所必须。使用选择器的一般步骤是:
-问题的关键在于如何找出想要的控件。对于文本控件一般通过他的文字来定位他,图片控件则通过id或者图片描述(desc)。选择器所做的就是提供这些筛选条件并给出筛选结果。
-选择器提供了更强大的定位界面控件与对其进行操作的功能,可以用他们完成更多的自动操作和提取界面信息。
选择器通过附加筛选条件,筛选出符合条件的控件或控件集合,之后可以对这些控件这些操作。
可供选择的筛选条件包括:
要对选择器所确定的筛选条件,对屏幕上的控件进行筛选,调用方法find(), findOne(), untilFind()。其中find(), untilFind()返回控件的集合,findOne()返回一个控件。untilFind和findOne函数会一直寻找直到屏幕上出现满足条件的控件为止。
一个完整的选择器示例如下:
var emoj = id("name").packageName("com.tencent.mobileqq").clickable()
- .className("ImageView").drawingOrder(5).findOne();
-emoj.click();
-上述代码是找到QQ聊天界面下面的表情按钮(第5个按钮)并点击。也可以简化为:
-id("name").packageName("com.tencent.mobileqq").clickable()
- .className("ImageView").click();
-这段代码意思是,找出id为"name", 包名为"com.tentcent.mobileqq",类名为ImageView的所有可点击控件,对他们执行点击动作。
-最后的click()函数相当于untilFind().click()。也就是如果只需要在找到控件以后立即进行操作,只需要调用相应的操作函数,而不需要先调用find等函数等到控件再操作。
要获取屏幕上的控件的信息(例如id, text, desc, bounds等),可以开启悬浮窗,使用界面层次查看和界面范围查看。
选择器部分内容如果有安卓开发经验会更容易掌握。
-附加id严格匹配筛选条件。
-控件的id属性通常是可以用来确定控件的唯一标识,如果一个控件有id,那么使用id来找到他是最好的方法。要查看屏幕上的控件的id,可以开启悬浮窗并使用界面工具,点击相应控件即可查看。若查看到的控件id为null, 表示该控件没有id。另外,在列表中会出现多个控件的id相同的情况。例如微信的联系人列表,每个头像的id都是一样的。此时不能用id来唯一确定控件。
-在QQ界面经常会出现多个id为"name"的控件,在微信上则每个版本的id都会变化。对于这些软件而言比较难用id定位控件。
-附加控件id包含字符串str的筛选条件。
-附加id需要以prefix开头的筛选条件。
-附加id需要以suffix结束的筛选条件。
-附加id需要满足正则表达式。有关正则表达式,可以查看菜鸟教程。
-这里的正则表达式是Java的正则表达式,不能直接使用JavaScript的正则表达式。
-idMatches("[a-zA-Z]+")
-附加控件文本等于字符串str的筛选条件。
-控件的text(文本)属性是控件上的显示的文字,例如微信左上角的"微信"文本。对于图片或者其他控件通常text属性为null。
-附加控件文本需要以prefix开头的筛选条件。
-附加控件文本需要以prefix开头的筛选条件。
-附加控件文本需要以suffix结束的筛选条件。
-附加控件文本需要满足正则表达式的条件。
-附加控件描述等于字符串str的筛选条件。
-控件的desc(描述,全称为Content-Description)属性是对一个控件的描述,例如网易云音乐右上角的放大镜图标的描述为搜索。要查看一个控件的描述,同样地可以借助悬浮窗查看。
-desc属性同样是定位控件的利器。
-附加控件描述需要以prefix开头的筛选条件。
-附加控件描述需要以prefix开头的筛选条件。
-附加控件描述需要以suffix结束的筛选条件。
-附加控件描述需要满足正则表达式的条件。
-附加控件类名等于字符串str的筛选条件。
-控件的className属性是一个控件的具体类型,例如图片控件通常为ImageView,文本控件通常为TextView, 输入框通常为EditText。(若一个控件是在android.widget包里的,那么android.widget可以省略。但除此之外的其他控件必须是类的全名,例如"com.stardust.theme.ThemeColorImageView")。
-附加控件类名需要以prefix开头的筛选条件。
-附加控件类名需要以prefix开头的筛选条件。
-附加控件类名需要以suffix结束的筛选条件。
-附加控件类名需要满足正则表达式的条件。
-附加包名等于字符串str的筛选条件。
-packageName属性也即控件所属的应用的包名(参见《shell命令:应用包名》),通常用来保证当前运行的应用是想要的应用。
-附加包名需要以prefix开头的筛选条件。
-附加包名需要以prefix开头的筛选条件。
-附加包名需要以suffix结束的筛选条件。
-附加包名需要满足正则表达式的条件。
-附加控件是否可勾选的条件。可勾选指的是,例如QQ和微信发送图片时图片的勾选。
-附加控件是否被选中的条件。被选中指的是,例如QQ聊天界面点击下方的表情按钮时,会出现自己收藏的表情,这时表情按钮便处于选中状态。
-附加控件是否可点击的条件。但并非所有clickable为false的控件都真的不能点击,这取决于控件的实现。因而要确定一个控件的clickable属性,可以开启悬浮窗工具。
-附加控件是否可长按的条件。
-附加控件是否已启用的条件。大多数控件都是启用的状态,处于“禁用”状态通常是灰色并且不可点击。
-附加控件是否可滑动的条件。
-附加控件是否可编辑的条件。一般来说可编辑的控件为输入框(EditText)。
-我也不知道是什么,下次再补充吧。
-我也不知道是什么,下次再补充吧。
-附加控件是否文本或输入框控件是否是多行显示的条件。
-根据当前的选择器所确定的筛选条件,对屏幕上的控件进行搜索,直到屏幕上出现满足条件的一个控件为止,并返回该控件。如果找不到控件,当屏幕内容发生变化时会重新寻找,直至找到。参见控件。
-根据当前的选择器所确定的筛选条件,对屏幕上的控件进行搜索,找到所有满足条件的控件集合并返回。这个搜索只进行一次,并不保证一直会找到,因而会出现返回的控件集合为空的情况。参见控件集合。
-可以通过empty()或nonEmpty()函数判断找到的是否为空。例如:
-var c = className("AbsListView").find();
-if(c.empty()){
- toast("找到啦");
-}else{
- toast("没找到╭(╯^╰)╮");
-}
-根据当前的选择器所确定的筛选条件,对屏幕上的控件进行搜索,直到找到至少一个满足条件的控件为止,并返回所有满足条件的控件集合。参见控件集合。
-判断屏幕上是否存在控件符合选择器所确定的条件。例如要判断某个文本出现就执行某个动作,可以用:
-if(text("嘿嘿嘿").exists()){
- //嘿嘿嘿
-}
-等待屏幕上出现符合条件的控件。
-text("嘿嘿嘿").waitFor();
-找到所有符合条件的控件并点击。相当于untilFind().click()。参见click)。
-找到所有符合条件的控件并长按。相当于untilFind().longClick()。参见longClick)。
-找到所有符合条件的控件并复制其内容,只对文本框或输入框控件有文字选中时有效。相当于untilFind().copy()。参见copy)。
-找到所有符合条件的控件并粘贴,只对输入框控件有效。相当于untilFind().paste()。参见paste)。
-找到所有符合条件的控件并选中。相当于untilFind().select()。参见select)。
-找到所有符合条件的控件并剪切其内容,只对文本框或输入框控件有文字选中时有效。相当于untilFind().cut()。参见cut)。
-找到所有符合条件的控件并折叠。相当于untilFind().collapse()。参见collapse)。
-找到所有符合条件的控件并展开。相当于untilFind().expand()。参见expand)。
-找到所有符合条件的控件并使其出现在屏幕上。相当于untilFind().show()。参见show)。
-找到所有符合条件的控件并向前滑。相当于untilFind().scrollForward()。参见scrollForward)。
向前滑指的是,对于左右滑动的控件向右滑,上下滑动的控件向下滑。
找到所有符合条件的控件并向后滑。相当于untilFind().scrollBackward()。参见scrollBackward)。
向后滑指的是,对于左右滑动的控件向左滑,上下滑动的控件向上滑。
找到所有符合条件的控件并向上滑。相当于untilFind().scrollUp()。参见scrollUp)。
-找到所有符合条件的控件并向下滑。相当于untilFind().scrollDown()。参见scrollDown)。
-找到所有符合条件的控件并向左滑。相当于untilFind().scrollLeft()。参见scrollLeft)。
-找到所有符合条件的控件并向右滑。相当于untilFind().scrollRight()。参见scrollRight)。
-文档缺失
-找到所有符合条件的控件并设置文字选中区域,只对文本控件和输入框有效。相当于untilFind().setSelection()。参见setSelection。
-UiCollection, 控件集合, 通过选择器的find(), untilFind()方法返回的对象。可以对其进行操作或者获取其信息。
-返回集合中的控件数。
-返回集合中第i+1个控件(UiObject)。
-遍历集合。例如:
-var c = clickable();
-c.each(function(o){
- log(o.text());
-});
-返回控件集合是否为空。
-返回控件集合是否非空。
-过滤出控件集合中符合条件的子控件。例如要过滤出所有子控件数目为1的控件为:
-var newCollection = collection.filter(function(obj){
- return obj.childCount() == 1;
-});
-根据selector所确定的条件在该控件集合的控件和子控件找到所有符合条件的控件并返回控件集合。
-注意这会递归地遍历控件集合里所有的控件以及他们的子控件。和filter函数不同。
-例如:
-var names = id("name");
-var clickableNames = names.find(clickable());
-根据selector所确定的条件在该控件集合中找到一个符合条件的控件并返回控件。若找不到则返回null。
-点击集合中所有控件,并返回是否全部点击成功。
-长按集合中所有控件,并返回是否全部操作成功。
-对集合中所有控件执行复制操作,并返回是否全部操作成功。
-对集合中所有控件执行粘贴操作,并返回是否全部操作成功。
-对集合中所有控件执行选中操作,并返回是否全部操作成功。
-对集合中所有控件执行剪切操作,并返回是否全部操作成功。
-对集合中所有控件执行折叠操作,并返回是否全部操作成功。
-对集合中所有控件执行展开操作,并返回是否全部操作成功。
-对集合中所有控件执行显示操作,并返回是否全部操作成功。
-对集合中所有控件执行向前滑的操作,并返回是否全部操作成功。
-对集合中所有控件执行向后滑的操作,并返回是否全部操作成功。
-对集合中所有控件执行向上滑的操作,并返回是否全部操作成功。
-对集合中所有控件执行向下滑的操作,并返回是否全部操作成功。
-对集合中所有控件执行向左滑的操作,并返回是否全部操作成功。
-对集合中所有控件执行向右滑的操作,并返回是否全部操作成功。
-对集合中所有控件设置文字选中区域,并返回是否全部操作成功。
-控件, 选择器的findOne方法返回的对象。和UiCollection有相似的方法,不再赘述。除此之外还有以下方法。
-返回第i+1个子控件(UiObject)。
-返回父控件(UiObject)。
-返回该控件的所有子控件组成的控件集合。
-返回子控件数目。
-返回控件在屏幕上的范围,其值是一个[Rect]对象。
-返回控件在父控件中的范围,其值是一个[Rect]对象。
-返回控件的绘制次序。
-返回控件的id,可能为null。
-返回控件的文本,如果控件没有文本,返回""。
-根据文本text在子控件中递归地寻找并返回文本或描述(desc)包含这段文本text的控件,返回它们组成的集合。。
-根据选择器selector在子控件中递归地寻找符合条件的控件,返回它们组成的集合。
-根据选择器selector在子控件中递归地寻找一个符合条件的控件。找不到则返回null。
-UiObject.bounds(), UiObject.boundsInParent()返回的对象。表示一个长方形。
-长方形左边界的x坐标、
-长方形左边界的x坐标、
-长方形上边界的y坐标、
-长方形下边界的y坐标、
-长方形中点x坐标。
-长方形中点y坐标。
-长方形宽度。通常可以作为控件宽度。
-长方形高度。通常可以作为控件高度。
-返回是否包含另一个长方形r。
-返回是否和另一个长方形相交。
- - -本章节介绍了一些适用于Android7.0以上、不需要root权限、依赖于无障碍服务的点按与手势模拟的全局函数。
-注意以下命令只有Android7.0及以上才有效
-模拟点击坐标(x, y),并返回是否点击成功。只有在点击执行完成后脚本才继续执行。
-一般而言,只有点击过程(大约150毫秒)中被其他事件中断(例如用户自行点击)才会点击失败。
-使用该函数模拟连续点击时可能有点击速度过慢的问题,这时可以用[press][]函数代替。
---可以在开发者选项中启用指针位置来查看坐标
-
模拟长按坐标(x, y), 并 返回是否成功。只有在长按执行完成(大约600毫秒)时脚本才会继续执行。
-一般而言,只有长按过程中被其他事件中断(例如用户自行点击)才会长按失败。
-模拟按住坐标(x, y), 并返回是否成功。只有按住操作执行完成时脚本才会继续执行。
-如果按住时间过短,那么会被系统认为是点击;如果时长超过500毫秒,则认为是长按。
-一般而言,只有按住过程中被其他事件中断才会操作失败。
-模拟从坐标(x1, y1)滑动到坐标(x2, y2),并返回是否成功。只有滑动操作执行完成时脚本才会继续执行。
-一般而言,只有滑动过程中被其他事件中断才会滑动失败。
-duration <number> 手势的时长模拟手势操作。例如gesture(1000, [0, 0], [500, 500], [500, 1000])为模拟一个从(0, 0)到(500, 500)到(500, 100)的手势操作,时长为2秒。
同时模拟多个手势。每个手势的参数为[delay, duration, 坐标], delay为延迟多久(毫秒)才执行该手势;duration为手势执行时长;坐标为手势经过的点的坐标。其中delay参数可以省略,默认为0。
-例如手指捏合:
-gestures([0, 500, [800, 300], [500, 1000]],
- [0, 500, [300, 1500], [500, 1000]]);
-设置脚本坐标点击所适合的屏幕宽高。如果脚本运行时,屏幕宽度不一致会自动放缩坐标。
-例如在1920*1080的设备中,某个操作的代码为
-setScreenMetrics(1080, 1920);
-click(800, 200);
-longClick(300, 500);
-那么在其他设备上AutoJs会自动放缩坐标以便脚本仍然有效。
-RootAutomator是一个使用root权限来模拟触摸的对象,用它可以完成触摸与多点触摸,并且这些动作的执行没有延迟。
-注意以下命令需要root权限
-var ra = new RootAutomator();
-点击位置(x, y)。其中id是一个整数值,用于区分多点触摸,不同的id表示不同的"手指",例如:
-var ra = new RootAutomator();
-//让"手指1"点击位置(100, 100)
-ra.tap(100, 100, 1);
-//让"手指2"点击位置(200, 200);
-ra.tap(200, 200, 2);
-ra.exit();
-如果不需要多点触摸,则不需要id这个参数。 -多点触摸通常用于手势或游戏操作,例如模拟双指捏合、双指上滑等。
-模拟一次从(x1, y1)到(x2, y2)的时间为duration毫秒的滑动。
-模拟按下位置(x, y),时长为duration毫秒。
-使用该函数模拟连续点击时可能有点击速度过慢的问题,这时可以用[RootAutomator.press][]函数代替。
-模拟长按位置(x, y)。
-以上为简单模拟触摸操作的函数。如果要模拟一些复杂的手势,需要更底层的函数。
-模拟手指按下位置(x, y)。
-模拟移动手指到位置(x, y)。
-模拟手指弹起。
-注意:本章节的函数在后续版本很可能有改动!请勿过分依赖本章节函数的副作用。推荐使用[RootAutomator][]代替本章节的触摸函数。
-以下函数均需要root权限,可以实现任意位置的点击、滑动等。
-例如:
-Tap(100, 100);
-sleep(500);
-注意,动作的执行可能无法被停止,例如:
-for(var i = 0; i < 100; i++){
- Tap(100, 100);
-}
-这段代码执行后可能会出现在任务管理中停止脚本后点击仍然继续的情况。 -因此,强烈建议在每个动作后加上延时:
-for(var i = 0; i < 100; i++){
- Tap(100, 100);
- sleep(500);
-}
-点击位置(x, y), 您可以通过"开发者选项"开启指针位置来确定点击坐标。
-滑动。从(x1, y1)位置滑动到(x2, y2)位置。 -
- -images模块提供了一些手机设备中常见的图片处理函数,包括截图、读写图片、图片剪裁、找色、找图等。
-landscape <boolean> 布尔值, 表示将要执行的截屏是否为横屏。如果landscape为false, 则表示竖屏截图; true为横屏截图。向系统申请屏幕截图权限,返回是否请求成功。
-第一次使用该函数会弹出截图权限请求,建议选择“总是允许”。
-这个函数只是申请截图权限,并不会真正执行截图,真正的截图函数是[captureScreen][]。
-该函数在截图脚本中只需执行一次,而无需每次调用[captureScreen][]都调用一次。
-如果不指定landscape值,则截图方向由当前设备屏幕方向决定,因此务必注意执行该函数时的屏幕方向。
-建议在本软件界面运行该函数,在其他软件界面运行时容易出现一闪而过的黑屏现象。
-示例:
-//请求截图
-if(!requestScreenCapture()){
- toast("请求截图失败");
- exit();
-}
-//连续截图10张图片(间隔1秒)并保存到存储卡目录
-for(var i = 0; i < 10; i++){
- captureScreen("/sdcard/screencapture" + i + ".png");
- sleep(1000);
-}
-该函数也可以作为全局函数使用。
-截取当前屏幕并返回一个Image对象。
-没有截图权限时执行该函数会抛出SecurityException。
-该函数不会返回null,两次调用可能返回相同的Image对象。这是因为设备截图的更新需要一定的时间,短时间内(一般来说是16ms)连续调用则会返回同一张截图。
-截图需要转换为Bitmap格式,从而该函数执行需要一定的时间(0~20ms)。
-另外在requestScreenCapture()执行成功后需要一定时间后才有截图可用,因此如果立即调用captureScreen(),会等待一定时间后(一般为几百ms)才返回截图。
-例子:
-//请求横屏截图
-requestScreenCapture(true);
-//截图
-var img = captureScreen();
-//获取在点(100, 100)的颜色值
-var color = images.pixel(img, 100, 100);
-//显示该颜色值
-toast(colors.toString(color));
-该函数也可以作为全局函数使用。
-path <string> 截图保存路径截取当前屏幕并以PNG格式保存到path中。如果文件不存在会被创建;文件存在会被覆盖。
-该函数不会返回任何值。该函数也可以作为全局函数使用。
-返回图片image在点(x, y)处的像素的ARGB值。
-该值的格式为0xAARRGGBB,是一个"32位整数"(虽然JavaScript中并不区分整数类型和其他数值类型)。
-坐标系以图片左上角为原点。以图片左侧边为y轴,上侧边为x轴。
-image <image> 图片path <string> 路劲把图片image以PNG格式保存到path中。如果文件不存在会被创建;文件存在会被覆盖。
-path <string> 图片路径读取在路径path的图片文件并返回一个Image对象。如果文件不存在或者文件无法解码则返回null。
-url <string> 图片URL地址加载在地址URL的网络图片并返回一个Image对象。如果地址不存在或者图片无法解码则返回null。
-在图片中寻找颜色color。找到时返回找到的点Point,找不到时返回null。
-选项包括:
-region <Array> 找色区域。是一个两个或四个元素的数组。(region[0], region[1])表示找色区域的左上角;region[2]*region[3]表示找色区域的宽高。如果只有region只有两个元素,则找色区域为(region[0], region[1])到屏幕右下角。如果不指定region选项,则找色区域为整张图片。threshold <number> 找色时颜色相似度的临界值,范围为0~255(越小越相似,0为颜色相等,255为任何颜色都能匹配)。默认为16。threshold和浮点数相似度(0.0~1.0)的换算为 similarity = (255 - threshold) / 255.该函数也可以作为全局函数使用。
-一个循环找色的例子如下:
-requestScreenCapture();
-
-//循环找色,找到红色(#ff0000)时停止并报告坐标
-while(true){
- var img = captureScreen();
- var point = findColor(img, "#ff0000");
- if(point){
- toast("找到红色,坐标为(" + point.x + ", " + point.y + ")");
- }
-}
-一个区域找色的例子如下:
-//读取本地图片/sdcard/1.png
-var img = images.read("/sdcard/1.png");
-//判断图片是否加载成功
-if(!img){
- toast("没有该图片");
- exit();
-}
-//在该图片中找色,指定找色区域为在位置(400, 500)的宽为300长为200的区域,指定找色临界值为4
-var point = findColor(img, "#00ff00", {
- region: [400, 500, 300, 200],
- threshold: 4
- });
-if(point){
- toast("找到啦:" + point);
-}else{
- toast("没找到");
-}
-区域找色的简便方法。
-相当于
-images.findColor(img, color, {
- region: [x, y, width, height],
- threshold: threshold
-});
-该函数也可以作为全局函数使用。
-严格找色的简便方法。找色时要求颜色完全相等才匹配。
-相当于
-images.findColor(img, color, {
- region: [x, y, width, height],
- threshold: 0
-});
-该函数也可以作为全局函数使用。
-示例: -(通过找QQ红点的颜色来判断是否有未读消息)
-requestScreenCapture();
-launchApp("QQ");
-sleep(1200);
-var p = findColorEquals(captureScreen(), "#f64d30");
-if(p){
- toast("有未读消息");
-}else{
- toast("没有未读消息");
-}
-image <Image> 图片color <number> | <string> 要检测的颜色x <number> 要检测的位置横坐标y <number> 要检测的位置纵坐标threshold <number> 颜色相似度临界值,默认为16。取值范围为0~255。algorithm <string> 颜色匹配算法,包括:返回图片image在位置(x, y)处是否匹配到颜色color。用于检测图片中某个位置是否是特定颜色。
-一个判断微博客户端的某个微博是否被点赞过的例子:
-requestScreenCapture();
-//找到点赞控件
-var like = id("ly_feed_like_icon").findOne();
-//获取该控件中点坐标
-var x = like.bounds().centerX();
-var y = like.bounds().centerY();
-//截图
-var img = captureScreen();
-//判断在该坐标的颜色是否为橙红色
-if(images.detectsColor(img, "#fed9a8", x, y)){
- //是的话则已经是点赞过的了,不做任何动作
-}else{
- //否则点击点赞按钮
- like.click();
-}
-img <Image> 大图片template <Image> 小图片(模板)options <Object> 找图选项找图。在大图片img中查找小图片template的位置(模块匹配),找到时返回位置坐标(Point),找不到时返回null。
-选项包括:
-threshold <number> 图片相似度。取值范围为0~1的浮点数。默认值为0.9。region <Array> 找图区域。参见findColor函数关于region的说明。level <number> 一般而言不必修改此参数。不加此参数时该参数会根据图片大小自动调整。找图算法是采用图像金字塔进行的, level参数表示金字塔的层次, level越大可能带来越高的找图效率,但也可能造成找图失败(图片因过度缩小而无法分辨)或返回错误位置。因此,除非您清楚该参数的意义并需要进行性能调优,否则不需要用到该参数。该函数也可以作为全局函数使用。
-一个最简单的找图例子如下:
-var img = images.read("/sdcard/大图.png");
-var templ = images.read("/sdcard/小图.png");
-var p = findImage(img, templ);
-if(p){
- toast("找到啦:" + p);
-}else{
- toast("没找到");
-}
-稍微复杂点的区域找图例子如下:
-auto();
-requestScreenCapture();
-var wx = images.read("/sdcard/微信图标.png");
-//返回桌面
-home();
-//截图并找图
-var p = findImage(captureScreen(), wx, {
- region: [0, 50],
- threshold: 0.8
-});
-if(p){
- toast("在桌面找到了微信图标啦: " + p);
-}else{
- toast("在桌面没有找到微信图标");
-}
-区域找图的简便方法。相当于:
-images.findImage(img, template, {
- region: [x, y, width, height],
- threshold: threshold
-})
-该函数也可以作为全局函数使用。
-colors是颜色处理的工具对象。包含一些常用方法,包括android.graphics.Color的所有方法以及toString方法。
-color <number> 整数RGB颜色值返回颜色值的字符串,格式为 #AARRGGBB。
-color <number> 整数RGB颜色值返回颜色color的R通道的值,范围0~255.
-color <number> 整数RGB颜色值返回颜色color的G通道的值,范围0~255.
-color <number> 整数RGB颜色值返回颜色color的B通道的值,范围0~255.
-color <number> 整数RGB颜色值返回颜色color的Alpha通道的值,范围0~255.
-返回这些颜色通道构成的整数颜色值。Alpha通道将是255(不透明)。
-返回这些颜色通道构成的整数颜色值。
-表示一张图片,可以是截图的图片,或者本地读取的图片,或者从网络获取的图片。
-返回以像素为单位图片宽度。
-返回以像素为单位的图片高度。
-path <string> 路径把图片保存到路径path。(如果文件存在则覆盖)
-返回图片image在点(x, y)处的像素的ARGB值。
-该值的格式为0xAARRGGBB,是一个"32位整数"(虽然JavaScript中并不区分整数类型和其他数值类型)。
-坐标系以图片左上角为原点。以图片左侧边为y轴,上侧边为x轴。
-findColor, findImage返回的对象。表示一个点(坐标)。
-横坐标。
-纵坐标。
- - -控制台模块提供了一个和Web浏览器中相似的用于调试的控制台。用于输出一些调试信息、中间结果等。 -console模块中的一些函数也可以直接作为全局函数使用,例如log, print等。
-显示控制台。这会显示一个控制台的悬浮窗(需要悬浮窗权限)。
-清空控制台。
-data ...args 打印到控制台,并带上换行符。 可以传入多个参数,第一个参数作为主要信息,其他参数作为类似于 printf(3) 中的代替值(参数都会传给 util.format())。
-const count = 5;
-console.log('count: %d', count);
-// 打印: count: 5 到 stdout
-console.log('count:', count);
-// 打印: count: 5 到 stdout
-详见 util.format()。
-data ...args 与console.log类似,但输出结果以灰色字体显示。输出优先级低于log,用于输出观察性质的信息。
-data ...args 与console.log类似,但输出结果以绿色字体显示。输出优先级高于log, 用于输出重要信息。
-data ...args 与console.log类似,但输出结果以蓝色字体显示。输出优先级高于info, 用于输出警告信息。
-data ...args 与console.log类似,但输出结果以红色字体显示。输出优先级高于warn, 用于输出错误信息。
-断言。如果value为false则输出错误信息message并停止脚本运行。
-data ...args 与console.log一样输出信息,并在控制台显示输入框等待输入。按控制台的确认按钮后会将输入的字符串用eval计算后返回。
-部分机型可能会有控制台不显示输入框的情况,属于bug。
-例如:
-var n = console.input("请输入一个数字:");
-//输入123之后:
-toast(n + 1);
-//显示124
-data ...args 与console.log一样输出信息,并在控制台显示输入框等待输入。按控制台的确认按钮后会将输入的字符串直接返回。
-部分机型可能会有控制台不显示输入框的情况,属于bug。
-例如:
-var n = console.input("请输入一个数字:");
-//输入123之后:
-toast(n + 1);
-//显示1231
-在控制台中输出文本text。不会自动换行。
- - -events模块提供了监听手机通知、按键、触摸的接口。您可以用他配合自动操作函数完成自动化工作。
-events本身是一个EventEmiiter, 但内置了一些事件、包括按键事件、通知事件、Toast事件等。
-返回一个新的[EventEmitter][]。这个EventEmitter没有内置任何事件。
-启用按键监听,例如音量键、Home键。此函数使用无障碍服务实现,因此此函数会调用auto()确保无障碍服务启用。
-只有这个函数成功执行后, [onKeyDown][], [onKeyUp][]等按键事件的监听才有效。
-该函数在安卓4.3以上才能使用。
-keyName <string> 要监听的按键名称listener <Function> 按键监听器。参数为一个KeyEvent。注册一个按键监听函数,当有keyName对应的按键被按下会调用该函数。可用的按键名称参见[Keys][]。
-例如:
-//启用按键监听
-events.observeKey();
-//监听音量上键按下
-events.onKeyDown("volume_up", function(event){
- toast("音量上键被按下了");
-});
-//监听菜单键按下
-events.onKeyDown("menu", function(event){
- toast("菜单键被按下了");
- exit();
-});
-keyName <string> 要监听的按键名称listener <Function> 按键监听器。参数为一个KeyEvent。注册一个按键监听函数,当有keyName对应的按键弹起会调用该函数。可用的按键名称参见Keys。
-一次完整的按键动作包括了按键按下和弹起。按下事件会在手指按下一个按键的"瞬间"触发, 弹起事件则在手指放开这个按键时触发。
-例如:
-//启用按键监听
-events.observeKey();
-//监听音量下键弹起
-events.onKeyDown("volume_down", function(event){
- toast("音量上键弹起");
-});
-//监听Home键弹起
-events.onKeyDown("home", function(event){
- toast("Home键弹起");
- exit();
-});
-keyName <string> 要监听的按键名称listener <Function> 按键监听器。参数为一个KeyEvent注册一个按键监听函数,当有keyName对应的按键被按下时会调用该函数,之后会注销该按键监听器。
-也就是listener只有在onceKeyDown调用后的第一次按键事件被调用一次。
-keyName <string> 要监听的按键名称listener <Function> 按键监听器。参数为一个KeyEvent注册一个按键监听函数,当有keyName对应的按键弹起时会调用该函数,之后会注销该按键监听器。
-也就是listener只有在onceKeyUp调用后的第一次按键事件被调用一次。
-keyName <string> 按键名称删除该按键的KeyDown(按下)事件的所有监听。
-keyName <string> 按键名称删除该按键的KeyUp(弹起)事件的所有监听。
-启用屏幕触摸监听。(需要root权限)
-只有这个函数被成功执行后, 触摸事件的监听才有效。
-没有root权限调用该函数则什么也不会发生。(注意: 这个行为未来可能会更改为抛出异常)
-timeout <number> 两个触摸事件的最小间隔。单位毫秒。默认为10毫秒。如果number小于0,视为0处理。设置两个触摸事件分发的最小时间间隔。
-例如间隔为10毫秒的话,前一个触摸事件发生并被注册的监听器处理后,至少要过10毫秒才能分发和处理下一个触摸事件,这10毫秒之间的触摸将会被忽略。
-建议在满足需要的情况下尽量提高这个间隔。一个简单滑动动作可能会连续触发上百个触摸事件,如果timeout设置过低可能造成事件拥堵。强烈建议不要设置timeout为0。
-返回触摸事件的最小时间间隔。
-listener <Function> 参数为[Point][]的函数注册一个触摸监听函数。相当于on("touch", listener)。
例如:
-//启用触摸监听
-events.observeTouch();
-//注册触摸监听器
-events.onTouch(function(p){
- //触摸事件发生时, 打印出触摸的点的坐标
- log(p.x + ", " + p.y);
-});
-删除所有事件监听函数。
-keyCode <number> 键值event <KeyEvent> 事件当有按键被按下或弹起时会触发该事件。 -例如:
-auto();
-events.observeKey();
-events.on("key", function(keyCode, event){
- //处理按键事件
-});
-其中监听器的参数KeyCode包括:
-KeyEvent.KEYCODE_HOME 主页键KeyEvent.KEYCODE_BACK 返回键KeyEvent.KEYCODE_MENU 菜单键KeyEvent.KEYCODE_VOLUMEUP 音量上键KeyEvent.KEYCODE_VOLUMEDOWN 音量下键keyCode <number> 键值event <KeyEvent> 事件当有按键被按下时会触发该事件。
-auto();
-events.observeKey();
-events.on("key_down", function(keyCode, event){
- //处理按键按下事件
-});
-keyCode <number> 键值event <KeyEvent> 事件当有按键弹起时会触发该事件。
-auto();
-events.observeKey();
-events.on("key_up", function(keyCode, event){
- //处理按键弹起事件
-});
-开启通知(包括Toast)监听。
-通知与Toast监听依赖于无障碍服务,因此这个函数会调用auto()来确保无障碍服务启用。
例如:
-events.obverseNotification();
-events.onNotification(function(notification){
- log(notification.getText());
-});
-events.onToast(function(toast){
- log(toast.getText());
-});
-toast <Object>getText() 获取Toast的文本内容getPackageName() 获取发出Toast的应用包名当有应用发出toast(气泡消息)时会触发该事件。但Auto.js软件本身的toast除外。 -例如,要记录发出所有toast的应用:
-events.obverseNotification();
-events.onToast(function(toast){
- log("Toast内容: " + toast.getText() + " 包名: " + toast.getPackageName());
-});
-notification <Object> 通知当有应用发出通知时会触发该事件。
-例如:
-events.observeNotification();
-events.on("notification", function(notification){
- log(notification);
-});
-注意: 这是一个实验性功能。实测只有某些情况下的通知才能被正确捕捉。
-每个事件默认可以注册最多 10 个监听器。 单个 EventEmitter 实例的限制可以使用 emitter.setMaxListeners(n) 方法改变。 所有 EventEmitter 实例的默认值可以使用 EventEmitter.defaultMaxListeners 属性改变。
-设置 EventEmitter.defaultMaxListeners 要谨慎,因为会影响所有 EventEmitter 实例,包括之前创建的。 因而,调用 emitter.setMaxListeners(n) 优先于 EventEmitter.defaultMaxListeners。
-注意,与Node.js不同,这是一个硬性限制。 EventEmitter 实例不允许添加更多的监听器,监听器超过最大数量时会抛出TooManyListenersException。
-emitter.setMaxListeners(emitter.getMaxListeners() + 1);
-emitter.once('event', () => {
- // 做些操作
- emitter.setMaxListeners(Math.max(emitter.getMaxListeners() - 1, 0));
-});
-eventName <any>listener <Function>emitter.on(eventName, listener) 的别名。
-eventName <any>args <any>按监听器的注册顺序,同步地调用每个注册到名为 eventName 事件的监听器,并传入提供的参数。
-如果事件有监听器,则返回 true ,否则返回 false。
-返回一个列出触发器已注册监听器的事件的数组。 数组中的值为字符串或符号。
-const myEE = events.emitter();
-myEE.on('foo', () => {});
-myEE.on('bar', () => {});
-
-const sym = Symbol('symbol');
-myEE.on(sym, () => {});
-
-console.log(myEE.eventNames());
-// 打印: [ 'foo', 'bar', Symbol(symbol) ]
-返回 EventEmitter 当前的最大监听器限制值,该值可以通过 emitter.setMaxListeners(n) 设置或默认为 EventEmitter.defaultMaxListeners。
-eventName <string> 正在被监听的事件名返回正在监听名为 eventName 的事件的监听器的数量。
-eventName <string>返回名为 eventName 的事件的监听器数组的副本。
-server.on('connection', (stream) => {
- console.log('someone connected!');
-});
-console.log(util.inspect(server.listeners('connection')));
-// 打印: [ [Function] ]
-eventName <any> 事件名listener <Function> 回调函数添加 listener 函数到名为 eventName 的事件的监听器数组的末尾。 不会检查 listener 是否已被添加。 多次调用并传入相同的 eventName 和 listener 会导致 listener 被添加与调用多次。
-server.on('connection', (stream) => {
- console.log('有连接!');
-});
-返回一个 EventEmitter 引用,可以链式调用。
-默认情况下,事件监听器会按照添加的顺序依次调用。 emitter.prependListener() 方法可用于将事件监听器添加到监听器数组的开头。
-const myEE = events.emitter();
-myEE.on('foo', () => console.log('a'));
-myEE.prependListener('foo', () => console.log('b'));
-myEE.emit('foo');
-// 打印:
-// b
-// a
-eventName <any> 事件名listener <Function> 回调函数添加一个单次 listener 函数到名为 eventName 的事件。 下次触发 eventName 事件时,监听器会被移除,然后调用。
-server.once('connection', (stream) => {
- console.log('首次调用!');
-});
-返回一个 EventEmitter 引用,可以链式调用。
-默认情况下,事件监听器会按照添加的顺序依次调用。 emitter.prependOnceListener() 方法可用于将事件监听器添加到监听器数组的开头。
-const myEE = events.emitter();
-myEE.once('foo', () => console.log('a'));
-myEE.prependOnceListener('foo', () => console.log('b'));
-myEE.emit('foo');
-// 打印:
-// b
-// a
-eventName <any> 事件名listener <Function> 回调函数添加 listener 函数到名为 eventName 的事件的监听器数组的开头。 不会检查 listener 是否已被添加。 多次调用并传入相同的 eventName 和 listener 会导致 listener 被添加与调用多次。
-server.prependListener('connection', (stream) => {
- console.log('有连接!');
-});
-返回一个 EventEmitter 引用,可以链式调用。
-eventName <any> 事件名listener <Function> 回调函数添加一个单次 listener 函数到名为 eventName 的事件的监听器数组的开头。 下次触发 eventName 事件时,监听器会被移除,然后调用。
-server.prependOnceListener('connection', (stream) => {
- console.log('首次调用!');
-});
-返回一个 EventEmitter 引用,可以链式调用。
-eventName <any>移除全部或指定 eventName 的监听器。
-注意,在代码中移除其他地方添加的监听器是一个不好的做法,尤其是当 EventEmitter 实例是其他组件或模块创建的。
-返回一个 EventEmitter 引用,可以链式调用。
-eventName <any>listener <Function>从名为 eventName 的事件的监听器数组中移除指定的 listener。
-const callback = (stream) => {
- console.log('有连接!');
-};
-server.on('connection', callback);
-// ...
-server.removeListener('connection', callback);
-removeListener 最多只会从监听器数组里移除一个监听器实例。 如果任何单一的监听器被多次添加到指定 eventName 的监听器数组中,则必须多次调用 removeListener 才能移除每个实例。
-注意,一旦一个事件被触发,所有绑定到它的监听器都会按顺序依次触发。 这意味着,在事件触发后、最后一个监听器完成执行前,任何 removeListener() 或 removeAllListeners() 调用都不会从 emit() 中移除它们。 随后的事件会像预期的那样发生。
-const myEmitter = events.emitter();
-
-const callbackA = () => {
- console.log('A');
- myEmitter.removeListener('event', callbackB);
-};
-
-const callbackB = () => {
- console.log('B');
-};
-
-myEmitter.on('event', callbackA);
-
-myEmitter.on('event', callbackB);
-
-// callbackA 移除了监听器 callbackB,但它依然会被调用。
-// 触发是内部的监听器数组为 [callbackA, callbackB]
-myEmitter.emit('event');
-// 打印:
-// A
-// B
-
-// callbackB 被移除了。
-// 内部监听器数组为 [callbackA]
-myEmitter.emit('event');
-// 打印:
-// A
-因为监听器是使用内部数组进行管理的,所以调用它会改变在监听器被移除后注册的任何监听器的位置索引。 虽然这不会影响监听器的调用顺序,但意味着由 emitter.listeners() 方法返回的监听器数组副本需要被重新创建。
-返回一个 EventEmitter 引用,可以链式调用。
-n <number>默认情况下,如果为特定事件添加了超过 10 个监听器,则 EventEmitter 会打印一个警告。 此限制有助于寻找内存泄露。 但是,并不是所有的事件都要被限为 10 个。 emitter.setMaxListeners() 方法允许修改指定的 EventEmitter 实例的限制。 值设为 Infinity(或 0)表明不限制监听器的数量。
-返回一个 EventEmitter 引用,可以链式调用。
-返回事件的动作。包括:
-KeyEvent.ACTION_DOWN 按下事件KeyEvent.ACTION_UP 弹起事件返回按键的键值。包括:
-KeyEvent.KEYCODE_HOME 主页键KeyEvent.KEYCODE_BACK 返回键KeyEvent.KEYCODE_MENU 菜单键KeyEvent.KEYCODE_VOLUME_UP 音量上键KeyEvent.KEYCODE_VOLUME_DOWN 音量下键返回事件发生的时间戳。返回值的类型是number。
-返回最近一次按下事件的时间戳。如果本身是按下事件,则与getEventTime()相同。
-把键值转换为字符串。例如KEYCODE_HOME转换为"KEYCODE_HOME"。
-按键事件中所有可用的按键名称为:
-volume_up 音量上键volume_down 音量下键home 主屏幕键back 返回键menu 菜单键timers 模块暴露了一个全局的 API,用于在某个未来时间段调用调度函数。 因为定时器函数是全局的,所以使用该 API 无需调用 timers.*
-Auto.js 中的计时器函数实现了与 Web 浏览器提供的定时器类似的 API,除了它使用了一个不同的内部实现,它是基于 Android Looper-Handler消息循环机制构建的。其实现机制与Node.js比较相似。
-callback <Function> 在Looper循环的当前回合结束时要调用的函数。...args <any> 当调用 callback 时要传入的可选参数。预定立即执行的 callback,它是在 I/O 事件的回调之后被触发。 返回一个用于 clearImmediate() 的 id。
-当多次调用 setImmediate() 时,callback 函数会按照它们被创建的顺序依次执行。 每次事件循环迭代都会处理整个回调队列。 如果一个立即定时器是被一个正在执行的回调排入队列的,则该定时器直到下一次事件循环迭代才会被触发。
-callback <Function> 当定时器到点时要调用的函数。delay <number> 调用 callback 之前要等待的毫秒数。...args <any> 当调用 callback 时要传入的可选参数。预定每隔 delay 毫秒重复执行的 callback。 返回一个用于 clearInterval() 的 id。
-当 delay 小于 0 时,delay 会被设为 0。
-callback <Function> 当定时器到点时要调用的函数。delay <number> 调用 callback 之前要等待的毫秒数。...args <any> 当调用 callback 时要传入的可选参数。预定在 delay 毫秒之后执行的单次 callback。 返回一个用于 clearTimeout() 的 id。
-callback 可能不会精确地在 delay 毫秒被调用。 Auto.js 不能保证回调被触发的确切时间,也不能保证它们的顺序。 回调会在尽可能接近所指定的时间上调用。
-当 delay 小于 0 时,delay 会被设为 0。
-setImmediate()、setInterval() 和 setTimeout() 方法每次都会返回表示预定的计时器的id。 它们可用于取消定时器并防止触发。
-id <number> 一个 setImmediate() 返回的 id。取消一个由 setImmediate() 创建的 Immediate 对象。
-id <number> 一个 setInterval() 返回的 id。取消一个由 setInterval() 创建的 Timeout 对象。
-id <number> 一个 setTimeout() 返回的 id。取消一个由 setTimeout() 创建的 Timeout 对象。
- - -shell即Unix Shell,在类Unix系统提供与操作系统交互的一系列命令。
-很多程序可以用来执行shell命令,例如终端模拟器。
-在Auto.js大致等同于用adb执行命令"adb shell"。其实现包括两种方式:
-java.lang.Runtime.exec执行(shell, Tap, Home等函数)返回运行一个对象表示命令的执行结果。其属性如下:
-示例(强制停止微信) :
-var result = shell("am force-stop com.tencent.mm", true);
-log(result);
-console.show();
-if(result.code == 0){
- toast("执行成功");
-}else{
- toast("执行失败!请到控制台查看错误信息");
-}
-shell函数通过用来一次性执行单条命令并获取结果。如果有多条命令需要执行,用Shell对象的效率更高。这是因为,每次运行shell函数都会打开一个单独的shell进程并在运行结束后关闭他,这个过程需要一定的时间;而Shell对象自始至终使用同一个shell进程。
-Shell对象的"构造函数"。
-var sh = new Shell(true);
-sh.exec("am force-stop com.tencent.mm");
-sh.exit();
-cmd <string> 要执行的命令执行命令cmd。该函数不会返回任何值。
-注意,命令执行是"异步"的、非阻塞的。也就是不会等待命令完成后才继续向下执行。
-尽管这样的设计使用起来有很多不便之处,但受限于终端模拟器,暂时没有解决方式;如果后续能找到解决方案,则将提供Shell.execAndWaitFor函数。
直接退出shell。这意味着正在执行的命令会被强制退出。
-执行"exit"命令并等待执行命令执行完成、退出shell。
-此函数会执行exit命令来正常退出shell。
-设置该Shell的回调函数,以便监听Shell的输出。可以包括以下属性:
-例如:
-var sh = new Shell();
-sh.setCallback({
- onNewLine: function(line){
- log(line);
- }
-})
-while(true){
- var cmd = dialogs.rawInput("请输入要执行的命令,输入exit退出");
- if(cmd == "exit"){
- break;
- }
- sh.exec(cmd);
-}
-sh.exit();
-以下关于shell命令的资料来自AndroidStudio用户指南:Shell命令。
-am命令即Activity Manager命令,用于管理应用程序活动、服务等。
-以下命令均以"am "开头,例如"shell(\"am start -p com.tencent.mm\");"(启动微信)
-启动 intent 指定的 Activity(应用程序活动)。
请参阅 intent 参数的规范。
选项包括:
-启动 intent 指定的 Service(服务)。
请参阅 intent 参数的规范。
选项包括:
强行停止与 package(应用包名)关联的所有应用。
-终止与 package(应用包名)关联的所有进程。此命令仅终止可安全终止且不会影响用户体验的进程。
选项包括:
终止所有后台进程。
-发出广播 intent。 -请参阅 intent 参数的规范。
-选项包括:
-使用 Instrumentation 实例启动监控。通常,目标 component 是表单 test_package/runner_class。
选项包括:
转储 process 的堆,写入 file。
-选项包括:
-选项包括:
-选项包括:
-替换模拟器/设备显示尺寸。此命令对于在不同尺寸的屏幕上测试您的应用非常有用,它支持使用大屏设备模仿小屏幕分辨率(反之亦然)。
示例:
shell("am display-size 1280x800", true);
-替换模拟器/设备显示密度。此命令对于在不同密度的屏幕上测试您的应用非常有用,它支持使用低密度屏幕在高密度环境环境上进行测试(反之亦然)。
示例:
shell("am display-density 480", true);
-将给定的 intent 规范以 URI 的形式输出。 -请参阅 intent 参数的规范。
-将给定的 intent 规范以 intent:URI 的形式输出。 -请参阅 intent 参数的规范。
-对于采用 intent 参数的 am 命令,您可以使用以下选项指定 intent:
-所谓应用包名,是唯一确定应用的标识。例如微信的包名是"com.tencent.mm", QQ的包名是"com.tencent.mobileqq"。
要获取一个应用的包名,可以通过函数getPackageName(appName)获取。参见帮助->其他一般函数。
pm命令用于管理应用程序,例如卸载应用、冻结应用等。
以下命令均以"pm "开头,例如"shell(\"pm disable com.tencent.mm\");"(冻结微信)
输出所有软件包,或者,仅输出包名称包含 filter 中的文本的软件包。
选项:
输出所有已知的权限组。
-输出所有已知权限,或者,仅输出 group 中的权限。
选项:
列出所有测试软件包。
选项:
输出系统的所有功能。
-输出当前设备支持的所有库。
-输出系统上的所有用户。
-输出给定 package 的 APK 的路径。
-将软件包(通过 path 指定)安装到系统。
选项:
从系统中卸载软件包。
选项:
启用给定软件包或组件(作为“package/class”写入)。
-停用给定软件包或组件(作为“package/class”写入)。
-选项:
-从应用中撤销权限。在运行 Android 6.0(API 级别 23)及更高版本的设备上,可以是应用清单中声明的任何权限。在运行 Android 5.1(API 级别 22)和更低版本的设备上,必须是应用定义的可选权限。
-更改默认安装位置。位置值:
---注:此命令仅用于调试目的;使用此命令会导致应用中断和其他意外行为。
-
返回当前安装位置。返回值:
-指定是否应强制执行给定的权限。
-减少缓存文件以达到给定的可用空间。
-使用给定的 user_name 创建新用户,输出新用户的标识符。
-移除具有给定的 user_id 的用户,删除与该用户关联的所有数据。
-输出设备支持的最大用户数。
-screencap 命令是一个用于对设备显示屏进行屏幕截图的 shell 实用程序。在 shell 中,此语法为:
-screencap filename
-例如:
-$ shell("screencap /sdcard/screen.png");
-ls filepath
-例如:
-log(shell("ls /system/bin").result);
-
-
-
-
-files模块提供了一些常见的文件处理,包括文件读写、移动、复制、删掉等。
-path <string> 路径返回路径path是否是文件。
-path <string> 路径返回路径path是否是文件夹。
-path <string> 路径返回文件夹path是否为空文件夹。如果该路径并非文件夹,则直接返回false。
-连接两个路径并返回,例如files.join("/sdcard/", "1.txt")返回"/sdcard/1.txt"。
path <string> 路径创建一个文件并返回是否创建成功。
-path <string> 路径创建一个文件并返回是否创建成功。
-path <string> 路径返回在路径path处的文件是否存在。
-path <string> 路径确保路径path所在的文件夹存在。
-例如对于路径"/sdcard/Download/ABC/1.txt",如果/Download/文件夹不存在,则会先创建Download,再创建ABC文件夹。
-读取文件path的所有内容并返回。
-把text写入到文件path中。如果文件存在则覆盖,不存在则创建。
-复制文件。例如files.copy("/sdcard/1.txt", "/sdcard/Download/1.txt")。
移动文件,返回是否移动成功。例如files.move("/sdcard/1.txt", "/sdcard/Download/1.txt")会把1.txt文件从sd卡根目录移动到Download文件夹。
重命名文件,并返回是否重命名成功。例如files.rename("/sdcard/1.txt", "2.txt")。
重命名文件,不包含拓展名,并返回是否重命名成功。例如files.rename("/sdcard/1.txt", "2")会把1.txt重命名为2.txt。
path <string> 路径返回文件的文件名。例如files.getName("/sdcard/1.txt")返回"1.txt"。
path <string> 路径返回不含拓展名的文件的文件名。例如files.getName("/sdcard/1.txt")返回"1"。
path <string> 路径返回文件的拓展名。例如files.getExtension("/sdcard/1.txt")返回"txt"。
path <string> 路径删除文件或空文件夹,返回是否删除成功。
-删除文件夹,如果文件夹不为空,则删除该文件夹的所有内容再删除该文件夹,返回是否全部删除成功。
-返回SD卡路径。所谓SD卡,即外部存储器。
-path <string> 路径filter <Function> 过滤函数,可选。接收一个String参数(文件名),返回一个Boolean值。列出文件夹path下的满足条件的文件和文件夹的名称的数组。如果不加filter参数,则返回所有文件和文件夹。
-例如,获取sdcard目录下的txt文件为
-var txtFiles = files.listDir("/sdcard/", function(name){
- return name.endsWith(".txt") && files.isFile("/sdcard/" + name);
-});
-打开一个文件。根据打开模式返回不同的文件对象。包括:
-对于"w"模式,如果文件并不存在,则会创建一个,已存在则会清空该文件内容;其他模式文件不存在会抛出FileNotFoundException。
-可读文件对象。
-返回该文件剩余的所有内容的字符串。
-maxCount <Number> 最大读取的字符数量读取该文件接下来最长为maxCount的字符串并返回。即使文件剩余内容不足maxCount也不会出错。
-读取一行并返回(不包含换行符)。
-读取剩余的所有行,并返回它们按顺序组成的字符串数组。
-关闭该文件。
-打开一个文件不再使用时务必关闭
-可写文件对象。
-text <string> 文本把文本内容text写入到文件中。
-text <string> 文本把文本line写入到文件中并写入一个换行符。
-lines <Array> 字符串数组把很多行写入到文件中....
-把缓冲区内容输出到文件中。
-关闭文件。同时会被缓冲区内容输出到文件。
-打开一个文件写入后,不再使用时务必关闭,否则文件可能会丢失
- - -app模块提供一系列函数,用于与其他应用的交互。例如打开文件、拍照、发送邮件等。
-同时提供了方便的基础函数startActivity和sendBroadcast,用他们可完成app模块没有内置的和其他应用的交互。
-用其他应用查看文件。
-用其他应用编辑文件。
-卸载应用。
-用浏览器打开网站url。
-path <string> 照片保存路径调用相机应用拍照,完成后保存到路径path。
-options <Object> 发送邮件的参数。包括:
-根据选项options调用邮箱应用发送邮件。这些选项均是可选的。
-返回用intent对象构造的android.content.Intent对象。
-例如:
-var i = app.intent({
- action: "android.intent.action.VIEW",
- type: "text/plain",
- data: "file:///sdcard/1.txt",
-});
-如果你看了一脸懵逼,请百度安卓Intent。
-相当于context.startActivity(intent)。
-相当于context.sendBroadcast(intent)。
- - -http模块提供一些进行http请求的函数。
-url <string> 请求的URL地址,需要以"http://"或"https://"开头。如果url没有以"http://"开头,则默认为"http://"。options <Object> 请求选项。参见[http.request()][]。callback <Function> 回调函数,可选,其参数是一个[Response][]对象。如果不加回调函数,则该请求将阻塞、同步地执行。对地址url进行一次HTTP GET 请求。如果没有回调函数,则在请求完成或失败时返回此次请求的响应(参见[Response][])。
-最简单GET请求如下:
-console.show();
-var r = http.get("www.baidu.com");
-log("code = " + r.statusCode);
-log("html = " + r.body.string());
-采用回调形式的GET请求如下:
-console.show();
-http.get("www.baidu.com", {}, function(res, err){
- if(err){
- console.error(err);
- return;
- }
- log("code = " + r.statusCode);
- log("html = " + r.body.string());
-});
-如果要增加HTTP头部信息,则在options参数中添加,例如:
-console.show();
-var r = http.get("www.baidu.com", {
- headers: {
- "Accept-Language": "zh-cn,zh;q=0.5",
- "User-Agent: "Mozilla/5.0 (Macintosh; Intel Mac OS X
-10_7_0) AppleWebKit/535.11 (KHTML, like Gecko) Chrome/17.0.963.56
-Safari/535.11"
- }
-});
-log("code = " + r.statusCode);
-log("html = " + r.body.string());
-一个请求天气并解析返回的天气JSON结果的例子如下:
-var city = "广州";
-var res = http.get("http://www.sojson.com/open/api/weather/json.shtml?city=" + city);
-if(res.statusCode != 200){
- toast("请求失败: " + res.statusCode + " " + res.statusMessage);
-}else{
- var weather = res.body.json();
- log(weather);
- toast(util.format("温度: %s 湿度: %s 空气质量: %s", weather.data.wendu,
- weather.data.shidu, weather.quality));
-}
-url <string> 请求的URL地址,需要以"http://"或"https://"开头。如果url没有以"http://"开头,则默认为"http://"。data <string> | <Object> POST数据。options <Object> 请求选项。callback <Function> 回调,其参数是一个[Response][]对象。如果不加回调参数,则该请求将阻塞、同步地执行。对地址url进行一次HTTP POST 请求。如果没有回调函数,则在请求完成或失败时返回此次请求的响应(参见[Response][])。
-其中POST数据可以是字符串或键值对。具体含义取决于options.contentType的值。默认为"application/x-www-form-urlencoded"(表单提交), 这种方式是JQuery的ajax函数的默认方式。
-一个模拟表单提交登录淘宝的例子如下:
-var url = "https://login.taobao.com/member/login.jhtml";
-var username = "你的用户名";
-var password = "你的密码";
-var res = http.post(url, {
- "TPL_username": username,
- "TPL_password": password
-});
-var html = res.body.string();
-if(html.contains("页面跳转中")){
- toast("登录成功");
-}else{
- toast("登录失败");
-}
-url <string> 请求的URL地址,需要以"http://"或"https://"开头。如果url没有以"http://"开头,则默认为"http://"。data <Object> POST数据。options <Object> 请求选项。callback <Function> 回调,其参数是一个[Response][]对象。如果不加回调参数,则该请求将阻塞、同步地执行。以JSON格式向目标Url发起POST请求。如果没有回调函数,则在请求完成或失败时返回此次请求的响应(参见[Response][])。
-JSON格式指的是,将会调用JSON.stringify()把data对象转换为JSON字符串,并在HTTP头部信息中把"Content-Type"属性置为"application/json"。这种方式是AngularJS的ajax函数的默认方式。
一个调用图灵机器人接口的例子如下:
-url <string> 请求的URL地址,需要以"http://"或"https://"开头。如果url没有以"http://"开头,则默认为"http://"。options <Object> 请求选项。参见[http.buildRequest()][]。callback <Function> 回调,其参数是一个[Response][]对象。如果不加回调参数,则该请求将阻塞、同步地执行。对目标地址url发起一次HTTP请求。如果没有回调函数,则在请求完成或失败时返回此次请求的响应(参见[Response][])。
-选项options可以包含以下属性:
-headers <Object> 键值对形式的HTTP头部信息。有关HTTP头部信息,参见菜鸟教程:HTTP响应头信息。method <string> HTTP请求方法。包括"GET", "POST", "PUT", "DELET", "PATCH"。contentType <string> HTTP头部信息中的"Content-Type", 表示HTTP请求的内容类型。例如"text/plain", "application/json"。更多信息参见菜鸟教程:HTTP contentType。body <string> | <Array> | <Function> HTTP请求的内容。可以是一个字符串,也可以是一个字节数组;或者是一个以BufferedSink为参数的函数。该函数是get, post, postJson等函数的基础函数。因此除非是PUT, DELET等请求,或者需要更高定制的HTTP请求,否则直接使用get, post, postJson等函数会更加方便。
-HTTP请求的响应。
-当前响应的HTTP状态码。例如200(OK), 404(Not Found)等。
-有关HTTP状态码的信息,参见菜鸟教程:HTTP状态码。
-当前响应的HTTP状态信息。例如"OK", "Bad Request", "Forbidden"。
-有关HTTP状态码的信息,参见菜鸟教程:HTTP状态码。
-例子:
-var res = http.get("www.baidu.com");
-if(res.statusCode >= 200 && res.statusCode < 300){
- toast("页面获取成功!");
-}else if(res.statusCode == 404){
- toast("页面没找到哦...");
-}else{
- toast("错误: " + res.statusCode + " " + res.statusMessage);
-}
-当前响应的HTTP头部信息。该对象的键是响应头名称,值是各自的响应头值。 所有响应头名称都是小写的(吗)。
-有关HTTP头部信息,参见菜鸟教程:HTTP响应头信息。
-例子:
-console.show();
-var res = http.get("www.qq.com");
-console.log("HTTP Headers:")
-for(var headerName in res.headers){
- console.log("%s: %s", headerName, res.headers[headerName]);
-}
-当前响应的内容。他有以下属性和函数:
-dialogs 模块允许用户通过对话框与脚本进行交互。
-显示一个包含输入框的对话框。如果指定了 default ,那么对话框显示时输入框的内容就为该值。
该函数也可通过 rawInput(title[, default]) 、 prompt(title[, default]) 或者 dialogs.prompt(title[, default]) 来调用。调用时脚本将阻塞直至对话框被关闭。如果用户输入内容并点击确定,函数将返回输入的内容;否则返回 null 。
等效于 eval(dialogs.rawInput(title, default))
见 dialogs.rawInput
-显示一个只包含“确定”按钮的提示对话框。
-该函数也可通过 alert(title[, content]) 来调用。调用时脚本将阻塞直至对话框被关闭。该函数无返回值。
显示一个包含“确定”和“取消”按钮的提示对话框。
-该函数也可通过 confirm(title[, content]) 来调用。调用时脚本将阻塞直至对话框被关闭。如果用户点击“确定”则返回 true ,否则返回 false 。
显示一个带有选项列表的对话框。
-该函数也可通过 dialogs.select(title, ...items) 来调用。
例如: dialogs.select("标题", ["A", "B", "C"]) 可以用 dialogs.select("标题", "A", "B", "C") 替代。
调用时脚本将阻塞直至对话框被关闭。如果用户点击了对话框中的某个选项,该函数会返回该选项的位置(选中第一个选项返回0,第二个选项返回1,以此类推),否则返回-1。
-显示一个带有单选框选项列表的对话框。
-调用时脚本将阻塞直至对话框被关闭。如果用户选中了对话框中的某个选项并点击“确定”,该函数会返回该选项的位置(选中第一个选项返回0,第二个选项返回1,以此类推),否则返回-1。
-显示一个带有多选框选项列表的对话框。
-调用时脚本将阻塞直至对话框被关闭。如果用户点击“确定”按钮,该函数会返回所有已选选项的位置组成的数组,否则返回空数组。 -
- -engines模块包含了一些与脚本引擎有关的函数,包括运行其他脚本,关闭脚本等。
-在新线程中运行脚本script。返回一个ScriptExectuion对象。
-path <string> 要运行的脚本路径。config \在新线程中运行脚本文件path。返回一个ScriptExecution对象。
-path <string> 要运行的录制文件路径。config \在新线程中运行录制文件path。返回一个ScriptExecution对象。
-停止所有正在运行的脚本。包括当前脚本自身。
-停止所有正在运行的脚本并显示停止的脚本数量。包括当前脚本自身。
-返回当前脚本的脚本引擎对象(ScriptEngine)
-执行脚本时返回的对象,可以通过他获取执行的引擎、配置、源码等。
-返回执行该脚本的脚本引擎对象(ScriptEngine)
-返回该脚本的运行配置(ScriptConfig)
-返回该脚本的源码对象(ScriptSource)
-停止脚本引擎的执行。
-tagName <string> 名称返回对应于tagName的附加在该脚本引擎上的额外信息。tagName包括:
-source 该脚本引擎当前正在执行的源码(ScriptSource)execute_path 该脚本引擎当前执行的路径停止脚本引擎的执行。
-脚本执行时的配置。
-延迟执行的毫秒数
-循环运行时两次运行之间的时间间隔
-循环运行次数
-返回一个字符串数组表示脚本运行时模块寻找的路径。
-脚本执行时的源码对象。可以是字符串源码、文件源码等。
-如果该源码是文件脚本,则可以通过toString()得到该文件的路径。
返回该源码的名称。
-返回执行该源码的脚本引擎的名称。
- - -Auto.js 有一个简单的模块加载系统。 在 Auto.js 中,文件和模块是一一对应的(每个文件被视为一个独立的模块)。
-例子,假设有一个名为 foo.js 的文件:
-const circle = require('./circle.js');
-console.log(`半径为 4 的圆的面积是 ${circle.area(4)}`);
-在第一行中,foo.js 加载了同一目录下的 circle.js 模块。
-circle.js 文件的内容为:
-const { PI } = Math;
-
-exports.area = (r) => PI * r ** 2;
-
-exports.circumference = (r) => 2 * PI * r;
-circle.js 模块导出了 area() 和 circumference() 两个函数。 通过在特殊的 exports 对象上指定额外的属性,函数和对象可以被添加到模块的根部。
-模块内的本地变量是私有的,因为模块被 Node.js 包装在一个函数中(详见模块包装器)。 在这个例子中,变量 PI 是 circle.js 私有的。
-module.exports属性可以被赋予一个新的值(例如函数或对象)。
-如下,bar.js 会用到 square 模块,square 导出一个构造函数:
-const square = require('./square.js');
-const mySquare = square(2);
-console.log(`正方形的面积是 ${mySquare.area()}`);
-square 模块定义在 square.js 中:
-
-// 赋值给 `exports` 不会修改模块,必须使用 `module.exports`
-module.exports = function(width) {
- return {
- area: () => width ** 2
- };
-};
-
-
-
+ @include overview +@include qa +@include globals +@include widgets-based-automation +@include coordinates-based-automation +@include images +@include console +@include events +@include timers +@include shell +@include ui +@include files +@include app +@include http +@include dialogs +@include engines +@include modules +@include work-with-java
path <string> 路径encoding <string> 字符编码读取文件path的所有内容并返回。
+读取文本文件path的所有内容并返回一个字符串。
+path <string> 路径读取文件path的所有内容并返回一个字节数组。
+注意,该数组是Java的数组,不具有JavaScript数组的函数。
把text写入到文件path中。如果文件存在则覆盖,不存在则创建。
+path <string> 路径bytes <byte[]> 字节数组,要写入的二进制数据把bytes写入到文件path中。如果文件存在则覆盖,不存在则创建。
+把text追加到文件path的末尾。如果文件不存在则创建。
+path <string> 路径bytes <byte[]> 字节数组,要写入的二进制数据把bytes追加到文件path的末尾。如果文件不存在则创建。
fromPath <string> 要复制的原文件路径When called, util.deprecate() will return a function that will emit a
DeprecationWarning using the process.on('warning') event. By default,
this warning will be emitted and printed to stderr exactly once, the first
-timeFlag it is called. After the warning is emitted, the wrapped function
+time it is called. After the warning is emitted, the wrapped function
is called.
If either the --no-deprecation or --no-warnings command line flags are
used, or if the process.noDeprecation property is set to true prior to
the first deprecation warning, the util.deprecate() method does nothing.
If the --trace-deprecation or --trace-warnings command line flags are set,
or the process.traceDeprecation property is set to true, a warning and a
-stack trace are printed to stderr the first timeFlag the deprecated function is
+stack trace are printed to stderr the first time the deprecated function is
called.
If the --throw-deprecation command line flag is set, or the
process.throwDeprecation property is set to true, then an exception will be
@@ -447,7 +449,7 @@ via the util.inspect.styles and util.inspect.colors pr
regexp - rednull - boldundefined - greyspecial - cyan (only applied to functions at this timeFlag)special - cyan (only applied to functions at this time)name - (no styling)The predefined color codes are: white, grey, black, blue, cyan,
diff --git a/app/src/main/assets/docs/widgets-based-automation.html b/app/src/main/assets/docs/widgets-based-automation.html
index 2a4cacc6..7ab3c5aa 100644
--- a/app/src/main/assets/docs/widgets-based-automation.html
+++ b/app/src/main/assets/docs/widgets-based-automation.html
@@ -34,12 +34,14 @@