隐藏

autoJS pro-手机自动化脚本(douyin App模拟人工操作点赞、评论、收藏、转发)

发布:2023/10/19 23:20:52作者:管理员 来源:本站 浏览次数:805

autoJS自动化


本人是一个web前端开发工程师,没想到可以用javascript来实现手机自动化,就有了之后的一系列文章,有好建议的同学欢迎评论区分享 ;-)


专栏地址:点击此处


在这里插入图片描述


文章目录


   autoJS自动化

   开发环境

   链接

   背景

   功能

       1. 打开douyin极速版

       2. 自定义函数实现点击功能

       3. 基本操作

   源文件


开发环境


不同的环境可能导致部分代码运行有问题,所以开发者要确定好自己对应的环境


   autojs版本:Pro 9.2.13-0

   手机型号:小米8

   android版本:10

   开发工具:vscode

   vscode连接插件:Auto.js-Pro-Ext

   脚本对应软件:douyin极速版 version22.3.0


链接


   autojs参考文档:点击

   CSDN专栏:点击

   gitee地址:点击


背景


女朋友的douyin号每次更新总要叫我去帮他点赞、评论、收藏、转发,一次两次还好,后来懵了,就想着能不能做一个手机脚本,来解放双手。


   这篇文章只用来实现点赞、评论、收藏、转发 等基础操作;

   另外跳转到个人主页,跳转到指定视频页面的功能,自动下滑视频,随机执行基本操作,随机评论等…

   咋们其他文章再写~~~


功能

1. 打开douyin极速版


// 根据APP名称打开APP

app.launchApp("抖音极速版");

//  设置脚本坐标点击所适合的屏幕宽高。如果脚本运行时,屏幕宽度不一致会自动放缩坐标。这个功能可以设置屏幕上坐标点击的等比缩放效果。

setScreenMetrics(1080, 1920);



2. 自定义函数实现点击功能


这边主要封装了一个函数,用于点击屏幕,主要原理是autojs Pro 的小机器人获取布局,根据布局调用合适的API,获取到组件的rect,并且点击其中心点位置,实现模拟点击功能


/**

* @desc 根据条件点击找到组件,并且点击其中心点,并返回

* @param {*} str 输入需要找到组件里面带的文本

* @param {*} type 查找组件的类型,由此来确定需要调用什么方法

* @param {*} index 索引

* @param {*} offsetX 点击X轴偏移

* @param {*} offsetY 点击X轴偏移

* @returns

*/

function clickByTextAndType(str, type, index, offsetX, offsetY) {

 if (!str) {

   throw ("请输入需要查找的组件文本");

 }


 if (!type) {

   throw ("请输入查找组件的类型");

 }


 index = index ? index : 0;

 offsetX = offsetX ? offsetX : 0;

 offsetY = offsetY ? offsetY : 0;


 var rect = null;

 var collection = null;

 switch (type) {

   case "desc": {

     collection = descContains(str).find();

     break;

   }

   case "text": {

     collection = textContains(str).find();

     break;

   }

   default: {

     throw ("请输入正确的查找组件的类型");

     return false;

   }

 }


 // 判断有无找到组件

 if (collection.empty()) {

   throw ("没有找到该组件," + str + "," + type);

 }


 // 如果索引比长度小则拿最后一个

 if (collection.length < (index + 1)) {

   index = collection.length - 1;

 }


 // 找到了

 rect = collection[index].bounds();


 // 点击point

 var point = {

   x: rect.centerX() + offsetX,

   y: rect.centerY() + offsetY

 }

 // 点击按钮

 click(point.x, point.y);


 return point;

}


 


3. 基本操作


点赞、评论、收藏、转发只是控制点击跟输入input数据而已,这边就不细写,可以参考下面的源文件。

源文件


/*

* @Author: Penk

* @LastEditors: Penk

* @LastEditTime: 2022-09-15 17:33:26

* @FilePath: \autojs-demo\douyin基本操作.js

*/

// 根据APP名称打开APP

app.launchApp("抖音极速版");

//  设置脚本坐标点击所适合的屏幕宽高。如果脚本运行时,屏幕宽度不一致会自动放缩坐标。这个功能可以设置屏幕上坐标点击的等比缩放效果。

setScreenMetrics(1080, 1920);

sleep(5000);


var mApp = {}


/**

* @desc 根据条件点击找到组件,并且点击其中心点,并返回

* @param {*} str 输入需要找到组件里面带的文本

* @param {*} type 查找组件的类型,由此来确定需要调用什么方法

* @param {*} index 索引

* @param {*} offsetX 点击X轴偏移

* @param {*} offsetY 点击X轴偏移

* @returns

*/

function clickByTextAndType(str, type, index, offsetX, offsetY) {

 if (!str) {

   throw ("请输入需要查找的组件文本");

 }


 if (!type) {

   throw ("请输入查找组件的类型");

 }


 index = index ? index : 0;

 offsetX = offsetX ? offsetX : 0;

 offsetY = offsetY ? offsetY : 0;


 var rect = null;

 var collection = null;

 switch (type) {

   case "desc": {

     collection = descContains(str).find();

     break;

   }

   case "text": {

     collection = textContains(str).find();

     break;

   }

   default: {

     throw ("请输入正确的查找组件的类型");

     return false;

   }

 }


 // 判断有无找到组件

 if (collection.empty()) {

   throw ("没有找到该组件," + str + "," + type);

 }


 // 如果索引比长度小则拿最后一个

 if (collection.length < (index + 1)) {

   index = collection.length - 1;

 }


 // 找到了

 rect = collection[index].bounds();


 // 点击point

 var point = {

   x: rect.centerX() + offsetX,

   y: rect.centerY() + offsetY

 }

 // 点击按钮

 click(point.x, point.y);


 return point;

}


// douyin操作-点赞

mApp.zan = function () {

 clickByTextAndType("未点赞", "desc");

}


// douyin操作-评论

mApp.comment = function () {

 // 点击评论按钮

 clickByTextAndType("评论", "desc");


 sleep(random(500, 1000));

 // 输入评论

 setText(0,"素质3连,马上安排上...");


 sleep(random(1000, 5000));

 // 点击发送

 clickByTextAndType("发送", "desc");


 sleep(random(1000, 5000));

 // 点击空白处

 back();

}


// douyin操作-收藏

mApp.collect = function () {

 // 点击收藏按钮

 clickByTextAndType("未选中,收藏", "desc");

}


// douyin操作-转发

mApp.transmit = function () {

 // 点击转发按钮

 clickByTextAndType("分享", "desc");


 sleep(random(1000, 2000));

 // 私信朋友按钮

 clickByTextAndType("私信", "text");


 sleep(random(1000, 2000));

 // 私信朋友按钮

 var point = clickByTextAndType("分享", "desc", random(0, 2));


 sleep(random(1000, 2000));

 // 继续点击该位置,可以发信息

 click(point.x, point.y);


 sleep(random(1000, 2000));

 // 输入信息

 setText(0,"素质3连,马上安排上...");


 sleep(random(1000, 2000));

 // 点击发送

 clickByTextAndType("发送", "desc");

}


// 直接调用

mApp.transmit();



https://blog.csdn.net/cs492934056/article/details/126875366