Python&Auto.js:實(shí)現(xiàn)螞蟻森林自動收能量(懶人的高效生活)

來自博客搬家 https://blog.csdn.net/oliverchu/article/details/79573813

本腳本支持僅19201080 像素分辨率的機(jī)子上面正常運(yùn)行。*

-------------------------------------------------------------------------------

我是真的懶,連能量都不想好好收,因此寫了腳本來自動幫我收能量.

**Auto.js **這款腳本應(yīng)用我們在應(yīng)用市場可以很方便搜索到,它在沒有root的時候可以通過開啟無障礙服務(wù)來實(shí)現(xiàn)模擬點(diǎn)擊滑動,監(jiān)聽等等.使用下面這個腳本,可以實(shí)現(xiàn)打開支付寶,進(jìn)入螞蟻森林(你得將它添加到主頁常用子應(yīng)用中),滑動,查找有能量的好友,進(jìn)入收集。

好好享用,那么上代碼:

/**
 * 
 * @name 支付寶自動收能量腳本
 * @author Oliver
 * @description 需要您的設(shè)備分辨率為1920*1080;小米8上,截圖需要手動允許,需要點(diǎn)擊 “立即開始”; 開始運(yùn)行時請保證支付寶已經(jīng)處于首頁
 */

auto();
main();

/**
 * 下面注釋代碼可以進(jìn)一步完善,讀取到可以收取的時間,做個記錄,然后到時間自動進(jìn)去收集
 * 
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("程序開始運(yùn)行!");
    launchApp("支付寶");
    sleep(3000);
    click("螞蟻森林"); //為了這后面正常運(yùn)行,將螞蟻森林放在支付寶首頁中
    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("完成任務(wù)啦!")
            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中的實(shí)現(xiàn),我們使用android的自動化測試庫uiautomator來實(shí)現(xiàn),使用opencv來實(shí)現(xiàn)對截圖的中可搜集小手的識別,目前還不是很完善,提供一個思路,希望有時間的你來實(shí)現(xiàn),其實(shí)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
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容