來自博客搬家 https://blog.csdn.net/oliverchu/article/details/79573813
本腳本支持僅19201080 像素分辨率的機子上面正常運行离咐。*
-------------------------------------------------------------------------------
我是真的懶,連能量都不想好好收,因此寫了腳本來自動幫我收能量.
**Auto.js **這款腳本應用我們在應用市場可以很方便搜索到,它在沒有root的時候可以通過開啟無障礙服務來實現(xiàn)模擬點擊滑動,監(jiān)聽等等.使用下面這個腳本,可以實現(xiàn)打開支付寶,進入螞蟻森林(你得將它添加到主頁常用子應用中),滑動,查找有能量的好友,進入收集惫皱。
好好享用叹谁,那么上代碼:
/**
*
* @name 支付寶自動收能量腳本
* @author Oliver
* @description 需要您的設備分辨率為1920*1080;小米8上扒磁,截圖需要手動允許,需要點擊 “立即開始”; 開始運行時請保證支付寶已經(jīng)處于首頁
*/
auto();
main();
/**
* 下面注釋代碼可以進一步完善,讀取到可以收取的時間访递,做個記錄粒梦,然后到時間自動進去收集
*
events.observeNotification();
events.onToast(function (toast) {
var text = toast.getText();
var appName = toast.getPackageName();
var subIdx = text.indexOf("后");
if (appName == "com.eg.android.AlipayGphone" && subIdx != -1) {
var sub = text.substring(0, subIdx);
var idxHour = sub.indexOf("小時");
var idxMin = sub.indexOf("分");
var hour = 0;
var min = 0;
if (idxHour == -1) {
var stringMin = sub.substring(0, idxMin);
min = parseInt(stringMin)
} else {
var stringHour = sub.substring(0, idxHour);
var stringMin = sub.substring(idxHour + 2, idxMin);
hour = parseInt(stringHour)
min = parseInt(stringMin)
}
var time = (hour * 60 + min) * 60 * 1000;
if (nextTime > time) {
nextTime = time;
}
log("NextTime=" + hour + ":" + min + " Microseconds=" + nextTime + "ms");
}
});
//setTimeout(function() {
//}, 1000*1);
// main();
var nextTime = 900000000000;
*/
var end = false;
function main() {
toast("程序開始運行亮航!");
launchApp("支付寶");
sleep(3000);
click("螞蟻森林"); //為了這后面正常運行,將螞蟻森林放在支付寶首頁中
sleep(3000);
collect();
swipe(540, 1910, 540, 100, 500)
swipe(540, 1910, 540, 100, 500)
swipe(540, 1910, 540, 100, 500)
click(672, 954); //查看排行榜
sleep(2000);
swipe(540, 1800, 540, 1800 - 240, 500);
sleep(500);
toast("現(xiàn)在開始收集能量了谍倦!");
while (!end) {
execute();
}
}
function execute() {
swipe(540, 1919, 540, 88, 500)
col();
swipe(540, 1734, 540, 1734 - 156, 500)
click(540, 1918);
sleep(2000);
swipe(540, 1857, 540, 155, 500);
sleep(1000);
col();
}
function col() {
if (!requestScreenCapture()) {
toast("沒有截圖權(quán)限塞赂,程序退出!");
exit();
end = true;
}
var img = captureScreen();
for (var i = 187; i <= 1816; i = i + 200) {
if (isEnd(img, i)) {
back();
sleep(1000);
back();
sleep(1000);
back();
sleep(1000);
toast("完成任務啦昼蛀!")
end = true
}
var p = getColor(img, i);
if (p) {
click(1017, p.y + 20);
sleep(3000);
collect();
back();
sleep(1000);
} else {
log(i + " p=null");
}
}
}
function getColor(img, y) {
var p = findColor(img, "#30bf6c", {
region: [1017, y, 63, 100]
});
return p;
}
function isEnd(img, y) {
var p = findColor(img, "#30bf6c", {
region: [860, y, 10, 10]
});
if (p) {
return true;
} else {
return false;
}
}
function collect() {
for (var y = 460; y <= 860; y += 100) {
for (var x = 185; x <= 890; x += 100) {
click(x, y);
}
}
}
image.gif
Python中的實現(xiàn),我們使用android的自動化測試庫uiautomator來實現(xiàn),使用opencv來實現(xiàn)對截圖的中可搜集小手的識別,目前還不是很完善,提供一個思路,希望有時間的你來實現(xiàn),其實Auto.js那個真的好用;-)
#! -*- coding=utf-8 -*-
from uiautomator import Device
from uiautomator import Adb
import os
import cv2
import numpy as np
from matplotlib import pyplot as plt
def match():
img = cv2.imread("1.png",0)
img2 = img.copy()
template = cv2.imread("match.png",0)
w,h = template.shape[::-1]
# method = eval('cv2.TM_CCOEFF')
method = eval('cv2.TM_CCOEFF_NORMED')
res = cv2.matchTemplate(img2,template,method)
threshold = 0.5
loc = np.where( res >= threshold)
arr = []
for pt in zip(*loc[::-1]):
cv2.rectangle(img, pt, (pt[0] + w, pt[1] + h), (0,0,255), 2)
d = (pt,(pt[0] + w, pt[1] + h),)
arr.append(d)
cv2.imwrite('res.png',img)
return arr
if __name__ == "__main__":
d = Device("7cba0eb")
# d.screen.on()
# a = Adb()
# os.system("adb shell am start -n com.eg.android.AlipayGphone/.AlipayLogin")
# # a.cmd("shell am start -n com.eg.android.AlipayGphone/.AlipayLogin")
# d(text="螞蟻森林").click()
# # d(text="種樹").click(
# print d.info
# d.wait.idle()
# d.wait.update()
# d.screenshot("1.png")
# d(scrollable=True).fling()
# web = d(className="com.uc.webview.export.WebView")
# web = d(className="com.uc.webkit.WebView")
# web.scroll.toEnd()
# web.swipe.down()
# web.click(800,940)
# d.wait.update()
# web = d(className="com.uc.webview.export.WebView")
d.screenshot("1.png")
loc= match()
print loc
# print (tl[0]+br[0])/2,(tl[1]+br[1])/2
# d.click((tl[0]+br[0])/2,(tl[1]+br[1])/2)
# d.wait.update()
# for y in range(400,870,100):
# for x in range(50,1080,100):
# d.click(x,y)
image.gif