全局模块
说明
全局模块是指直接调用方法就可以使用的模块,无需使用前缀对象名称
中控版本
version 获取中控版本
- 获取中控版本
- @return 字符串 例如 2.9.0
function main() {
logd(version())
}
main();
插件模块加载
loadDex 载入jar包
- 载入dex文件
- @param path 路径,加载顺序分别是插件目录(例如 ab.jar)或者是文件路径(例如 D:/ab.jar)加载
- @return true 载入成功, false载入失败
function main() {
//直接填文件名,会从项目的plugin插件目录加载
loadDex("ocr.apk");
//填绝对路径,则从电脑路径中加载
loadDex("D:/a.jar");
// a.apk中存在com.A这个这个类,可以直接使用
var obj = new com.A();
}
main();
require 导入JS
- 导入JS模块
- @param path 路径,例如 本地D:/a.js或者 EC工程中的文件路径 slib/a.js
- @return 模块对象
function main() {
//注意,js文件不要放在js目录或下级目录中
test = require("slib/a.js")
logd(test.c());
}
main();
//视频介绍:https://www.bilibili.com/video/BV1ES4y1f7qV?vd_source=2abc6be820f5a6382ebc0ceafc5dbe00&p=39&spm_id_from=333.788.videopod.episodes
importClass 导入JAVA类
- 导入java的class给js用
- @param clz class的名称例如: com.A
function main() {
importClass(com.A);
var obj = new com.A();
}
main();
importPackage 导入JAVA包
- 导入java包下面所有类给js用
- @param clz class的名称例如: com.b
function main() {
importPackage(com.b);
var obj = new com.b.A();
}
main();
脚本启停
exit 退出脚本
exit();
isScriptExit 是否已退出脚本
- 判断EC运行的当前线程是否处于退出状态,可用判断脚本是否退出,或者子线程是否退出
- @return true 已退出
function main() {
try {
while (true) {
sleep(1000)
logd("222")
if (isScriptExit()) {
break
}
}
logd("222")
} catch (e) {
logd(e)
if (isScriptExit()) {
return
}
}
}
main();
sleep 暂停执行
- 休眠
- @param miSecond 毫秒
function main() {
sleep(1000);
}
main();
execScript 载入JS
- 执行JS文件或者内容, [如果出现illegalStateException,可以尝试修改eval函数执行js脚本]
- eval函数是js自带的,直接传入js内容就行
- @param type 1=文件,2=直接是JS内容
- @param content 路径例如D:/a.js或者js的内容
- @return 布尔型,true代表执行成功, false代表失败
function main() {
var d = 'while(true){sleep(1000);logd(111111);}';
thread.execAsync(function () {
//execScript(1,"D:/ad.js")
execScript(2, d);
});
while (true) {
sleep(2000);
loge("fsadffsad")
}
}
main();
restartScript 重启脚本
- 重启脚本,适合无限循环,或者有异常的情况可以再次执行,
- 注意: 该方法威力巨大,请自行控制好是否自动重启,否则只能强杀进程才能停止
- @param path 新的IEC路径,如果不需要可以填写null
- @param stopCurrent 是否停止当前的脚本
- @param delay 延迟多少秒后执行
- @return bool true 代表成功 false 代表失败
function main() {
logd("我是在脚本运行的");
setStopCallback(function () {
restartScript(null, true, 3)
});
//setExceptionCallback(function (){
// restartScript(null,true,3)
//});
sleep(1000);
logd("脚本结束")
}
main();
setScriptPause 设置脚本暂停或者继续
- 设置脚本暂停或者继续
- 适配 EC 鸿蒙Next 1.0.0+
- @param pause true 代表暂停脚本,false代表继续
- @param timeout 自动恢复时间单位毫秒,0 代表不自动恢复,等待外部交互后恢复,大于0代表到了时间自动恢复运行
- @return
{boolean}
true 代表脚本处于暂停中,false 代表继续运行中
function main() {
sleep(1000);
logd("start....")
// 代表暂停脚本执行,3秒后会自动化继续
// 这里仅仅是演示,实际情况需要根据自己的业务逻辑做判断或者从ui进行暂停脚本
setScriptPause(true, 3000)
logd("我是三秒后的日志")
}
main();
isScriptPause 脚本是否处于暂停中
- 脚本是否处于暂停中
- 适配 EC 鸿蒙Next 1.0.0+
- @return
{boolean}
true 代表脚本处于暂停中
function main() {
sleep(1000);
logd("start....")
// 代表暂停脚本执行,3秒后会自动化继续
// 这里仅仅是演示,实际情况需要根据自己的业务逻辑做判断或者从ui进行暂停脚本
// 仅仅是函数调用演示,实际情况根据业务处理
logd("isScriptPause " + isScriptPause())
setScriptPause(true, 3000)
logd("isScriptPause " + isScriptPause())
logd("我是三秒后的日志")
}
main();
JSON处理
JSON.stringify 格式化为JSON字符串
- 格式化对象为JSON字符串
- @param 对象
- @return 字符串
function main() {
var m = {"sss": "a"};
var d = JSON.stringify(m);
logd(d);
}
main();
JSON.parse 转换为JSON对象
- 格式化JSON字符串为对象
- @param 字符串
- @return 对象
function main() {
let m = `{"sss": "a"}`
let d = JSON.parse(m);
logd(d);
}
main();
监 听脚本和服务
setStopCallback 脚本停止监听
- 脚本开头执行一次
function main() {
setStopCallback(function () {
logd("fdsafsad 我是停止回调")
});
var result = sleep(1000);
if (result) {
logd("成功");
} else {
logd("失败");
}
}
main();
setExceptionCallback 脚本异常停止监听
- 脚本开头执行一次
function main() {
setExceptionCallback(function (msg) {
logd(" 异常停止消息: " + msg)
});
var result = sleep(1000);
if (result) {
logd("成功");
} else {
logd("失败");
}
//这里有异常抛出
result.length();
}
main();
日志消息方法
setLogLevel 设置日志的等级
- 设置日志的等级,可以根据情况关闭或开启日志
- 文件保存在中控安装目录的的logs/device下
- @param level 日 志等级,值分别是 debug,info,warn,error,off,排序分别是
debug < info < warn < error < off
, - 例如 off代表关闭所有级别日志,debug代表打印包含logd,logi,logw,loge的日志,info代表打印包含logi,logw,loge的日志,warn 代表打印包含logw,loge的日志
- @param displaylogd 是否展示logd消息
- @return
{bool}
布尔型 true代表成功 false代表失败
function main() {
setLogLevel("info", false)
for (var i = 0; i < 1; i++) {
sleep(10);
//logd(time()+" debug");
logi(time() + " info");
//logw(time()+" warn");
// loge(time()+" error");
logd("--- " + time());
}
//logd(time()+" 222");
}
main();
setDeviceRecordLog 记录日志
- 设置当前设备记录并保存日志
- 默认是不记录
- 适配 EC 鸿蒙Next 1.0.0+
- @param open true 代表记录到文件,false代表不处理
- @param level 日志等级,值分别是 debug,info,warn,error,off,排序分别是
debug<info<warn<error<off
, - 例如 off代表关闭所有级别日志,debug代表打印包含logd,logi,logw,loge的日志,info代表打印包含logi,logw,loge的日志,warn 代表打印包含logw,loge的日志
- @return
{bool}
布尔型 true代表成功 false代表失败
function main() {
setDeviceRecordLog(true, "", debug)
for (var i = 0; i < 1; i++) {
sleep(10);
//logd(time()+" debug");
logi(time() + " info");
//logw(time()+" warn");
// loge(time()+" error");
logd("--- " + time());
}
//logd(time()+" 222");
}
main();
logd 调试日志
- 调试日志
- @param msg 消息字符串
function main() {
logd("msg");
//可变参数写法
logd("我是消息{},{}", "测试1", 2)
}
main();
loge 错误日志
- 错误日志
- @param msg 消息字符串
function main() {
loge("msg");
//可变参数写法
loge("我是消息{},{}", "测试1", 2)
}
main();
logw 警告日志
- 警告日志
- @param msg 消息字符串
function main() {
logw("msg");
//可变参数写法
logw("我是消息{},{}", "测试1", 2)
}
main();
logi 信息日志
- 信息日志
- @param msg 消息字符串
function main() {
logi("msg");
//可变参数写法
logi("我是消息{},{}", "测试1", 2)
}
main();