用autojs写了一个用来随时记单词的apk

在这里插入图片描述

“ui”;
ui.layout(


<horizontal>
	<button textColor="green" id="b1" text="置底" style="Widget.AppCompat.Button.Borderless" w="auto" h="auto" />
	<text id="t1" textSize="20sp" textColor="green" text="{{this.word1}}"></text>
</horizontal>
<horizontal>
	<button textColor="green" id="b2" text="置底" style="Widget.AppCompat.Button.Borderless" w="auto" h="auto" />
	<text id="t2"textSize="20sp" textColor="green" text="{{this.word2}}"></text>
</horizontal>
<horizontal>
	<button textColor="green" id="b3" text="置底" style="Widget.AppCompat.Button.Borderless" w="auto" h="auto" />
	<text id="t3"textSize="20sp" textColor="green"text="{{this.word3}}"></text>
</horizontal>
<horizontal>
	<button textColor="green" id="b4" text="置底" style="Widget.AppCompat.Button.Borderless" w="auto" h="auto" /><text
		id="t4"textSize="20sp" textColor="green" text="{{this.word4}}"></text>
</horizontal>
<horizontal>
	<button textColor="green" id="b5" text="置底" style="Widget.AppCompat.Button.Borderless" w="auto" h="auto" /><text
		id="t5"textSize="20sp" textColor="green" text="{{this.word5}}"></text>
</horizontal>
<horizontal>
	<button textColor="green" id="b6" text="置底" style="Widget.AppCompat.Button.Borderless" w="auto" h="auto" /><text
		id="t6"textSize="20sp" textColor="green" text="{{this.word6}}"></text>
</horizontal>
<horizontal>
	<button textColor="green" id="b7" text="置底" style="Widget.AppCompat.Button.Borderless" w="auto" h="auto" /><text
		id="t7"textSize="20sp" textColor="green" text="{{this.word7}}"></text>
</horizontal>
<horizontal>
	<button textColor="green" id="b8" text="置底" style="Widget.AppCompat.Button.Borderless" w="auto" h="auto" /><text
		id="t8"textSize="20sp" textColor="green" text="{{this.word8}}"></text>
</horizontal>
<horizontal>
	<button textColor="green" id="b9" text="置底" style="Widget.AppCompat.Button.Borderless" w="auto" h="auto" /><text
		id="t9"textSize="20sp" textColor="green" text="{{this.word9}}"></text>
</horizontal>
<horizontal>
	<button textColor="green" id="b10" text="置底" style="Widget.AppCompat.Button.Borderless" w="auto" h="auto" /><text
		id="t10"textSize="20sp" textColor="green" text="{{this.word10}}"></text>
</horizontal>
<horizontal>
	<button textColor="green" id="b11" text="更新" style="Widget.AppCompat.Button.Borderless" w="auto" h="auto" />
	<input id="newWord" hint="点我输入新单词" textColor="green"textColorHint="green"textSize="15sp" />
</horizontal>
); var b = new Array(10); var temp=0; var storage = storages.create("tenWords");

var tenWords = storage.get(“items”, [
{
word1: “单词1”,
word2: “单词2”,
word3: “单词3”,
word4: “单词4”,
word5: “单词5”,
word6: “单词6”,
word7: “单词7”,
word8: “单词8”,
word9: “单词9”,
word10: “单词10”
}
]);;

ui.tenWords.setDataSource(tenWords);

function startCount(){
for(let key in tenWords[0]){
b[temp]=tenWords[0][key];
temp++;
if(temp10){temp=0;}
}
}
function downUpdate(position){
var temp=b[position];
for(let i=position+1;i<10;i++){
b[i-1]=b[i];
}
b[9]=temp;
}
function newUpdate(newWord){
for(let i=0;i<9;i++){
b[i]=b[i+1];
}
b[9]=newWord;
}
function overCount(){
for(let key in tenWords[0]){
tenWords[0][key]=b[temp];
temp++;
if(temp
10){temp=0;}
}
ui.tenWords.setDataSource(tenWords);
storage.put(“items”, tenWords);
}
ui.tenWords.on(“item_bind”,function(itemView, itemHolder){

itemView.b1.on("click", function(){
  startCount();
downUpdate(0);
overCount();
});
itemView.b2.on("click", function(){
  startCount();
downUpdate(1);
overCount();
});
itemView.b3.on("click", function(){
  startCount();
downUpdate(2);
overCount();
});
itemView.b4.on("click", function(){
  startCount();
downUpdate(3);
overCount();
});
itemView.b5.on("click", function(){
  startCount();
downUpdate(4);
overCount();
});
itemView.b6.on("click", function(){
  startCount();
downUpdate(5);
overCount();
});
itemView.b7.on("click", function(){
  startCount();
downUpdate(6);
overCount();
});
itemView.b8.on("click", function(){
  startCount();
downUpdate(7);
overCount();
});
itemView.b9.on("click", function(){
  startCount();
downUpdate(8);
overCount();
});
itemView.b10.on("click", function(){
  startCount();
downUpdate(9);
overCount();
});
itemView.b11.on("click", function(){
  startCount();
newUpdate(ui.newWord.text());
overCount();
itemView.newWord.setText("");
});
itemView.t1.on("click", function(){
  let item = itemHolder.item;
  ui.webView.loadUrl("https://fanyi.baidu.com/?aldtype=38319#en/zh/"+itemView.t1.text());
  
});
itemView.t2.on("click", function(){
  let item = itemHolder.item;
  ui.webView.loadUrl("https://fanyi.baidu.com/?aldtype=38319#en/zh/"+itemView.t2.text());

});
itemView.t3.on("click", function(){
  let item = itemHolder.item;
  ui.webView.loadUrl("https://fanyi.baidu.com/?aldtype=38319#en/zh/"+itemView.t3.text());

});
itemView.t4.on("click", function(){
  let item = itemHolder.item;
  ui.webView.loadUrl("https://fanyi.baidu.com/?aldtype=38319#en/zh/"+itemView.t4.text());

});
itemView.t5.on("click", function(){
  let item = itemHolder.item;
  ui.webView.loadUrl("https://fanyi.baidu.com/?aldtype=38319#en/zh/"+itemView.t5.text());

});
itemView.t6.on("click", function(){
  let item = itemHolder.item;
  ui.webView.loadUrl("https://fanyi.baidu.com/?aldtype=38319#en/zh/"+itemView.t6.text());

});
itemView.t7.on("click", function(){
  let item = itemHolder.item;
  ui.webView.loadUrl("https://fanyi.baidu.com/?aldtype=38319#en/zh/"+itemView.t7.text());

});
itemView.t8.on("click", function(){
  let item = itemHolder.item;
  ui.webView.loadUrl("https://fanyi.baidu.com/?aldtype=38319#en/zh/"+itemView.t8.text());

});
itemView.t9.on("click", function(){
  let item = itemHolder.item;
  ui.webView.loadUrl("https://fanyi.baidu.com/?aldtype=38319#en/zh/"+itemView.t9.text());

});
itemView.t10.on("click", function(){
  let item = itemHolder.item;
  ui.webView.loadUrl("https://fanyi.baidu.com/?aldtype=38319#en/zh/"+itemView.t10.text());

});

})

function callJavaScript(webViewWidget, script, callback) {
try {
console.assert(webViewWidget != null, “webView控件为空”);
//console.log(script.toString())
webViewWidget.evaluateJavascript(“javascript:” + script, new JavaAdapter(android.webkit.ValueCallback, {
onReceiveValue: (val) => {
if (callback) {
callback(val);
}
}
}));
} catch (e) {
console.error(“执行JavaScript失败”);
console.trace(e);
}
}

function AutoX() {
let getAutoXFrame = () => {
let bridgeFrame = document.getElementById(“AutoXFrame”);
if (!bridgeFrame) {
bridgeFrame = document.createElement(‘iframe’);
bridgeFrame.id = “AutoXFrame”;
bridgeFrame.style = “display: none”;
document.body.append(bridgeFrame);
}
return bridgeFrame;
};
const h5Callbackers = {};
let h5CallbackIndex = 1;
let setCallback = (callback) => {
let callId = h5CallbackIndex++;
h5Callbackers[callId] = {
“callback”: callback
};
return callId;
};
let getCallback = (callId) => {
let callback = h5Callbackers[callId];
if (callback) {
delete h5Callbackers[callId];
}
return callback;
};

function invoke(cmd, params, callback) {
    let callId = null;
    try {
        let paramsStr = JSON.stringify(params);
        let AutoXFrame = getAutoXFrame();
        callId = setCallback(callback);
        AutoXFrame.src = "jsbridge://" + cmd + "/" + callId + "/" + encodeURIComponent(paramsStr);
    } catch (e) {
        if (callId) {
            getCallback(callId);
        }
        console.trace(e);
    }
};
let callback = (data) => {
    let callId = data.callId;
    let params = data.params;
    let callbackFun = getCallback(callId);
    if (callbackFun) {
        callbackFun.callback(params);
    }
};
return {
    invoke: invoke,
    callback: callback
};

};
function bridgeHandler_handle(cmd, params) {
console.log(‘bridgeHandler处理 cmd=%s, params=%s’, cmd, JSON.stringify(params));
let fun = this[cmd];
if (!fun) {
throw new Error(“cmd= " + cmd + " 没有定义实现”);
}
let ret = fun(params)
return ret;
}
function mFunction(params) {
// toastLog(params.toString());
// device.vibrate(120);
return files.isDir(’/storage/emulated/0/Download’)//‘toast提示成功’;
}
function webViewExpand_init(webViewWidget) {
webViewWidget.webViewClient = new JavaAdapter(android.webkit.WebViewClient, {
onPageFinished: (webView, curUrl) => {
try {
// 注入 AutoX
callJavaScript(webView, AutoX.toString() + “;var auto0 = AutoX();auto0.invoke(‘mFunction’,‘This is AutoX!’,(data) => {console.log(‘接收到callback1:’ + JSON.stringify(data));});”, null);
} catch (e) {
console.trace(e)
}
},
shouldOverrideUrlLoading: (webView, request) => {
let url = ‘’;
try {
url = (request.a && request.a.a) || (request.url);
if (url instanceof android.net.Uri) {
url = url.toString();
}
if (url.indexOf(“jsbridge://”) == 0) {
let uris = url.split("/");
let cmd = uris[2];
let callId = uris[3];
let params = java.net.URLDecoder.decode(uris[4], “UTF-8”);
console.log(‘AutoX处理JavaScript调用请求: callId=%s, cmd=%s, params=%s’, callId, cmd, params);
let result = null;
try {
result = bridgeHandler_handle(cmd, JSON.parse(params));
} catch (e) {
console.trace(e);
result = {
message: e.message
};
}
result = result || {};
webView.loadUrl(“javascript:auto0.callback({‘callId’:” + callId + “, ‘params’: " + JSON.stringify(result) + “});”);
} else if (url.startsWith(“http://”) || url.startsWith(“https://”) || url.startsWith(“file://”) || url.startsWith(“ws://”) || url.startsWith(“wss://”)) {
webView.loadUrl(url);
} else {
}
return true;
} catch (e) {
if (e.javaException instanceof android.content.ActivityNotFoundException) {
webView.loadUrl(url);
} else {
toastLog('无法打开URL: ’ + url);
}
console.trace(e);
}
},
onReceivedError: (webView, webResourceRequest, webResourceError) => {
let url = webResourceRequest.getUrl();
let errorCode = webResourceError.getErrorCode();
let description = webResourceError.getDescription();
console.trace(errorCode + " " + description + " " + url);
}
});
webViewWidget.webChromeClient = new JavaAdapter(android.webkit.WebChromeClient, {
onConsoleMessage: (msg) => {
console.log(”[%s:%s]: %s", msg.sourceId(), msg.lineNumber(), msg.message());
}
});
}

webViewExpand_init(ui.webView)
ui.webView.loadUrl(“https://fanyi.baidu.com/?aldtype=38319#en/zh/”);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
autojsapk Auto.js使用JavaScript作为脚本语言,目前使用Rhino 1.7.7.2作为脚本引擎,支持ES5与部分ES6特性。 因为Auto.js是基于JavaScript的,学习Auto.js的API之前建议先学习JavaScript的基本语法和内置对象,可以使用教程前面的两个JavaScript教程链接来学习。 如果您想要使用TypeScript来开发,目前已经有开发者公布了一个可以把使用TypeScript进行Auto.js开发的工具,参见Auto.js DevTools。 如果想要在电脑而不是手机上开发Auto.js,可以使用VS Code以及相应的Auto.js插件使得在 电脑上编辑的脚本能推送到手机运行,参见Auto.js-VSCode-Extension。 本文档的章节大致上是以模块来分的,总体上可以分成"自动操作"类模块(控件操作、触摸模拟、按键模拟等)和其他类模块(设备、应用、界面等)。 "自动操作"的部分又可以大致分为基于控件和基于坐标的操作。基于坐标的操作是传统按键精灵、触摸精灵等脚本软件采用的方式,通过屏幕坐标来点击、长按指定位置模拟操作,从而到达目的。例如click(100, 200), press(100, 200, 500)等。这种方式在游戏类脚本中比较有可行性,结合找图找色、坐标放缩功能也能达到较好的兼容性。但是,这种方式对一般软件脚本却难以达到想要的效果,而且这种方式需要安卓7.0版本以上或者root权限才能执行。所以对于一般软件脚本(例如批量添加联系人、自动提取短信验证码等等),我们采用基于控件的模拟操作方式,结合通知事情、按键事情等达成更好的工作流。这些部分的文档参见基于控件的操作和基于坐标的操作。 其他部分主要包括: app: 应用。启动应用,卸载应用,使用应用查看、编辑文件、访问网页,发送应用间广播等。 console: 控制台。录运行的日志、错误、信息等。 device: 设备。获取设备屏幕宽高、系统版本等信息,控制设备音量、亮度等。 engines: 脚本引擎。用于启动其他脚本。 events: 事件与监听。按键监听,通知监听,触摸监听等。 floaty: 悬浮窗。用于显示自定义的悬浮窗。 files: 文件系统。文件创建、获取信息、读。 http: HTTP。发送HTTP请求,例如GET, POST等。 images, colors: 图片和图色处理。截图,剪切图片,找图找色,读取保存图片等。 keys: 按键模拟。比如音量键、Home键模拟等。 shell: Shell命令。 threads: 多线程支持。 ui: UI界面。用于显示自定义的UI界面,和用户交互。 除此之外,Auto.js内置了对Promise。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值