Autojs页面开发

概述:

 Autojs功能很强大!  可以打包成apk文件装在手机里运行,也可以做页面UI级别的开发、本文主要对基础页面开发常用方法、demo、资料做收集, 属于比较基础的文章、大佬请略过.........

基于:Auto.js Pro版本,免费版本很多功能限制,不建议使用

 

小案例:

1.输入并获取输入的内容

"ui";

var color = "#009688";

ui.layout(
    <drawer id="drawer">
        <vertical>
            <appbar>
                <toolbar id="toolbar"  title="自动化首页"/>
                {/* <toolbar title="顶部可以加多标题"/> */}
            </appbar>
            <frame w="*" h="*">
                <vertical>
                    <card w="*" h="80" cardCornerRadius="10" gravity="center" marginTop="10">
                        <horizontal gravity="center">
                            <Switch id="autoService" text="无障碍服务" checked="{{auto.service != null}}" gravity="left" textSize="20sp" />
                            <Switch id="xfc" text="    打开悬浮窗" checked="{{(new android.provider.Settings).canDrawOverlays(context) != false}}" gravity="right" textSize="20sp" />
                        </horizontal>
                    </card>
                    <vertical gravity="center">
                        {/* center居中、 marginTop文字大小、w、h宽高、bg字体颜色*/}
                        <card gravity="center" marginTop="15xp" w="auto" h="auto" cardCornerRadius="200" >
                            <vertical gravity="center" bg="#54FF9F">
                                <text text="功能选择" />
                            </vertical>
                        </card>
                    </vertical>
                    <card w="*" cardCornerRadius="10" gravity="center" marginTop="10">
                        <vertical>
                            <horizontal>
                                <text padding="10 0 0 0" text="关注滑动延迟:" />
                                <input id="sjS" text="3" w="50" />
                                <text text="至" />
                                <input id="sjE" text="4" w="50" />
                                <text text="秒" />
                            </horizontal>
                            <horizontal>
                                <text padding="10 0 0 0" text="关注每单延迟:" />
                                <input id="mdyc" text="3" w="50" />
                                <text text="秒" />
                            </horizontal>
                            <horizontal>
                                <text padding="10 0 0 0" text="总共关注" />
                                <text text="次数:" />
                                <input id="yc" text="60" w="50" />
                                <text text="次" />
                            </horizontal>
                            <horizontal>
                                <button w="*" id="start" style="Widget.AppCompat.Button.Colored" text="运行"/>
                            </horizontal>
                        </vertical>
                    </card>
                </vertical>
            </frame>
        </vertical>
        <vertical layout_gravity="left" bg="#ffffff" w="280">
            <img w="280" h="400" scaleType="fitXY" src="http://images.shejidaren.com/wp-content/uploads/2014/10/023746fki.jpg" />
            <list id="menu">
                <horizontal bg="?selectableItemBackground" w="*">
                    <img w="50" h="50" padding="16" src="{{this.icon}}" tint="{{color}}" />
                    <text textColor="black" textSize="15sp" text="{{this.title}}" layout_gravity="center" />
                </horizontal>
            </list>
        </vertical>
    </drawer>
);

//创建选项菜单(右上角)
ui.emitter.on("create_options_menu", menu => {
    menu.add("日志");
    menu.add("关于");
});

//监听选项菜单点击
ui.emitter.on("options_item_selected", (e, item) => {
    switch (item.getTitle()) {
        case "日志":
            app.startActivity("console");//跳转到控制台
            break;
        case "关于":
            alert("关于", "定制脚本找九黎q1906507927");//弹框
            break;
    }
    e.consumed = true;
});
//展示右上角...
activity.setSupportActionBar(ui.toolbar);
ui.menu.on("item_click", item => {
    switch (item.title) {
        case "退出":
            ui.finish();
            break;
    }
})

//两次才能返回
threads.start(function () {
    var isCanFinish = false;
    var isCanFinishTimeout;
    ui.emitter.on("back_pressed", e => {
        if (!isCanFinish) {
            isCanFinish = true;
            isCanFinishTimeout = setTimeout(() => {
                toastLog("再返回一次就失去我了哟![表情][表情]");
                isCanFinish = false;
            }, 500);
            e.consumed = true;
        } else {
            clearTimeout(isCanFinishTimeout);
            e.consumed = false;
        };
    });
    setInterval(() => { }, 1000)
});


//点击运行按钮触发
ui.start.on("click", function() {
    if(ui.yc.text()) {
        toastLog('关注滑动延迟'+ui.sjS.text()+'秒至'+ui.sjE.text()+'秒')//获取id为sjS的值
        toastLog('关注每单延时'+ui.mdyc.text())//获取id为mdyc的值
        toastLog('关注总次数'+ui.yc.text())//获取id为yc的值
        toastLog('关注总次数-通过attr获取'+ui.yc.attr("text"))
        
    }else {
        toastLog('点击运行按钮无效')
    }
})

//获取文本的值(id与yc的text)
let text = $ui.yc.attr("text");
toastLog(text)
View Code

 

2.判断并开启悬浮窗和无障碍服务

"ui";

//启动后就会展示ui.layout
ui.layout(
    <vertical>
        <appbar>
            <toolbar title="悬浮窗权限无障碍服务"/>
        </appbar>
        <horizontal>
            <Switch id="无障碍服务" text="无障碍服务" checked="{{auto.service != null}}" padding="8 8 8 8" textSize="15sp"/>
            <Switch id="悬浮窗权限" text="悬浮窗权限" checked="{{floaty.checkPermission() != false}}" padding="8 8 8 8" textSize="15sp"/>
        </horizontal>
        <button id="start" text="开始运行"/>
    </vertical>
);


//点击开始运行触发函数
function main(){
  toast("启动成功")//没什么作用
}


// //点击开始运行触发函数
// function main(){
//     var id = setInterval(function(){
//         if (text("继续安装").exists()){
//             click('继续安装'); 
//         }
//     }, 5000);
//   toast("点击成功")
// }



ui.无障碍服务.on("check", function(checked) {
    // 用户勾选无障碍服务的选项时,跳转到页面让用户去开启
    if (checked && auto.service == null) {
        app.startActivity({
            action: "android.settings.ACCESSIBILITY_SETTINGS"
        });
    }
    if (!checked && auto.service != null) {
        auto.service.disableSelf();
    }
});


ui.悬浮窗权限.on("check", function(checked) {
    //申请悬浮窗
    importClass(android.content.Intent);
    importClass(android.net.Uri);
    importClass(android.provider.Settings);
    var intent = new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION,
        Uri.parse("package:" + context.getPackageName()));
    intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
    app.startActivity(intent);
});


// 当用户回到本界面时,resume事件会被触发
ui.emitter.on("resume", function() {
    // 此时根据无障碍服务的开启情况,同步开关的状态
    ui.无障碍服务.checked = auto.service != null;
    ui.悬浮窗权限.checked = floaty.checkPermission() != false
});


//绑定id=start的点击事件
ui.start.on("click", function() {
    //判断是否有悬浮窗权限
    if (floaty.checkPermission() == false) {
        toast("请先开启悬浮窗权限!")
        return;
    }
    //程序开始运行之前判断无障碍服务
    if (auto.service == null) {
        toast("请先开启无障碍服务!");
        return;
    }
    main();//调用
});
View Code

 

3.进度条操作

"ui";
ui.layout(
    <vertical padding="16">
        <text text="处理中..." textColor="black" textSize="16sp"/>
        <progressbar />

        <text text="直线无限进度条" textColor="black" textSize="16sp" marginTop="24"/>
        <progressbar indeterminate="true" style="@style/Base.Widget.AppCompat.ProgressBar.Horizontal"/>

        <text text="直线进度条" textColor="black" textSize="16sp" marginTop="24"/>
        <progressbar progress="30" style="@style/Base.Widget.AppCompat.ProgressBar.Horizontal"/>

        <text text="可调节进度条" textColor="black" textSize="16sp" marginTop="24"/>
        <seekbar progress="20"/>



        <horizontal gravity="center" marginTop="24" >
            <text id="progress_value" textColor="black" textSize="16sp" margin="8" text="当前值:0"/>
            <progressbar id="progress" w="*" style="@style/Base.Widget.AppCompat.ProgressBar.Horizontal"/>
        </horizontal>
        <button id="download">开始下载</button>
    </vertical>
);

var downloadId = null;

//绑定id=download的点击事件(点击下载会触发)
ui.download.click(() => {
    if (downloadId != null) {
        stopDownload();//停止下载
    } else {
        startDownload();//开始下载
    }
});


function stopDownload() {
    ui.download.text("开始下载");
    clearInterval(downloadId);
    downloadId = null;
}


//开始下载函数
function startDownload() {
    if (ui.progress.getProgress() == 100) {
        ui.progress.setProgress(0);
    }
    ui.download.text("停止下载");
    downloadId = setInterval(() => {
        var p = ui.progress.getProgress();
        p++;
        if (p > 100) {
            stopDownload();
            return;
        }
        ui.progress.setProgress(p);
        //进度条描述赋值
        ui.progress_value.setText('当前值:'+p.toString());
    }, 200);
}




//_________________________________手动滑动进度条并取值_________________________________________

"ui";
ui.layout(
  <vertical gravity="center">
    <img id="logo" src="file://./xiaomilogo.jpg" w="200dp" h="200dp"></img>
    <horizontal w="*" h="wrap_content" gravity="center" margin="5">
    <text id="price" textSize="20sp" textStyle="bold" gravity="center"></text>
    </horizontal>
    <seekbar id="seekbar" w="*" h="10dp" max="100" margin="10 10 10 10" />
    {/* <text textSize="20sp" textStyle="bold" gravity="center">
      底部描述信息
    </text> */}
  </vertical>
);

var seekbarListener = new android.widget.SeekBar.OnSeekBarChangeListener({
  onProgressChanged: function (seekbar, progress, fromUser) {
    log('滑动的值:'+progress);
    ui.price.setText('当前值:'+Math.floor(progress));//更新数据id=price
    ui.logo.cornerRadius = progress;
  },
});
ui.post(function () {
//   ui.price.setText("chenwei");
  ui.seekbar.progress = 70;//默认设置70
});

//绑定id为seekbar事件(也就是进度条)
ui.seekbar.setOnSeekBarChangeListener(seekbarListener);
View Code

 

4.各种小组件

//_________________________________控制并获取开关状态_________________________________
"ui";
ui.layout(
    <vertical>
        <Switch id="autoService" text="无障碍服务" checked="false" textSize="15sp"/>
    </vertical>
);

ui.autoService.on("check", function(checked) {
    if(checked) {
        toastLog("开关状态:"+ui.autoService.checked)
        toastLog("开")
    }else{
        toastLog("关")
    }
});



//_____________________________获取下拉列表的值_____________________________________________
"ui";
ui.layout(
    <vertical padding="16">
        <horizontal>
            <text textSize="16sp">下拉菜单</text>
            <spinner id="sp1" entries="选项1|选项2|选项3"/>
        </horizontal>

        <horizontal>
            <text textSize="16sp">对话框菜单</text>
            <spinner id="sp2" entries="选项4|选项5|选项6" spinnerMode="dialog"/>
        </horizontal>

        {/* 按钮确定 */}
        <button id="ok">确定</button>
        <button id="select3">选择第3选项</button>
    </vertical>
);

//绑定id=ok的点击事件
ui.ok.on("click", () => {

    //获取当前选项
    var i = ui.sp1.getSelectedItemPosition();//选中的sp1
    var j = ui.sp2.getSelectedItemPosition();//选择的sp2
    //默认下标是从0开始,所以这里需要i+1, j需要j+4
    toast("您的选择是选项" + (i + 1) + "和选项" + (j + 4));//这里目前只能拿到下标,可以通过下标判断(直接拿值以后研究)
});


//绑定id=select3的点击事件
ui.select3.on("click", () => {
    ui.sp1.setSelection(2);//重选sp1,选择2个
});



//____________________________________单选和多选框控件__________________________________________
"ui";
ui.layout(
    <vertical padding="16">
        <checkbox id="cb1" text="复选框"/>
        <checkbox id="cb2" checked="true" text="默认勾选"/>
        <radiogroup>
            <radio text="单选框1"/>
            <radio text="单选框2"/>
            <radio text="单选框3"/>
        </radiogroup>
        <radiogroup mariginTop="16">
            <radio id="dan1" text="单选框1"/>
            <radio id="dan2" text="单选框2"/>
            <radio text="默认勾选单选框3" checked="true"/>
        </radiogroup>

        <button id="ok">确定按钮</button>
    </vertical>
);


//绑定id=cb1的勾选事件(只有勾选就会触发)
ui.cb1.on("check", (checked) => {
    //判断checked是否选择(checked属性:表示该项是不是被选择了)
    if (checked) {
        toastLog('获取checked的值:'+checked);
        toast("第一个框被勾选了");
        toast("获取列表2-的第2个值:"+ui.dan2.text)
    } else {
        toastLog('获取checked的值:'+checked);
        toast("第一个框被取消勾选了");
    }
});

//绑定id=ok的点击事件
ui.ok.on("click", () => {
    toast("获取列表2-的第1个值:"+ui.dan1.checked)
    toast("获取列表2-的第2个值:"+ui.dan2.checked)
});



//________________________________按钮布局_________________________________________
"ui";
ui.layout(
    <vertical padding="16">
        {/* horizontal表示把多个button放在一起, w="*" 表示宽度填满, w="auto"表示宽度自动 style表样式*/}
        <horizontal>
            <button text="退出" id="activate" w="auto" style="Widget.AppCompat.Button.Colored" />
            <button w="*" id="start" style="Widget.AppCompat.Button.Colored" text="运行"/>
        </horizontal>
        <button text="普通按钮" w="auto"/>
        <button gravity="lfet" w="300" h="auto" text="靠右的文字"/>
        <button text="带颜色按钮" style="Widget.AppCompat.Button.Colored" w="auto"/>
        <button text="无边框按钮" style="Widget.AppCompat.Button.Borderless" w="auto"/>
        <button text="无边框有颜色按钮" style="Widget.AppCompat.Button.Borderless.Colored" w="auto"/>
        <button text="长长的按钮" w="*"/>
        <button id="click_me" text="点我" w="auto"/>
        <horizontal>
            <button text="退出" id="activate" w="350px" />
            <button w="350px" id="start" text="开始"/>
            <button w="350px" id="qiut" text="清除"/>
        </horizontal>

    </vertical>
);

//绑定id=click_me的点击事件
ui.click_me.on("click", () => {
    toast("我被点啦");
});

//绑定id=click_me的长按时间
ui.click_me.on("long_click", () => {
    toast("我被长按啦");
});



//___________________________________图片控件________________________________________
"ui";
ui.layout(
    <scroll>
     {/* bg背景颜色, padding表示x位置,textColor标题颜色, textSiz标题字体大小, */}
    <vertical bg="#53b0ab" padding="16">
        <text text="网络图片" textColor="BLUE" textSize="16sp" marginTop="16"/>
        <img src="http://file.superdalan.com//e6514482865d5db453f0d9e42d449e25~500"
            w="100" h="100"/>

        <text text="带边框的图片" textColor="black" textSize="16sp" marginTop="16"/>
        <img src="https://testerhome.com/uploads/opensource_project/2017/36378478-8aef-4cf4-b598-ff24372a7e28.png"
                w="100" h="100" borderWidth="2dp" borderColor="#202020"/>

        <text text="圆形图片" textColor="black" textSize="16sp" marginTop="16"/>
        <img src="https://testerhome.com/uploads/opensource_project/2017/36378478-8aef-4cf4-b598-ff24372a7e28.png"
                w="100" h="100" circle="true"/>

        <text text="带边框的圆形图片" textColor="black" textSize="16sp" marginTop="16"/>
        <img src="https://testerhome.com/uploads/opensource_project/2017/36378478-8aef-4cf4-b598-ff24372a7e28.png"
                w="100" h="100" circle="true" borderWidth="2dp" borderColor="#202020"/>

        <text text="圆角图片" textColor="black" textSize="16sp" marginTop="16"/>
        <img id="rounded_img" src="https://testerhome.com/uploads/opensource_project/2017/36378478-8aef-4cf4-b598-ff24372a7e28.png"
                w="100" h="100" radius="20dp" scaleType="fitXY"/>

        <button id="change_img" text="更改图片"/>
    </vertical>
</scroll>
);

//绑定id=change_img的点击事件
ui.change_img.on("click", () => {
    ui.rounded_img.setSource("http://file.superdalan.com//e6514482865d5db453f0d9e42d449e25~500");//更改id=rounded_img的图片
});
View Code

 

 

5.页面布局及获取值

"ui";
const storage = storages.create("Coolxx");//本地存储文件建立
// storage.put("键名","键值")  //向存储中存入数据
const isShow = storage.get("show",false)//通过键名获取数据
const loopNum = storage.get("loopNum",100)//通过键名获取数据
const sleepTime = storage.get("sleepTime",10)
const isVip = storage.get("isVip",false)
const playName = storage.get("playName","")
const playlists = storage.get("playlists","这是一个测试")
const isAnti = storage.get("anti",true)
const model = storage.get("model",0)

ui.statusBarColor("#1495E7")
ui.layout(
    <frame>
            <vertical>
                <appbar>
                    <toolbar id="toolbar" bg="#1495E7"  title="xx助手"></toolbar>
                </appbar>
                <ScrollView>
                <vertical>
                    <card w="*" h="70" margin="10 5" cardCornerRadius="2dp" cardElevation="1dp" foreground="?selectableItemBackground">
                        <horizontal gravity="center_vertical">
                            <View bg="#1495E7" h="*" w="5"/>
                            <vertical padding="10 8" h="auto" w="0" layout_weight="1">
                                <horizontal>
                                    <Switch id="autoService" text="无障碍服务" checked="{{auto.service != null}}" padding="8 8 8 8" textSize="14"/>
                                    <Switch id="isShow" text="悬浮窗权限" checked="{{floaty.checkPermission() != false}}" padding="8 8 8 8" textSize="14"/>
                                </horizontal>
                            </vertical>
                        </horizontal>
                    </card>
                    <card w="*" h="270" margin="10 5" cardCornerRadius="2dp" cardElevation="1dp" foreground="?selectableItemBackground">
                        <horizontal gravity="center_vertical">
                            <View bg="#1495E7" h="*" w="5"/>
                            <vertical padding="10 8" h="auto" w="0" layout_weight="1">
                                <horizontal id="play"><text text="歌单名称"/><input w="*" hint="指定歌单模式该值必填" id="playlists"  text="{{playlists}}" /></horizontal>
                                <horizontal id="play"><text text="歌曲名称"/><input w="*" hint="搜索运行模式该值必填" id="playName"  text="{{playName}}" /></horizontal>
                                <horizontal><text text="循环次数"/><input w="*" id="loopNum" inputType="number" text="{{loopNum}}" /></horizontal>
                                <horizontal><text text="切歌间隔"/><input w="*" id="sleepTime"  inputType="number" text="{{sleepTime}}" /></horizontal>
                                <horizontal>

                                    <text text="是否下载"/><Switch id="isVip" padding="8 8 8 8" textSize="12" checked="{{isVip}}"></Switch>
                                    <text text="防止封号"/><Switch id="isAnti" checked="{{isAnti}}" padding = "8 8 8 8" textSize="12"></Switch>
                                </horizontal>
                                <horizontal><text text="运行模式"/><spinner id="model" entries="播放界面运行|搜索运行|播放喜欢的音乐|指定歌单" ></spinner></horizontal>
                            </vertical>
                        </horizontal>
                    </card>
                    <card w="*" h="200" margin="10 5" cardCornerRadius="2dp" cardElevation="1dp" foreground="?selectableItemBackground">
                        <horizontal gravity="center_vertical">
                            <View bg="#1495E7" h="*" w="5"/>
                            <vertical padding="10 8" h="auto" w="0" layout_weight="1">
                                <horizontal padding="0 5"><text id="title" text="[是否下载] 是否下载刷量歌曲,开启后会影响切歌间隔" textSize="13sp" /></horizontal>
                                <horizontal padding="0 5"><text id="title" text="[切歌间隔] 播放单条音乐多久切换下一首,单位秒" textSize="13sp" /></horizontal>
                                <horizontal padding="0 5"><text id="title" text="[运行模式] 播放界面运行:循环播放当前播放歌曲,需进入xx播放界面" textSize="13sp" /></horizontal>
                                <horizontal padding="0 5"><text id="title" text="[运行模式] 搜索运行:循环播放搜索歌曲,由参数[歌曲名称]决定" textSize="13sp" /></horizontal>
                                <horizontal padding="0 5"><text id="title" text="[运行模式] 播放喜欢的音乐:循环播放xx歌单[我喜欢的音乐]" textSize="13sp" /></horizontal>  
                                <horizontal padding="0 5"><text id="title" text="[运行模式] 指定歌单:循环播放xx歌单,由参数[歌单名称]决定" textSize="13sp" /></horizontal>  
                                <horizontal padding="0 5"><text id="title" text="[运行方式]{{playlists}}" textSize="13sp" /></horizontal>  
                                
                            </vertical>
                        </horizontal>
                    </card>
                    <vertical padding="5">
                        <horizontal>
                            <button text="退出" id="activate" w="auto" style="Widget.AppCompat.Button.Colored" />
                            <button w="*" id="start" style="Widget.AppCompat.Button.Colored" text="运行"/>
                        </horizontal>
                    </vertical>
                </vertical>
                </ScrollView>
            </vertical>
    </frame>
)
 ui.model.setSelection(model) 


//绑定id=start的点击事件
ui.start.on("click", function() {
    //如果id=playName有值就打印
    if(ui.playName.text()) {
        toastLog('歌单名字:'+ui.playlists.text())//获取id为playlists的text
        toastLog('歌曲名字:'+ui.playName.text())//获取id为playName的text
        toastLog('是否下载:'+ui.isVip.checked)//获取id为isVip的checked  
        var i = ui.model.getSelectedItemPosition();
        toastLog('运行模式:'+i+1)//这里通过下标判断, 1播放界面运行、2搜索运行、3播放喜欢的音乐、4指定歌单
    }          
    else {
        if(auto.service == null) {
            toast("id=playName没有值");
            
            return;
        }
    }
})


// 绑定id=activate的点击事件(函数功能:实现程序退出)
ui.activate.on("click", function() {
    engines.myEngine().forceStop();//停止自己
});


ui.autoService.on("check", function(checked) {
    // 用户勾选无障碍服务的选项时,跳转到页面让用户去开启
    if (checked && auto.service == null) {
        app.startActivity({
            action: "android.settings.ACCESSIBILITY_SETTINGS"
        });
    }
    if (!checked && auto.service != null) {
        auto.service.disableSelf();
    }
});


ui.isShow.on("check", function(checked) {
    //申请悬浮窗
    importClass(android.content.Intent);
    importClass(android.net.Uri);
    importClass(android.provider.Settings);
    var intent = new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION,
        Uri.parse("package:" + context.getPackageName()));
    intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
    app.startActivity(intent);
});


// 当用户回到本界面时,resume事件会被触发
ui.emitter.on("resume", function() {
    // 此时根据无障碍服务的开启情况,同步开关的状态
    ui.autoService.checked = auto.service != null;
    ui.isShow.checked = floaty.checkPermission() != false
});


//绑定id=start的点击事件
ui.start.on("click", function() {
    //判断是否有悬浮窗权限
    if (floaty.checkPermission() == false) {
        toast("请先开启悬浮窗权限!")
        return;
    }
    //程序开始运行之前判断无障碍服务
    if (auto.service == null) {
        toast("请先开启无障碍服务!");
        return;
    }
});
View Code

 

 6.菜单及表单

//__________________________________卡片布局_____________________________________________________
"ui";
ui.layout(
    <vertical>
        <appbar>
            <toolbar id="toolbar" title="卡片布局"/>
        </appbar>
        <card w="*" h="70" margin="10 5" cardCornerRadius="2dp"
            cardElevation="1dp" gravity="center_vertical">
            <vertical padding="18 8" h="auto">
                <text text="写操作系统作业" textColor="#222222" textSize="16sp"/>
                <text text="明天第1~2节" textColor="#999999" textSize="14sp"/>
            </vertical>
            <View bg="#f44336" h="*" w="10"/>
        </card>
        <card w="*" h="70" margin="10 5" cardCornerRadius="2dp"
            cardElevation="1dp" gravity="center_vertical">
            <vertical padding="18 8" h="auto">
                <text text="修复ui模式的Bug" textColor="#222222" textSize="16sp"/>
                <text text="无限期" textColor="#999999" textSize="14sp"/>
            </vertical>
            <View bg="#ff5722" h="*" w="10"/>
        </card>
        <card w="*" h="70" margin="10 5" cardCornerRadius="2dp"
            cardElevation="1dp" gravity="center_vertical">
            <vertical padding="18 8" h="auto">
                <text text="发布Auto.js 5.0.0正式版" textColor="#222222" textSize="16sp"/>
                <text text="2019年1月" textColor="#999999" textSize="14sp"/>
            </vertical>
            <View bg="#4caf50" h="*" w="10"/>
        </card>
        <card w="*" h="70" margin="10 5" cardCornerRadius="2dp"
            cardElevation="1dp" gravity="center_vertical">
            <vertical padding="18 8" h="auto">
                <text text="完成毕业设计和论文" textColor="#222222" textSize="16sp"/>
                <text text="2019年4月" textColor="#999999" textSize="14sp"/>
            </vertical>
            <View bg="#2196f3" h="*" w="10"/>
        </card>
    </vertical>
);




//_______________________________列菜单_____________________________________________
"ui";

var color = "#009688";
ui.layout(
    <drawer id="drawer">
        <vertical>
            <appbar>
                <toolbar id="toolbar" title="示例"/>
                <tabs id="tabs"/>
            </appbar>
            <viewpager id="viewpager">
                <frame>
                    <text text="第一页内容" textColor="black" textSize="16sp"/>
                </frame>
                <frame>
                    <text text="第二页内容" textColor="red" textSize="16sp"/>
                </frame>
                <frame>
                    <text text="第三页内容" textColor="green" textSize="16sp"/>
                </frame>
            </viewpager>
        </vertical>
        <vertical layout_gravity="left" bg="#ffffff" w="280">
            <img w="280" h="200" scaleType="fitXY" src="http://images.shejidaren.com/wp-content/uploads/2014/10/023746fki.jpg"/>
            <list id="menu">
                <horizontal bg="?selectableItemBackground" w="*">
                    <img w="50" h="50" padding="16" src="{{this.icon}}" tint="{{color}}"/>
                    <text textColor="black" textSize="15sp" text="{{this.title}}" layout_gravity="center"/>
                </horizontal>
            </list>
        </vertical>
    </drawer>
);


//创建选项菜单(右上角)
ui.emitter.on("create_options_menu", menu => {
    menu.add("设置");
    menu.add("关于");
});
//监听选项菜单点击
ui.emitter.on("options_item_selected", (e, item) => {
    switch (item.getTitle()) {
        case "设置":
            toast("还没有设置");
            break;
        case "关于":
            alert("关于", "Auto.js界面模板 v1.0.0");
            break;
    }
    e.consumed = true;
});
activity.setSupportActionBar(ui.toolbar);

//设置滑动页面的标题
ui.viewpager.setTitles(["标签一", "标签二", "标签三"]);
//让滑动页面和标签栏联动
ui.tabs.setupWithViewPager(ui.viewpager);

//让工具栏左上角可以打开侧拉菜单
ui.toolbar.setupWithDrawer(ui.drawer);

ui.menu.setDataSource([{
        title: "选项一",
        icon: "@drawable/ic_android_black_48dp"
    },
    {
        title: "选项二",
        icon: "@drawable/ic_settings_black_48dp"
    },
    {
        title: "选项三",
        icon: "@drawable/ic_favorite_black_48dp"
    },
    {
        title: "退出",
        icon: "@drawable/ic_exit_to_app_black_48dp"
    }
]);

ui.menu.on("item_click", item => {
    switch (item.title) {
        case "退出":
            ui.finish();
            break;
    }
})




//__________________________________表单综合_________________________________________________
"ui";
ui.layout(
    <vertical>
        <text textSize="18sp" textColor="#000000" margin="20" textStyle="bold">
            关于Auto.js的用户调查
        </text>
        <ScrollView>
            <vertical>
                <text textSize="16sp" margin="8">1. 您的年龄是?</text>
                <input text="18" inputType="number" margin="0 16"/>
                <text textSize="16sp" margin="8">2. 您用过其他类似软件(脚本精灵,按键精灵等)吗?</text>
                <radiogroup margin="0 16">
                    <radio text="没有用过"/>
                    <radio text="用过"/>
                    <radio text="用过,感觉不好用"/>
                    <radio text="没有Root权限无法使用"/>
                </radiogroup>
                <text textSize="16sp" margin="8">3. 您使用Auto.js通常用于做什么?(多选)</text>
                <checkbox text="游戏辅助" marginLeft="16"/>
                <checkbox text="点赞" marginLeft="16"/>
                <checkbox text="日常生活工作辅助" marginLeft="16"/>
                <checkbox text="练习编程" marginLeft="16"/>
                <checkbox text="自动化测试" marginLeft="16"/>
                <linear>
                    <checkbox text="其他" marginLeft="16"/>
                    <input w="*" margin="0 16"/>
                </linear>
                <text textSize="16sp" margin="8">4. 您更喜欢以下哪个图标?</text>
                <radiogroup margin="0 16">
                    <radio/>
                    <img w="100" h="100" margin="0 16" src="https://pro.autojs.org/images/logo.png"/>
                    <radio/>
                    <img w="50" h="50" margin="0 16" src="https://pro.autojs.org/images/logo.png"/>
                </radiogroup>
                <text textSize="16sp" margin="8">5. 您是什么时候开始使用Auto.js的呢?</text>
                <datepicker margin="4 16" datePickerMode="spinner"/>
                <text textSize="16sp" margin="8">6. 您用过下面这个Auto.js的论坛吗?</text>
                <webview id="webview" h="300" margin="0 16"/>
                <radiogroup marginLeft="16" marginTop="16">
                    <radio text="没有用过"/>
                    <radio text="用过"/>
                    <radio text="用过,感觉不好用"/>
                </radiogroup>
                <linear gravity="center">
                    <button margin="16">提交</button>
                    <button margin="16">放弃</button>
                </linear>
            </vertical>
        </ScrollView>
    </vertical>
)

ui.webview.loadUrl("http://www.autojs.org");





// ______________________________________卡片功能__________________________________________________
"ui";
ui.layout(
    <frame>
        <vertical>
            <appbar>
                <toolbar id="toolbar" title="Todo" />
            </appbar>
            <button id="selectAll" text="全选"/>
            <button id="selectexit" text="消除"/>
            <list id="todoList">
                <card w="*" h="70" margin="10 5" cardCornerRadius="2dp"
                    cardElevation="1dp" foreground="?selectableItemBackground">
                    <horizontal gravity="center_vertical">
                        <View bg="{{this.color}}" h="*" w="10" />
                        <vertical padding="10 8" h="auto" w="0" layout_weight="1">
                            <text id="title" text="{{this.title}}" textColor="#222222" textSize="16sp" maxLines="1" />
                            <text text="{{this.summary}}" textColor="#999999" textSize="14sp" maxLines="1" />
                        </vertical>
                        <checkbox id="done" marginLeft="4" marginRight="6" checked="{{this.done}}" />
                    </horizontal>

                </card>
            </list>
        </vertical>
        <fab id="add" w="auto" h="auto"  text="添加" src="@drawable/ic_add_black_48dp"
            margin="16" layout_gravity="bottom|right" tint="#ffffff" />
    </frame>
);

var materialColors = ["#e91e63", "#ab47bc", "#5c6bc0", "#7e57c2", "##2196f3", "#00bcd4",
    "#26a69a", "#4caf50", "#8bc34a", "#ffeb3b", "#ffa726", "#78909c", "#8d6e63"
];

var storage = storages.create("todoList");//本地存储文件建立

//从storage获取todo列表
var todoList = storage.get("items", [{
        title: "写操作系统作业",
        summary: "明天第1~2节",
        color: "#f44336",
        done: false
    },
    {
        title: "给ui模式增加若干Bug",
        summary: "无限期",
        color: "#ff5722",
        done: false
    },
    {
        title: "发布Auto.js 5.0.0正式版",
        summary: "2019年1月",
        color: "#4caf50",
        done: false
    },
    {
        title: "完成毕业设计和论文",
        summary: "2019年4月",
        color: "#2196f3",
        done: false
    }
]);;

ui.todoList.setDataSource(todoList);//设置需要加载的todoList


//绑定全选按钮
ui.selectAll.on("click", function() {
    todoList.forEach(item => {
        item.done = true;
    });
    // 通知数据全部更新
    ui.todoList.adapter.notifyDataSetChanged();
});


// 绑定消除按钮
ui.selectexit.on("click", function() {
    todoList.forEach(item => {
        item.done = false;
    });
    // 通知数据全部更新
    ui.todoList.adapter.notifyDataSetChanged();
});


ui.todoList.on("item_bind", function(itemView, itemHolder) {
    //绑定勾选框事件
    itemView.done.on("check", function(checked) {
        let item = itemHolder.item;
        item.done = checked;
        let paint = itemView.title.paint;
        //设置或取消中划线效果
        if (checked) {
            paint.flags |= Paint.STRIKE_THRU_TEXT_FLAG;
        } else {
            paint.flags &= ~Paint.STRIKE_THRU_TEXT_FLAG;
        }
        itemView.title.invalidate();
    });
});

ui.todoList.on("item_click", function(item, i, itemView, listView) {
    itemView.done.checked = !itemView.done.checked;
});

//长按删除
ui.todoList.on("item_long_click", function(e, item, i, itemView, listView) {
    confirm("确定要删除" + item.title + "吗?")
        .then(ok => {
            if (ok) {
                todoList.splice(i, 1);
            }
        });
    e.consumed = true;
});

//当离开本界面时保存todoList
ui.emitter.on("pause", () => {
    storage.put("items", todoList);
});

// 绑定点击按钮的事件点击
ui.add.on("click", () => {
    dialogs.rawInput("请输入标题")
        .then(title => {
            if (!title) {
                return;
            }
            dialogs.rawInput("请输入期限", "明天")
                .then(summary => {
                    todoList.push({
                        title: title,
                        summary: summary,
                        color: materialColors[random(0, materialColors.length - 1)]
                    });
                });
        })
});





//______________________________________登录与注册页面______________________________________
"ui";
showLoginUI();
ui.statusBarColor("#B22222")//顶部颜色

//显示登录界面
function showLoginUI() {
    ui.layout(
        <frame>
            
        <vertical h="auto" align="center" margin="0 50">

          <linear>
             <text w="56" gravity="center" color="#111111" size="16">用户名</text>
             <input id="name" w="*" h="40"/>
          </linear>
          <linear>
             <text w="56" gravity="center" color="#111111" size="16">密码</text>
             <input id="password" w="*" h="40" password="true"/>
          </linear>
          <linear gravity="center">
             <button id="login" text="登录"/>
             <button id="register" text="注册"/>
          </linear>
        </vertical>
      </frame>
    )
//绑定id为login的点击事件(登录)
ui.login.on("click", () => {
    toastLog("您输入的用户名为" + ui.name.text() + " 密码为" + ui.password.text());
});

//绑定id为register的点击事件(从登录跳注册)
ui.register.on("click", () => showRegisterUI());//触发调用showRegisterUI函数

};
    


//显示注册界面
function showRegisterUI() {
    ui.layout(
        <frame>
        <vertical h="auto" align="center" margin="0 50">
          <linear>
             <text w="56" gravity="center" color="#111111" size="16">用户名</text>
             <input id="register_name"  w="*" h="40"/>
          </linear>
          <linear>
             <text w="56" gravity="center" color="#111111" size="16">密码</text>
             <input id="register_password" w="*" h="40" password="true"/>
          </linear>
          <linear>
             <text w="56" gravity="center" color="#111111" size="16">邮箱</text>
             <input id="register_emali" w="*" h="40" inputType="textEmailAddress"/>
          </linear>
          <linear gravity="center">
             <button id="chen_login">确定</button>
             <button id="cancel">取消</button>
          </linear>
        </vertical>
      </frame>
    );
    //触发调用showLoginUI函数(从注册条登录)
    ui.cancel.on("click", () => showLoginUI());

    //绑定id为login的点击事件(注册)
    ui.chen_login.on("click", () => {
        toastLog("注册的用户名为" + ui.register_name.text() + " 注册密码为" + ui.register_password.text() + " 注册邮箱为" + ui.register_emali.text());
    });
}
View Code

 

 

 7.各种对话框

 

 

8.控制台或日志

 

 9.悬浮窗

ui模式下,必须在线程里创建悬浮窗,否则就卡死了

////____________________________________________顶部悬浮窗_______________________________________________________________
////悬浮框布局样式
var window = floaty.window(
    <frame gravity="center">
        <text id="text" textSize="10sp" textColor="#153AD8"/>
    </frame>
);

window.exitOnClose();

////启动窗口
window.text.click(() => {
    window.setAdjustEnabled(!window.isAdjustEnabled());
});

setInterval(() => {
    ////对控件的操作需要在UI线程中执行
    ui.run(function() {
        window.text.setText(dynamicText());
    });
}, 1000);


////需要显示的内容
function dynamicText() {
    var date = new Date();
    var str = util.format("时间: %d:%d:%d\n", date.getHours(), date.getMinutes(), date.getSeconds());

    ////getMemoryUsage获取内存使用率
    str += util.format("内存使用量: %d%%\n", getMemoryUsage());
    str += "当前活动: " + currentActivity() + "\n";
    str += "当前包名: " + currentPackage();
    return str;
}


////获取内存使用率
function getMemoryUsage() {
    var usage = (100 * device.getAvailMem() / device.getTotalMem());
    ////保留一位小数
    return Math.round(usage * 10) / 10;
}






////__________________________________简单悬浮窗_______________________________________________

////悬浮框布局样式
var window = floaty.window(
    <frame gravity="center">
        <text id="text" textSize="15sp" textColor="#153AD8">  的点点滴滴多</text>
    </frame>
);


//// 设置悬浮窗的位置
window.setPosition(500, 500);

setTimeout(()=>{
    ////2秒后关闭窗口
    obj.close();
}, 8000);





////________________________________文件打印悬浮________________________________________________
////悬浮框布局样式
var window = floaty.window(
    <frame gravity="center"  bg="#53b0ab" w="500px" h="100px">
        <text id="text" textSize="15sp" textColor="#153AD8">  的点点滴滴多</text>
    </frame>
);

//// 5秒后关闭窗口
setTimeout(()=>{
    window.close();
}, 7000);

////运行
ui.run(function(){
    //// obj对应窗口返回的对象
    //// text对应节点的ID 
    window.text.setText("DEBUG:当前值为50");

    window.text.setText("DEBUG:计算后值为2500");
    setTimeout(function(){
        window.text.setText("ERROR:当前计算的数字不对,程序即将退出!");
    }, 2000); 

});




////_____________________________________UI下的悬浮窗_____________________________________________
"ui";
ui.layout(
    <vertical>
        <Switch id="autoService" text="无障碍服务" checked="false" textSize="15sp"/>
    </vertical>
);

ui.autoService.on("check", function(checked) {
    if(checked) {
        toastLog("开关状态:"+ui.autoService.checked)
        toastLog("开")
    }else{
        toastLog("关")
    }
});


////悬浮窗
function createFloaty() {
        ////悬浮框布局样式
    window = floaty.window(
        <frame gravity="center"  bg="#53b0ab" w="500px" h="100px">
            <text id="text" textSize="15sp" textColor="#153AD8">  的点点滴滴多</text>
        </frame>
)};

/////运行悬浮窗
threads.start(function () {
    createFloaty();
    window.text.setText("DEBUG:当前值为50");
    window.text.setText("DEBUG:计算后值为2500");
    sleep(4000);
    ui.run(() => {
        window.text.setText("ERROR:当前计算的数字不对,程序即将退出!");
    });   
});






////_____________________________________日志打印到悬浮窗______________________________________
////自定义悬浮窗-控制台
window = floaty.rawWindow(
    <vertical>
        <text id="控制台"text="控制台"h="100"w="200"bg="#ffffff"gravity="bottom"/>
    </vertical>
)

window.setPosition(0, 0);////定义控制台位置


////调用log并打印日志
function Log(a) {
    let sz = window.控制台.text().split("\n")
    ////日志大于6条就刷新悬浮窗屏幕
    if (sz.length > 6) {
        sz.shift();
    }
    sz.push(时间()+a)
    window.控制台.setText(sz.join("\n"))
}

////获取当前时间
function 时间() {
    var mydate = new Date();
    var 小时 = mydate.getHours().toString();
    var 分钟 = mydate.getMinutes().toString();
    var 秒数 = mydate.getSeconds().toString();
    if(小时.length==1){
        小时="0"+小时
    }
    if(分钟.length==1){
        分钟="0"+分钟
    }
    if(秒数.length==1){
        秒数="0"+秒数
    }
    return "["+小时+":"+分钟+":"+秒数+"] "
}




// //控制需要打印的内容,,setInterval周期定时循环执行
// i=10
// setInterval(() => {
//     Log(i)//每次i加一
//     i++
// }, 1000);


// //控制需要打印的内容,,setInterval周期定时循环执行
var timesRun = 0;
//2秒执行一次,当timesRun等于60就结束循环
var interval = setInterval(function(){
    Log(timesRun)//每次i加一
    timesRun += 1;
    if(timesRun === 20){
        clearInterval(interval);
        engines.myEngine().forceStop();//停止脚本  
    }
    
}, 1000);





////_____________________________________UI模式下悬浮窗日志______________________________________
"ui";

//启动后就会展示ui.layout
ui.layout(
    <vertical>
        <appbar>
            <toolbar title="悬浮窗权限无障碍服务"/>
        </appbar>
        <horizontal>
            <Switch id="无障碍服务" text="无障碍服务" checked="{{auto.service != null}}" padding="8 8 8 8" textSize="15sp"/>
            <Switch id="悬浮窗权限" text="悬浮窗权限" checked="{{floaty.checkPermission() != false}}" padding="8 8 8 8" textSize="15sp"/>
        </horizontal>
        <button id="start" text="开始运行"/>
    </vertical>
);

//自定义悬浮窗-控制台
window = floaty.rawWindow(
    <vertical>
        <text id="控制台"text="控制台"h="100"w="200"bg="#ffffff"gravity="bottom"/>
    </vertical>
)

window.setPosition(0, 0);//定义控制台位置


//点击开始运行触发函数
function main(){
    toast("启动成功")//没什么作用
    //调用log并打印日志
    let sz = window.控制台.text().split("\n")

    var timesRun = 1;
    var interval = setInterval(() => {
         //日志大于5条就刷新悬浮窗屏幕
         if (sz.length > 5) {
            sz.shift();
        }
        sz.push('qqqqqq'+timesRun)
        console.log(timesRun);
        window.控制台.setText(sz.join("\n"))//这里可以调用当前时间函数
        timesRun++;
        //timesRun就退出
        if(timesRun >= 20){    
            clearInterval(interval);//退出循环 
            engines.myEngine().forceStop();//停止脚本    
        }
    }, 2000);
 
}


ui.无障碍服务.on("check", function(checked) {
    // 用户勾选无障碍服务的选项时,跳转到页面让用户去开启
    if (checked && auto.service == null) {
        app.startActivity({
            action: "android.settings.ACCESSIBILITY_SETTINGS"
        });
    }
    if (!checked && auto.service != null) {
        auto.service.disableSelf();
    }
});


ui.悬浮窗权限.on("check", function(checked) {
    //申请悬浮窗
    importClass(android.content.Intent);
    importClass(android.net.Uri);
    importClass(android.provider.Settings);
    var intent = new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION,
        Uri.parse("package:" + context.getPackageName()));
    intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
    app.startActivity(intent);
});


// 当用户回到本界面时,resume事件会被触发
ui.emitter.on("resume", function() {
    // 此时根据无障碍服务的开启情况,同步开关的状态
    ui.无障碍服务.checked = auto.service != null;
    ui.悬浮窗权限.checked = floaty.checkPermission() != false
});


//绑定id=start的点击事件
ui.start.on("click", function() {
    //判断是否有悬浮窗权限
    if (floaty.checkPermission() == false) {
        toast("请先开启悬浮窗权限!")
        return;
    }
    //程序开始运行之前判断无障碍服务
    if (auto.service == null) {
        toast("请先开启无障碍服务!");
        return;
    }
    main();//调用
});
View Code

 

 

 

 

 

实际案例:

1.项目demo1

"ui";
importClass(android.view.View);
var scriptName = 'xx全自动接单'
var version = '1.8.9'
var themeColor = '#4EBFDD'
var scriptTitle = scriptName+' v'+version
var APPVersion = 'xx陪玩 3.2.6'
password = '9999'


var ScriptUIAllStr = ScriptUI.toString()
var ScriptUIStr = ScriptUIAllStr.slice(ScriptUIAllStr.indexOf('{'),ScriptUIAllStr.lastIndexOf('}')).slice(1,-2).replace(/项目标题/g,scriptTitle).replace(/#4EBFDD/g,themeColor)
configIDArr = ScriptUIStr.match(/ id( )?=( )?["|'].*?["|']/g).map(item => item.replace(/ id( )?=( )?["|']|"|'/g,''))
ui.statusBarColor(themeColor);
ui.layout(ScriptUIStr);

function ScriptUI(){
    <vertical>
        <appbar>
            <toolbar bg="#4EBFDD" layout_height="70" margin="-2" id="toolbar" title="项目标题" />
        </appbar>
        <ScrollView>
            <vertical marginTop="5">
                <card w="*" h="auto" margin="10 5" cardCornerRadius="2dp" cardElevation="1dp" gravity="center_vertical">
                    <vertical padding="18 8" h="auto">
                        <linear>
                            <Switch margin="12 0" layout_weight="1"  id="autoService"   text="无障碍服务"   textSize="15sp" checked="{{auto.service != null}}" />
                            <Switch margin="12 0" layout_weight="1"  id="floatyService" text="悬浮窗权限"   textSize="15sp" checked="false" />
                        </linear>
                    </vertical>
                    <View bg="#4EBFDD" h="*" w="5" />
                </card>
                <text id="info" text="QQ号:1906507927" layout_gravity="center"  textColor="red" w="auto" textStyle="bold" />
                <card w="*" h="auto" margin="10 5" cardCornerRadius="2dp" cardElevation="1dp" gravity="center_vertical">
                    <vertical padding="18 8" h="auto">
                        <linear>
                            <text text="注册码:"   textColor="black" w="auto" textStyle="bold" />
                            <input id = "输入框_注册码"  color="#666666" paddingLeft="5" w="*"/>
                        </linear>
                    </vertical>
                    <View bg="#4EBFDD" h="*" w="5" />
                </card>
                <card w="*" h="auto" margin="10 5" cardCornerRadius="2dp" cardElevation="1dp" gravity="center_vertical">
                    <vertical padding="18 8" h="auto">
                        <text text="功能选择:"  marginLeft="5" w="auto" textStyle="bold" textColor='black'/>
                        <radiogroup orientation="horizontal" >
                            <checkbox id="选择框_是否发现boss" text="发现boss"  textColor="black" />
                            <checkbox id="选择框_是否浏览陪玩" text="浏览陪玩"  textColor="black" />
                        </radiogroup>
                        <linear>
                            <checkbox id="选择框_是否私信访客" text="监听新访客"  textColor="black" checked='true'/>
                            <checkbox id="选择框_是否监听抢单" text="监听抢单"  textColor="black" checked='true'/>
                        </linear>

                        <text text="全局设置:"  marginLeft="5" w="auto" textStyle="bold" textColor='black'/>
                        <checkbox id="选择框_是否添加符号" text="话术添加随机符号"  textColor="black" checked='true'/>
                    </vertical>
                    <View bg="#4EBFDD" h="*" w="5" />
                </card>
                <card w="*" h="auto" margin="10 5" cardCornerRadius="2dp" cardElevation="1dp" gravity="center_vertical">
                    <button id="startScript" h="auto" text="开 始 运 行" textSize="17"  textStyle="bold" color="#ffffff" bg="#4EBFDD" foreground="?selectableItemBackground" layout_gravity="bottom" />
                    <View bg="#4EBFDD" h="*" w="5" />
                </card>
                <card w="*" h="auto" margin="10 5" cardCornerRadius="2dp" cardElevation="1dp" gravity="center_vertical">
                    <vertical padding="18 8" marginBottom="2" h="auto">
                        <text text="[发现boss设置]" color="#FFA500"  textStyle="bold" textSize="15sp"/>
                        <horizontal>
                            <text text="私信次数:"  textStyle="bold" textSize="15sp"/>
                            <input id="输入框_私信次数" text="0" color="#666666" w="*"/>
                        </horizontal>
                        <horizontal>
                            <text text="私信boss间隔(秒):"  textStyle="bold" textSize="15sp"/>
                            <input id="输入框_私信boss间隔" text="2" color="#666666" w="*"/>
                        </horizontal>
                        <horizontal>
                            <text text="进入发现boss页面等待时间(秒):"  textStyle="bold" textSize="15sp"/>
                            <input id="输入框_进入发现boss页面等待时间" text="1" color="#666666" w="*"/>
                        </horizontal>
                        <horizontal>
                            <text text="话术:"  textStyle="bold" textSize="15sp"/>
                            <input id="输入框_boss话术" text="你好#hello#在嘛" color="#666666" w="*"/>
                        </horizontal>
                        <text text="多条用#分割,随机选择一条发送" color="#D2B48C"  textStyle="bold" textSize="12sp"/>
                    </vertical>
                    <View bg="#4EBFDD" h="*" w="5" />
                </card>
                <card w="*" h="auto" margin="10 5" cardCornerRadius="2dp" cardElevation="1dp" gravity="center_vertical">
                    <vertical padding="18 8" marginBottom="2" h="auto">
                        <text text="[私信访客设置]" color="#FFA500"  textStyle="bold" textSize="15sp"/>
                        <horizontal>
                            <text text="话术:"  textStyle="bold" textSize="15sp"/>
                            <input id="输入框_visitor话术" text="你好#hello#在嘛" color="#666666" w="*"/>
                        </horizontal>
                        <text text="多条用#分割,随机选择一条发送" color="#D2B48C"  textStyle="bold" textSize="12sp"/>
                    </vertical>
                    <View bg="#4EBFDD" h="*" w="5" />
                </card>
                <card w="*" h="auto" margin="10 5" cardCornerRadius="2dp" cardElevation="1dp" gravity="center_vertical">
                    <vertical padding="18 8" marginBottom="2" h="auto">
                        <text text="[抢单设置]" color="#FFA500"  textStyle="bold" textSize="15sp"/>
                        <horizontal>
                            <text text="每次抢单概率(%):"  textStyle="bold" textSize="15sp"/>
                            <input id="输入框_每次抢单概率" text="30" color="#666666" w="*"/>
                        </horizontal>
                        <text text="(此功能概率根据个人要求设置,封号与本脚本无关)" color="#D2B48C"  textStyle="bold" textSize="12sp"/>
                        <horizontal>
                            <text text="抢单总次数:"  textStyle="bold" textSize="15sp"/>
                            <input id="输入框_抢单总次数" text="0" color="#666666" w="*"/>
                        </horizontal>
                        <horizontal>
                            <text text="抢单延时(毫秒):"  textStyle="bold" textSize="15sp"/>
                            <input id="输入框_抢单延时小" text="600" color="#666666" w="80"/>
                            <text text=" - "  textStyle="bold" textSize="15sp"/>
                            <input id="输入框_抢单延时大" text="2000" color="#666666" w="80"/>
                        </horizontal>
                    </vertical>
                    <View bg="#4EBFDD" h="*" w="5" />
                </card>
                <card id="showHide_func4" w="*" h="auto" margin="10 5" cardCornerRadius="2dp" cardElevation="1dp" gravity="center_vertical">
                    <vertical padding="18 8" marginBottom="2" h="auto">
                        <text text="[浏览设置]" color="#FFA500"  textStyle="bold" textSize="15sp"/>
                        <radiogroup orientation="horizontal" >
                            <text text="性别选择:"  w="auto" textStyle="bold" />
                            <radio id="单选框_是否不限" text="不限" checked="true" marginLeft='5'/>
                            <radio id="单选框_是否男" text="男" marginLeft='5'/>
                            <radio id="单选框_是否女" text="女" marginLeft='5'/>
                        </radiogroup>
                        <horizontal>
                            <text text="浏览轮数:"  textStyle="bold" textSize="15sp"/>
                            <input id="输入框_浏览轮数" text="10" color="#666666" w="*"/>
                        </horizontal>
                        <horizontal>
                            <text text="浏览前多少个:"  textStyle="bold" textSize="15sp"/>
                            <input id="输入框_浏览前多少个" text="20" color="#666666" w="*"/>
                        </horizontal>
                        <horizontal>
                            <text text="查看停留时间(秒):"  textStyle="bold" textSize="15sp"/>
                            <input id="输入框_查看停留时间小" text="1" color="#666666" w="80"/>
                            <text text=" - "  textStyle="bold" textSize="15sp"/>
                            <input id="输入框_查看停留时间大" text="2" color="#666666" w="80"/>
                        </horizontal>
                        <horizontal>
                            <text text="每轮间隔(秒):"  textStyle="bold" textSize="15sp"/>
                            <input id="输入框_每轮间隔小" text="10" color="#666666" w="80"/>
                            <text text=" - "  textStyle="bold" textSize="15sp"/>
                            <input id="输入框_每轮间隔大" text="20" color="#666666" w="80"/>
                        </horizontal>
                    </vertical>
                    <View bg="#4EBFDD" h="*" w="5" />
                </card>
            </vertical>
        </ScrollView>
    </vertical>
}
View Code

 

 

 2.项目二-比较全

"ui";
var rootUrl = "http://114.115.220.1:91";
ui.layout(
    <drawer id="drawer">
        <vertical>
            <appbar>
                <toolbar bg="#FF5c50e6" id="toolbar" title="薅羊毛UI版v1.0.0" paddingTop="2dp" h="auto" >
                </toolbar>
                <tabs id="tabs" />
            </appbar>
            <viewpager id="viewpager">
                {/* 第一个Frame */}
                <frame>
                    <scroll>
                        <vertical gravity="center">
                            <checkbox id="qimao" text="七猫免费小说" textSize="16sp" checked="true" />
                            <checkbox id="fanqie" text="番茄免费小说" textSize="16sp" />
                            <checkbox id="lizhi" text="栗子视频" textSize="16sp" />
                            <checkbox id="douyin" text="抖音极速版" textSize="16sp" checked="true" />
                            <checkbox id="kuaishou" text="快手极速版" textSize="16sp" checked="true" />
                            <checkbox id="caidan" text="彩蛋视频" textSize="16sp" checked="true" />
                            <checkbox id="shuabao" text="刷宝短视频" textSize="16sp" checked="true" />
                            <checkbox id="huoshan" text="火山极速版" textSize="16sp" checked="true" />
                            <checkbox id="taokandian" text="淘看点" textSize="16sp" />
                            <checkbox id="youyan" text="有颜短视频" textSize="16sp" />
                            <checkbox id="hongbao" text="红包视频" textSize="16sp" />
                            <horizontal gravity="right">
                                <button style="Widget.AppCompat.Button.Colored" id="wool" text="薅羊毛" padding="12dp" w="auto" />
                                <button style="Widget.AppCompat.Button.Colored" id="close" text="关闭线程" />
                            </horizontal>
                        </vertical>
                    </scroll>
                </frame>
                {/* 第二个Frame */}
                <frame>
                    <scroll>
                        <vertical>
                            <vertical>
                                <text text="遍历次数:" textColor="red" padding="8 8 8 8" />
                                <input id="txtForeachTimes" text="10" hint="每个App被打开的次数" inputType="number" padding="8 8 8 8" />
                            </vertical>
                            <vertical>
                                <text text="滑动屏幕次数:" textColor="red" padding="8 8 8 8" />
                                <input id="txtScreenSileTimes" text="100" hint="每个App被滑动屏幕次数" inputType="number" padding="8 8 8 8" />
                            </vertical>
                            <vertical>
                                <text text="屏幕滑动时间间隔(秒):" textColor="red" padding="8 8 8 8" />
                                <input id="txtScreenSileTimesInterval" text="15" hint="视频之间的滑动时间间隔" inputType="number" padding="8 8 8 8" />
                            </vertical>
                            <vertical>
                                <Switch id="autoService" text="开启无障碍服务" checked="{{auto.service != null}}" textColor="red" padding="8 8 8 8" textSize="15sp" />
                            </vertical>
                            <vertical>
                                <Switch id="switchEnbleFloating" text="开启悬浮窗" checked="{{auto.service != null}}" padding="8 8 8 8" textSize="15sp" textColor="red" />
                            </vertical>
                            <vertical>
                                <Switch id='switchIsShowConsole' text="是否开启控制台:" padding="8 8 8 8" textColor="black" />
                            </vertical>
                  
                            <horizontal>
                                <button style="Widget.AppCompat.Button.Colored" id="btnSaveWoolConfig" text="保存配置" padding="12dp" w="*" />
                            </horizontal>
                        </vertical>
                    </scroll>
                </frame>
                {/* 第3个Frame邀请码 */}
                <frame>
                    <scroll>
                        <vertical>
                            <vertical>
                                <list id="recommandList">
                                    <horizontal h="40">
                                        <text id="txtAppName" textSize="16sp" textColor="#000000" text="{{AppName}}" />
                                        <text id="txtAppCode" textSize="16sp" textColor="#000000" text="{{AppCode}}" />
                                        <button text="复制" id="btnCopyText" style="Widget.AppCompat.Button.Borderless" w="52" textColor="#FF7F50" />
                                    </horizontal>
                                </list>
                            </vertical>
                        </vertical>
                    </scroll>
                </frame>
                {/* 第4个Frame帮助文档 */}
                <frame>
                    <scroll>
                        <vertical>
                            <text w="auto" color="#111111" size="26" text="权限设置" textColor="black" padding="8 8 8 8" />
                            <vertical padding="8 8 8 8">
                                <text w="auto" color="#228B22" size="16" text="一、需要启动无障碍服务。因为本程序是基于Autojs4.1.0编写,AutoJs是基于无障碍服务的插件。" />
                                <text w="auto" color="#228B22" size="16" text="1、首先打开设置页面后,然后向下滑动。" />
                                <text w="auto" color="#228B22" size="16" text="2、此时我们我们将会看到辅助功能。" />
                                <text w="auto" color="#228B22" size="16" text="3、在辅助功能页面中我们继续向下滑动。" />
                                <text w="auto" color="#228B22" size="16" text="4、直到我们会看到无障碍,然后点击进去。" />
                                <text w="auto" color="#228B22" size="16" text="5、最后,我们找到想要设置的程序点击进去。" />
                                <text w="auto" color="#228B22" size="16" text="6、这时候我们点开开关即可成功启动。" />
                                <text w="auto" color="red" size="12" text="注:不同的android版本设置可能不同。" />
                            </vertical>
                            <vertical padding="8 8 8 8">
                                <text w="auto" color="#228B22" size="16" text="二、允许app显示在其他应用的上层。" />
                                <text w="auto" color="#228B22" size="16" text="1、首先打开设置页面后,然后向下滑动找到应用。" />
                                <text w="auto" color="#228B22" size="16" text="2、此时我们点击应用找到权限管理。" />
                                <text w="auto" color="#228B22" size="16" text="3、点击权限管理进入后可以搜索薅羊毛UI版或者滑动查找。" />
                                <text w="auto" color="#228B22" size="16" text="4、点击薅羊毛UI版进入后找到悬浮窗。" />
                                <text w="auto" color="#228B22" size="16" text="4、点击悬浮窗进入后点击允许即可。" />
                            </vertical>
                            <text w="auto" color="#111111" size="26" text="安装被薅羊毛App" textColor="black" padding="8 8 8 8" />
                            <vertical padding="8 8 8 8">
                                <text w="auto" color="#228B22" size="16" text="     点击“薅羊毛”选项卡查看哪些应用被支持,然后去应用市场或者直接在我的博客中下载相应的App。无论是在哪里下载的App都要在“推荐码”中复制邀请码,填写到App邀请中,双方互惠互利,也算是对作者的支持,在此谢过了!!!" />
                            </vertical>
                            <text w="auto" color="#111111" size="26" text="配置薅羊毛UI版" textColor="black" padding="8 8 8 8" />
                            <vertical padding="8 8 8 8">
                                <text w="auto" color="#228B22" size="16" text="     点击“配置”选项卡,在里面进行App打开次数和薅羊毛次数已经是否显示控制台等配置。其中无障碍模式和悬浮窗权限均可以在配置中设置。" />
                                <text w="auto" color="red" size="12" text="注1:控制台最好不开启,防止click直接点击屏幕失效。" />
                                <text w="auto" color="red" size="12" text="注2:防止封号建议遍历次数多设置几次,而滑动屏幕次数少一些建议不要超过500次。" />
                            </vertical>
                            <text w="auto" color="#111111" size="26" text="关于" textColor="black" padding="8 8 8 8" />
                            <vertical padding="8 8 8 8">
                                <text w="auto" color="#228B22" size="16" text="     薅羊毛UI版纯属个人爱好,如果涉及到侵权请通知作者,作者会尽快解决相应问题。作者邮箱:zy0412326@sina.com." />
                            </vertical>
                        </vertical>
                    </scroll>
                </frame>
                {/* 第五个Frame打赏 */}
                <frame>
                    <scroll>
                        <vertical padding="8 8 8 8">
                            <text color="#228B22" size="16" text="如果我帮助到了你,希望你也帮助我.毕竟您的支持才是我前进最大的动力。"></text>
                            <vertical padding="8 8 8 8">
                                <img src="http://ship.maritech.cn/app/Resources/Images/zhifubao.jpg" />
                            </vertical>
                            <vertical padding="8 8 8 8">
                                <img src="http://ship.maritech.cn/app/DownLoad/weixin.jpg" />
                            </vertical>
                        </vertical>
                    </scroll>
                </frame>
            </viewpager>
        </vertical>
        {/* drawer */}
        <vertical layout_gravity="left" bg="#ffffff" w="280">
            <img w="280" h="200" scaleType="fitXY" src="{{rootUrl}}/app/Resources/Images/weixin.jpg" />
            <scroll>
                <list id="menu">
                    <horizontal bg="?selectableItemBackground" w="*">
                        <img w="50" h="50" padding="16"  src="{{icon}}" />
                        <text textColor="black" textSize="15sp" text="{{title}}" layout_gravity="center" />
                    </horizontal>
                </list>
            </scroll>
        </vertical>
    </drawer>
);
//设置滑动页面的标题
ui.viewpager.setTitles(["薅羊毛", "配置", "推荐码", "帮助", "打赏"]);
//让滑动页面和标签栏联动
ui.tabs.setupWithViewPager(ui.viewpager);
 
 
var items = [
    { AppName: "1、抖音极速版", AppCode: "890992808" },
    { AppName: "2、快手极速版", AppCode: "2rvxaem" },
    { AppName: "3、刷宝短视频", AppCode: "AD8PRR6" },
    { AppName: "4、彩蛋视频", AppCode: "A162141619" },
    { AppName: "5、火山极速版", AppCode: "279116054" },
    { AppName: "6、种子视频", AppCode: "30183757" },
    { AppName: "7、刷爆短视频", AppCode: "2021337227" },
    { AppName: "8、红包视频", AppCode: "vu2226878" },
    { AppName: "9、七猫免费小说", AppCode: "5K9FRS" },
    { AppName: "10、番茄免费小说", AppCode: "1849623318" },
    { AppName: "11、今日头条极速版", AppCode: "1849623318" },
    { AppName: "12、看点快报", AppCode: "SLVJLQC" },
    { AppName: "13、步多多", AppCode: "6278618227" },
    { AppName: "14、猫扑运动", AppCode: "375011245" },
    { AppName: "15、走路赚钱", AppCode: "KCHRMAP2" },
    { AppName: "16、快刷视频", AppCode: "21337227" },
    { AppName: "17、淘看点", AppCode: "399479" },
    { AppName: "18、有颜短视频", AppCode: "27201029371" },
    { AppName: "19、免费淘小说", AppCode: "A74219742" },
    { AppName: "小米应用商店该有的都有", AppCode: "http://app.mi.com" },
];
ui.recommandList.setDataSource(items);
activity.setSupportActionBar(ui.toolbar);
 
 
// 用户勾选无障碍服务的选项时,跳转到页面让用户去开启 android.permission.SYSTEM_ALERT_WINDOW
ui.autoService.on("check", function (checked) {
    if (checked && auto.service == null) {
        app.startActivity({
            action: "android.settings.ACCESSIBILITY_SETTINGS"
        });
    }
    if (!checked && auto.service != null) {
        auto.service.disableSelf();
    }
});
// 用户勾选无障碍服务的选项时,跳转到页面让用户去开启 
ui.switchEnbleFloating.on("check", function (checked) {
    if (checked && auto.service == null) {
        app.startActivity({
            action: "android.permission.SYSTEM_ALERT_WINDOW"
        });
    }
    if (!checked && auto.service != null) {
        auto.service.disableSelf();
    }
});
// 当用户回到本界面时,resume事件会被触发
ui.emitter.on("resume", function () {
    // 此时根据无障碍服务的开启情况,同步开关的状态
    ui.autoService.checked = auto.service != null;
});
initializeRightMenu();
initializeHeaderMenu();
initializeData();
/**
 * 薅羊毛
 */
ui.wool.click(function () {
    var appArray = getAppList();
    var foreachTimes = ui.txtForeachTimes.getText();
    var screenSileTimes = ui.txtScreenSileTimes.getText();
    var isShowConsole = ui.switchIsShowConsole.isChecked();
    var timesInterval = ui.txtScreenSileTimesInterval.getText();
    var consoleMessage = "不开启控制台";
    if (isShowConsole) {
        consoleMessage = "开启控制台";
    }
    var tipMessage = "本次共" + appArray.length + "个App参与薅羊毛任务,共循环"
        + ui.txtForeachTimes.getText() + "次,"
        + "屏幕滑动" + screenSileTimes + "次,"
        + consoleMessage
        + "确认执行吗?如果配置不正确请点击取消,前往配置页面进行参数修正!";
    confirm(tipMessage).then(value => {
        //当点击确定后会执行这里, value为true或false, 表示点击"确定"或"取消"
        if (value) {
            threads.start(function () {
                //在新线程执行的代码
                auto.waitFor();
                toast("薅羊毛开始请等待进入第一个程序!");
                wool(appArray, foreachTimes, screenSileTimes, isShowConsole, timesInterval);
            });
        } else {
 
        }
    });
});
/**
 * 关闭薅羊毛程序
 */
ui.close.click(function () {
    toast("薅羊毛线程已经被关闭!");
    threads.shutDownAll();
});
ui.btnSaveWoolConfig.click(function () {
    var woolStorage = storages.create("zy0412326@sina.com");//创建本地存储
    woolStorage.put("foreachTimes", "" + ui.txtForeachTimes.getText() + "");
    woolStorage.put("screenSileTimes", "" + ui.txtScreenSileTimes.getText() + "");
    woolStorage.put("isShowConsole", "" + ui.switchIsShowConsole.isChecked() + "");
    woolStorage.put("timesInterval", "" + ui.txtScreenSileTimesInterval.getText() + "");
    toast("薅羊毛配置保存成功!");
});
ui.recommandList.on("item_bind", function (itemView, itemHolder) {
    itemView.btnCopyText.on("click", function () {
        let item = itemHolder.item;
        toast("复制成功: " + item.AppCode);
        setClip(item.AppCode);
    });
})
 
 
function initializeRightMenu() {
    ui.menu.setDataSource([
        { title: "更新日志",icon:"" },
        { title: "检查更新",icon:"" },
        { title: "教程",icon:"" },
        { title: "关于",icon:"" },
        { title: "退出" ,icon:""}
    ]);
    ui.menu.on("item_click", item => {
        switch (item.title) {
            case "更新日志":
                app.openUrl(rootUrl+"/app/WoolUpgradeLog.html");
                break;
            case "检查更新":
                threads.start(function () {
                    let titileAndVersion = ui.toolbar.getTitle();
                    let appNameAndVersionArray = titileAndVersion.split("v");
                    let appName = appNameAndVersionArray[0];
                    let appVersion = appNameAndVersionArray[1];
                    var url = rootUrl + "/app/WebService.asmx/CheckAppVersion";
                    var version = appVersion;
                    var res = http.post(url, { "appName": appName, "version": version });
                    var returnString = res.body.string();
                    let json = JSON.parse(returnString);
                    if (json.success == "true") {
                        if (json.data.upgrade == "true") {
                            app.openUrl(rootUrl + "/app/WebService.asmx/DownLoadWoolUIApk");
                        } else {
                            toast("已经是最新版");
                        }
                    } else {
                        toast("请求远端服务器出现异常!请稍后重试!");
                    }
                });
                break;
            case "教程":
                    app.openUrl("https://blog.csdn.net/zy0412326/article/details/104767602");
                    break;
            case "关于":
                dialogs.build({
                    title: "关于",
                    positive: "确定",
                    items: ["薅羊毛UI版纯属个人爱好,如果涉及到侵权请通知作者,作者会尽快解决相应问题。作者邮箱:zy0412326@sina.com"]
                }).on("show", (dialog) => { }).show();
                break;
            case "退出":
                ui.finish();
                break;
        }
    });
    //让工具栏左上角可以打开侧拉菜单
    ui.toolbar.setupWithDrawer(ui.drawer);
}
/**
* 创建选项菜单(右上角)右上角菜单事件
*/
function initializeHeaderMenu() {
    ui.emitter.on("create_options_menu", menu => {
        menu.add("更新日志");
        menu.add("打赏");
        menu.add("教程");
        menu.add("关于");
        menu.add("退出");
    });
    ui.emitter.on("options_item_selected", (e, item) => {
        switch (item.getTitle()) {
            case "更新日志":
                app.openUrl(rootUrl + "/app/WoolUpgradeLog.html");
                break;
            case "打赏":
                app.openUrl(rootUrl + "/app/index.aspx");
                break;
            case "教程":
                app.openUrl("https://blog.csdn.net/zy0412326/article/details/104767602");
                break;
            case "关于":
                dialogs.build({
                    title: "关于",
                    positive: "确定",
                    items: ["薅羊毛UI版纯属个人爱好,如果涉及到侵权请通知作者,作者会尽快解决相应问题。作者邮箱:zy0412326@sina.com"]
                }).on("show", (dialog) => { }).show();
                break;
            case "退出":
                ui.finish();
                break;
        }
        e.consumed = true;
    });
}
/**
 * 初始化UI和数据
 */
function initializeData() {
    // threads.start(function () {
    //     console.show();
    // });
    var woolStorage = storages.create("zy0412326@outlook.com");//创建本地存储
    var foreachTimes = woolStorage.get("foreachTimes");
    var screenSileTimes = woolStorage.get("screenSileTimes");
    var isShowConsole = woolStorage.get("isShowConsole");
    var timesInterval = woolStorage.get("timesInterval");
    var appInstallDateTime = woolStorage.get("appInstallDateTime");
    if (foreachTimes != null) {
        ui.txtForeachTimes.setText(foreachTimes);
    }
    if (screenSileTimes != null) {
        ui.txtScreenSileTimes.setText(screenSileTimes);
    }
    if (isShowConsole != null && isShowConsole == "true") {
        ui.switchIsShowConsole.setChecked(true);
    } else {
        ui.switchIsShowConsole.setChecked(false);
    }
    if (timesInterval != null) {
        ui.txtScreenSileTimesInterval.setText(timesInterval);
    }
    if (appInstallDateTime != null) {
        var curTime = new Date();
        var currentTime = new Date(parseInt(curTime.getFullYear()), parseInt(curTime.getMonth() + 1), parseInt(curTime.getDate()), parseInt(curTime.getHours()), parseInt(curTime.getMinutes()), parseInt(curTime.getSeconds()));
        var appInstallDate = appInstallDateTime.toString().split("-");
        var getDay = appInstallDate[2].split(" ")[0]; //
        var hourMM = appInstallDate[2].split(" ")[1];//时分秒
        var appInstallTime = new Date(parseInt(appInstallDate[0]), parseInt(appInstallDate[1]), parseInt(getDay), hourMM.split(":")[0], hourMM.split(":")[1], parseInt(0));
        var seconds=currentTime - appInstallTime;
        if (seconds/(1000 * 60 * 60 * 24)>3) {
            alert("薅羊毛已经过去3天了,烦请打赏一下作者,您的支持是作者最大的动力!");
            woolStorage.put("appInstallDateTime", "" + getTime() + "");
        }
    } else {
        woolStorage.put("appInstallDateTime", "" + getTime() + "");
    }
}
/**
 * 获取被选择的app
 */
function getAppList() {
    var appArray = new Array(); //app集合
 
    var qimao = ui.qimao.isChecked();
    if (qimao) {
        appArray.push(ui.qimao.getText());
    }
 
    var fanqie = ui.fanqie.isChecked();
    if (fanqie) {
        appArray.push(ui.fanqie.getText());
    }
   
    var douyin = ui.douyin.isChecked();
    if (douyin) {
        appArray.push(ui.douyin.getText());
    }
 
    var kuaishou = ui.kuaishou.isChecked();
    if (kuaishou) {
        appArray.push(ui.kuaishou.getText());
    }
    var shuabao = ui.shuabao.isChecked();
    if (shuabao) {
        appArray.push(ui.shuabao.getText());
    }
   
    var huoshan = ui.huoshan.isChecked();
    if (huoshan) {
        appArray.push(ui.huoshan.getText());
    }
    var hongbao = ui.hongbao.isChecked();
    if (hongbao) {
        appArray.push(ui.hongbao.getText());
    }
    var taokandian = ui.taokandian.isChecked();
    if (taokandian) {
        appArray.push(ui.taokandian.getText());
    }
    var youyan = ui.youyan.isChecked();
    if (youyan) {
        appArray.push(ui.youyan.getText());
    }
    var caidan = ui.caidan.isChecked();
    if (caidan) {
        appArray.push(ui.caidan.getText());
    }
    //lizhi
    var lizhi = ui.lizhi.isChecked();//
    if (lizhi) {
        appArray.push(ui.lizhi.getText());
    }
    return appArray;
}
/**
 * 薅羊毛
 * @param {应用列表} appArray 
 * @param {应用打开次数} foreach_count 
 * @param {屏幕滑动次数} see_count 
 * @param {是否显示控制台} isShowConsole 
 * @param {延迟时间} timesInterval 
 */
function wool(appArray, foreach_count, see_count, isShowConsole, timesInterval) {
    threads.start(function () {
        if (isShowConsole) {
            console.show();
            console.setSize(device.width, device.height / 4);
        }
    });
    for (x = 1; x <= foreach_count; x++) {
        for (y = 0; y < appArray.length; y++) {
            let appName = appArray[y];
            toast("当前薅羊毛程序" + appName);
            console.log("当前薅羊毛程序" + appName);
            app.launchApp(appName);
            sleep(10000);//目前无法判断网速和splash时间,只能延迟久一点。10秒延迟。
            if (appName == '刷宝短视频') {
                authorityCancleTip();//关闭权限提示框
            }
            else if (appName == '彩蛋视频') {
                caiDanCloseAd();
            }
            else if (appName == '七猫免费小说') {
                let bookList = className("android.widget.LinearLayout").find();
                if (bookList != null) {
                    try {
                        bookList[2].click();
                    } catch (e) { }
                }
            }
            else if (appName == '番茄免费小说') {
                try {
                    if (className("android.widget.RadioButton").id('in').exists()) {
                        let bookshelf = className("android.widget.RadioButton").id('in').findOnce();
                        bookshelf.click();
                        sleep(2000);
                        let booklist = className('android.view.ViewGroup').find();//查找到的所有ViewGroup
                        if (booklist != null) {
                            booklist[1].click();//第一本书的ViewGroup
                        }
                    }
                } catch (e) { }
            }
            else if (appName == '火山极速版') {
                clickScreen();//点击一下进入视频(默认页面是列表得选一个)
            }
            for (z = 1; z <= see_count; z++) {
                var curDateTimes = new Date();
                let currentDateTime = curDateTimes.getFullYear() + "-" + (curDateTimes.getMonth() + 1) + "-" + curDateTimes.getDate() + " " + curDateTimes.getHours() + ":" + curDateTimes.getMinutes() + ":" + curDateTimes.getSeconds();
                var messagge = currentDateTime + " " + appName + "被打开第" + x + "次一共" + foreach_count + "次。" + "本次打开滑动" + z + '次,' + "总计:" + see_count + "次"
                toast(messagge);
                console.info(messagge);
                if (appName == "抖音极速版") {
                    randomUpSildeScreen();
                    randomDownSildeScreen();
                    randomHeart('a4l');//随机关注百分之一的概率
                    randomFollow('a4j');//随机关注百分之一的概率
                    slideScreenDown(device.width / 2, device.height - 400, device.width / 2, 300, 300, timesInterval);
                    continue;
                } else if (appName == '快手极速版') {
                    kuaiShouCloseInvitationNotice();
                    kuaiShouCloseIsLike();
                    randomUpSildeScreen();
                    randomDownSildeScreen();
                    randomHeart('like_button');//随机关注百分之一的概率
                    randomFollow('nebula_thanos_bottom_follow_button_layout');//随机关注百分之一的概率
                } else if (appName == '刷宝短视频') {
                    clickScreen();//点击一下屏幕防止直播遮挡,影响滑动。
                    shuabaoCloseAD();
                    randomDownSildeScreen();//估计不好使
                    slideScreenDown(device.width / 2, device.height - 600, device.width / 2, 100, 700, timesInterval);//他的滑动特殊
                    continue;
                } else if (appName == '彩蛋视频') {
                    caiDanCloseAd();
                    caiDanCloseGoderEgg();
                    randomUpSildeScreen();
                    randomDownSildeScreen();
                    caiDanRandomHeart();
                    randomFollow("attention");
                    slideScreenDown(device.width / 2, device.height - 200, device.width / 2, 500, 700, timesInterval);
                    continue;
                } else if (appName == '火山极速版') {
                    clickScreen();//点击一下进入视频(默认页面是列表得选一个)
                    randomUpSildeScreen();
                    randomDownSildeScreen();
                } else if (appName == '红包视频') {
                    randomHeart('good_count_layoutob');//随机关注百分之一的概率
                    swipe(303, 1328, 335, 171, 600);
                    sleep(36000);//时间和其的视频不一样此类视频必须看完才给分
                    z++;
                }
                else if (appName == '淘看点') {
                    randomUpSildeScreen();//模仿人类随向上滑动一次,表示对这个视频有兴趣
                    randomDownSildeScreen();//模仿人类随连续下滑2次,表示对当前视频无兴趣
                    randomHeart("like_ll");//模仿人类随随机点赞有颜短视频
                    slideScreenDown(303, 1328, 335, 171, 600, timesInterval);
                    continue;
                }
                else if (appName == '有颜短视频') {
                    youyanCloseAd();
                    randomHeart("like_ll");//模仿人类随随机点赞
                    randomHeart("layout_like");//模仿人类随随机点赞
                    slideScreenDown(303, 1328, 335, 171, 600, timesInterval);
                    continue;
                }
                else if (appName == '七猫免费小说') {
                    sildeScreenRight();
                    continue;
                }
                else if (appName == '番茄免费小说') {
                    sildeScreenRight();
                    continue;
                }
                else if (appName == '栗子视频') {
                    randomDownSildeScreen();//模仿人类随连续下滑2次,表示对当前视频无兴趣
                    randomHeart("vv");//模仿人类随随机点赞
                    randomFollow("w3");//模仿人类随随机关注
                    slideScreenDown(device.width / 2, device.height-200, device.width / 2, 200, 300,timesInterval);
                    continue;;
                }
                slideScreenDown(device.width / 2, device.height - 200, device.width / 2, 500, 300, timesInterval);
            }
            console.clear();//
        }
    }
    toast("薅羊毛程序执行完毕3秒后即将关闭...");
    console.error("薅羊毛程序执行完毕3秒后即将关闭...");
    for (let i = 3; i >= 1; i--) {
        console.error(i);
        sleep(1000);
        if (i == 1) {
            home();//返回主页面
            return;
        }
    }
}
/**
 * 一键签到
 * @param {签到程序得app} appArray 
 * @param {是否显示控制台} isShowConsole 
 */
function sign(appArray, isShowConsole) {
 
}
/**
 * 秒转换成小时
 * @param {*} appCount 
 * @param {*} foreachCount 
 * @param {*} slideTimes 
 * @param {*} timesInterval 
 * @param {*} isExistsLongTimes 
 */
function computerTime(appCount, foreachCount, slideTimes, timesInterval, isExistsLongTimes) {
    let maxSecond = appCount * foreachCount * slideTimes * timesInterval;
    let maxHour = maxSecond / 3600;
    return Math.round(maxHour);
}
/**
 * 关闭脚本和回到桌面(让手机歇一会)
 * @param {程序关闭时间} closeDateTime 
 */
function closeWoolApp(closeDateTime) {
    if (closeDateTime == "") {
        return
    } else {
        var startDate = closeDateTime.toString().split("-");
        var getDay = startDate[2].split(" ")[0]; //
        var hourMM = startDate[2].split(" ")[1];//时分秒
        var stopTime = new Date(parseInt(startDate[0]), parseInt(startDate[1]), parseInt(getDay), parseInt(hourMM.split(":")[0]), parseInt(hourMM.split(":")[1]), parseInt(0));
        var curTime = new Date();
        var nowTime = new Date(parseInt(curTime.getFullYear()), parseInt(curTime.getMonth() + 1), parseInt(curTime.getDate()), parseInt(curTime.getHours()), parseInt(curTime.getMinutes()), parseInt(curTime.getSeconds()));
        if (stopTime < nowTime) {
            console.warn("关闭时间已到,系统5秒后关闭");
            sleep(5000);
            home();
            exit();
        }
    }
}
/**
 * 屏幕向下滑动并延迟8至12秒
 */
function slideScreenDown(startX, startY, endX, endY, pressTime, timesInterval) {
    swipe(startX, startY, endX, endY, pressTime);
    let randomMin = timesInterval * 1000;
    let randomMax = (parseInt(timesInterval) + 2) * 1000;
    let delayTime = random(randomMin, randomMax);
    sleep(delayTime);
}
/**
 *关闭金丹
 */
function caiDanCloseGoderEgg() {
    if (id("close_bottom_button").exists()) {
        console.log("关闭金丹");
        id("close_bottom_button").findOnce().click();
    }
}
/**
 *关闭广告
 */
function caiDanCloseAd() {
    if (id("btn_back").exists()) {
        console.log("关闭广告");
        id("btn_back").findOne().click();
    }
}
/**
 *彩疍随机点赞有问题
 */
function caiDanRandomHeart() {
    index = random(1, 50);
    if (index == 1) {
        console.log("彩疍随机点赞有问题");
        try {
            id("video_detail_recyclerview").className("android.support.v7.widget.RecyclerView").scrollable(true).findOne().children().forEach(child => {
                var target = child.findOne(id("ll_like_show_btn"));
                target.click();
                sleep(1000);
            });
        } catch (e) {
 
        }
    }
}
/**
 *点击一下屏幕
 */
function clickScreen() {
    var x = device.width / 2;
    var y = device.height / 2;
    click(x, y);
}
/**
 *通知权限被禁止后刷宝得提示框
 */
function authorityCancleTip() {
    if (id("cancel").exists()) {
        id("cancel").findOnce().click();
    }
}
/**
 *向右侧滑动
 */
function sildeScreenRight() {
    pressTime = random(250, 600);
    swipe(750, 1000, 100, 1000, pressTime);//750, 120, 100, 120, 100
    delayTime = random(25000, 30000);
    sleep(delayTime);
}
 
/**
 * 随机点赞
 * @param {点赞ID}} view_id 
 */
function randomHeart(view_id) {
    index = random(1, 100);
    if (index == 66) {
        var target = id(view_id).findOnce();
        if (target == null) {
            return;
        } else {
            target.click();
            sleep(1000);
        }
    }
}
/**
 * 随机关注
 * @param {*} follow_view_id 
 */
function randomFollow(follow_view_id) {
    index = random(1, 100);
    if (index == 66) {
        var target = id(follow_view_id).findOnce();
        if (target == null) {
            return;
        } else {
            target.click();
            sleep(1000);
        }
    }
}
/**
 * goPlay
 */
function goPlay() {
    if (goPlay = text("继续播放").exists()) {
        goPlay.click();
    };
}
/**
 * 随机上滑(防止被判定是机器)上滑后停留时间至少是10S,造成假象表示是对内容感兴趣
 * 点赞和关注先不搞。
 */
function randomUpSildeScreen() {
    let randomIndex = random(1, 50);
    if (randomIndex == 1) {
        console.log("随机上滑被执行了!!!");
        pressTime = random(200, 500);
        swipe(device.width / 2, 500, device.width / 2, device.height - 200, 300);
        delayTime = random(10000, 15000);
        sleep(delayTime);
    }
}
/**
 * 连续下滑对上一个无兴趣
 * 其实得和上滑做个排他,既然无兴趣不要在上滑
 */
function randomDownSildeScreen() {
    let randomIndex = random(1, 20);
    if (randomIndex == 1) {
        console.log("连续下滑被执行了");
        swipe(device.width / 2, device.height - 200, device.width / 2, 500, 300);
        sleep(2000);
        swipe(device.width / 2, device.height - 200, device.width / 2, 500, 300);
        delayTime = random(8000, 10000);
        sleep(delayTime);
    }
}
/**
 * 刷宝关闭广告
 */
function shuabaoCloseAD() {
    try {
        id("list").findOne().children().forEach(child => {
            var target = child.findOne(id("hotspot_imgdismiss"));
            target.click();
        });
    } catch (e) {
        console.error("刷宝关闭广告出现错误" + e);
    }
}
/**
 * 有颜视频关闭广告
 */
function youyanCloseAd() {
    if (className("android.widget.ImageView").id("img_close").exists()) {
        className("android.widget.ImageView").id("img_close").findOnce().click();
    }
}
function huoHuoClickGoldEgg() {
    if (text("金蛋大奖").exists()) {
        let b = text("金蛋大奖").findOne().parent().bounds();
 
        click(b.centerX(), b.centerY());
        sleep(400);
        let widgetViews = className("android.widget.TextView").find();
        if (widgetViews != null) {
            console.info(widgetViews.length);
            widgetViews[0].click();
        }
        sleep(4000);//关闭按钮3S后才出现
        if (className("android.widget.FrameLayout").id("jh").exists()) {
            className("android.widget.FrameLayout").id("jh").findOnce().click();
        }
        closeReturnOrCloseButton();
    }
    sleep(1000);
}
function closeReturnOrCloseButton() {
    if (className("android.widget.FrameLayout").id("jh").exists()) {
        className("android.widget.FrameLayout").id("jh").findOnce().click();
    }
}
function kuaiShuaCloseHongBao() {
    try {
        if (id("overlay_text").exists()) {
            id("overlay_text").findOnce().click();
        }
    } catch (e) { }
}
/**
 * 快手关闭是否喜欢对话框
 */
function kuaiShouCloseIsLike() {
    if (className("android.widget.TextView").text("不影响").exists()) {
        className("android.widget.TextView").text("不影响").findOnce().click();
    }
}
function kuaiShouCloseInvitationNotice() {
    try {
        if (className("android.widget.ImageButton").id("close").exists()) {
            className("android.widget.ImageButton").id("close").findOnce().click();
        }
    } catch (e) { }
}
function getTime() {
    var date = new Date();
    var year = date.getFullYear();
    var month = date.getMonth() + 1;
    if (month < 10) {
        month = "0" + month;
    };
    var day = date.getDate();
    if (day < 10) {
        day = "0" + day;
    };
    var hour = date.getHours();
    if (hour < 10) {
        hour = "0" + hour;
    };
    var minute = date.getMinutes();
    if (minute < 10) {
        minute = "0" + minute;
    };
    return year +"-"+ month +"-"+ day +" "+ hour +":"+ minute+":"+ "0";
};
View Code

 

3.项目三-可以参考

"ui"; 
ui.layout(
    <drawer id="drawer">
        <vertical>
            <appbar>
                <toolbar bg="#FF5c50e6" id="toolbar" title="超级大蚂蚁UI版v1.0.0" paddingTop="2dp" h="auto" >
                </toolbar>
                <tabs id="tabs" />
            </appbar>
            <viewpager id="viewpager">
                {/* 第一个Frame */}
                <frame>
                    <scroll>
                        <vertical gravity="center">
                            <horizontal  gravity="center_vertical" padding="5 5" >
                                <View bg="#00BFFF" h="*" w="10"  ></View>
                                <vertical padding="10 8" h="auto" w="0" layout_weight="1">
                                    <text w="auto" textColor="#222222" textSize="14sp" text="今日头条极速版" />
                                    <text w="auto" textColor="#999999" textSize="12sp" text="自动阅读、领金币、宝箱" />
                                </vertical>
                                <checkbox id="toutiao" marginLeft="4" marginRight="6" checked="true" />
                            </horizontal>
 
                            <horizontal  gravity="center_vertical" padding="5 5" >
                                <View bg="#00FFFF" h="*" w="10"  ></View>
                                <vertical padding="10 8" h="auto" w="0" layout_weight="1">
                                    <text w="auto" textColor="#222222" textSize="14sp" text="抖音短视频" />
                                    <text w="auto" textColor="#999999" textSize="12sp" text="滑动、关注、点赞、评论,自动化一体" />
                                </vertical> 
                                <checkbox id="douyin" marginLeft="4" marginRight="6" checked="false" />
                            </horizontal>
 
                           
 
                           
                            <horizontal gravity="right">
                                <button style="Widget.AppCompat.Button.Colored"  id="wool" text="启动" padding="12dp" w="auto" />
                                <button style="Widget.AppCompat.Button.Colored"  id="close" text="关闭线程" />
                            </horizontal>
                        </vertical>
                    </scroll>
                </frame>
                {/* 第二个Frame */}
                <frame>
                    <scroll>
                        <vertical>
                            
                            <horizontal  gravity="center_vertical" padding="5 5" >
                                <View bg="#4876FF" h="*" w="10"  ></View>
                                <text w="auto"  padding="8 8 8 8" textColor="#222222" textSize="14sp" text="遍历次数:" />
                                <input id="txtForeachTimes" text="10"  hint="App被打开的次数"  textSize="13sp"  inputType="number" />
                            </horizontal>
 
                            <horizontal  gravity="center_vertical" padding="5 5" >
                                <View bg="#4876FF" h="*" w="10"  ></View>
                                <text w="auto"  padding="8 8 8 8" textColor="#222222" textSize="14sp" text="滑动屏幕次数:" />
                                <input id="txtScreenSileTimes" text="100"  hint="滑动屏幕次数"  textSize="13sp"  inputType="number" />
                            </horizontal>
 
                            <horizontal  gravity="center_vertical" padding="5 5" >
                                <View bg="#4876FF" h="*" w="10"  ></View>
                                <text w="auto"  padding="8 8 8 8" textColor="#222222" textSize="14sp" text="屏幕滑动时间间隔(秒):" />
                                <input id="txtScreenSileTimesInterval" text="15"  hint="滑动时间间隔"  textSize="13sp"  inputType="number" />
                            </horizontal>
 
                            <horizontal  gravity="center_vertical" padding="5 5" >
                                <View bg="#4F4F4F" h="*" w="10"  ></View>
                                <text w="auto" padding="8 8 8 8" textColor="#222222" textSize="14sp" text="开启无障碍服务" />
                                <Switch id="autoService"  checked="{{auto.service != null}}"  padding="8 8 8 8" />
                            </horizontal>
 
                            <horizontal  gravity="center_vertical" padding="5 5" >
                                <View bg="#4F4F4F" h="*" w="10"  ></View>
                                <text w="auto" padding="8 8 8 8" textColor="#222222" textSize="14sp" text="是否开启控制台" />
                                <Switch id='switchIsShowConsole'  padding="8 8 8 8"  />
                            </horizontal>
                  
                            <horizontal>
                                <button style="Widget.AppCompat.Button.Colored" id="btnSaveWoolConfig" text="保存配置" padding="12dp" w="*" />
                            </horizontal>
                        </vertical>
                    </scroll>
                </frame>
                {/* 第三页*/}
                <frame>
                    <scroll>
                        <vertical>
 
                            <horizontal gravity="center_vertical" padding="5 5"  >
                                <View bg="#00BFFF" h="*" w="10"  ></View>
                                <vertical padding="10 8" h="auto" w="0" layout_weight="1">
                                    <text w="auto" color="#111111" size="16" text="1、需要启动无障碍服务。" />
                                    <text w="auto" color="#111111" size="16" text="2、允许app显示在其他应用的上层。" />
                                </vertical>
                            </horizontal>
                          
                    
                        </vertical>
                    </scroll>
                </frame> 
 
            </viewpager>
        </vertical>
        {/* drawer */}
        <vertical layout_gravity="left" bg="#ffffff" w="280">
            <img w="280" h="200" scaleType="fitXY" src="http://file.superdalan.com//dc46f1aa1f71787000f4252f2453ad3e~800" />
            <scroll>
                <list id="menu">
                    <horizontal bg="?selectableItemBackground" w="*">
                        <img w="50" h="50" padding="16"  src="{{icon}}" />
                        <text textColor="black" textSize="15sp" text="{{title}}" layout_gravity="center" />
                    </horizontal>
                </list>
            </scroll>
        </vertical>
    </drawer>
);
 
 
 
//设置滑动页面的标题
ui.viewpager.setTitles(["首页", "配置","说明"]);
//让滑动页面和标签栏联动
ui.tabs.setupWithViewPager(ui.viewpager);
activity.setSupportActionBar(ui.toolbar);
 
 
 
// 用户勾选无障碍服务的选项时,跳转到页面让用户去开启 
//android.permission.SYSTEM_ALERT_WINDOW
ui.autoService.on("check", function (checked) {
    if (checked && auto.service == null) {
        app.startActivity({
            action: "android.settings.ACCESSIBILITY_SETTINGS"
        });
    }
    if (!checked && auto.service != null) {
        auto.service.disableSelf();
    }
});
 
 
// 当用户回到本界面时,resume事件会被触发
ui.emitter.on("resume", function () {
    // 此时根据无障碍服务的开启情况,同步开关的状态
    ui.autoService.checked = auto.service != null;
});
 
initializeRightMenu();
initializeData();
 
/**
 * 薅羊毛
 */
ui.wool.click(function () {
    var appArray = getAppList();
    var foreachTimes = ui.txtForeachTimes.getText();
    var screenSileTimes = ui.txtScreenSileTimes.getText();
    var isShowConsole = ui.switchIsShowConsole.isChecked();
    var timesInterval = ui.txtScreenSileTimesInterval.getText();
    var consoleMessage = "不开启控制台";
    if (isShowConsole) {
        consoleMessage = "开启控制台";
    }
    var tipMessage = "本次共" + appArray.length + "个App参与薅羊毛任务,共循环"
        + ui.txtForeachTimes.getText() + "次,"
        + "屏幕滑动" + screenSileTimes + "次,"
        + consoleMessage
        + "确认执行吗?如果配置不正确请点击取消,前往配置页面进行参数修正!";
    confirm(tipMessage).then(value => {
        //当点击确定后会执行这里, value为true或false, 表示点击"确定"或"取消"
        if (value) {
            threads.start(function () {
                //在新线程执行的代码
                auto.waitFor();
                toastLog("薅羊毛开始请等待进入第一个程序!");
                wool(appArray, foreachTimes, screenSileTimes, isShowConsole, timesInterval);
            });
        } else {
 
        }
    });
});
 
 
 
 
/**
 * 关闭薅羊毛程序
 */
ui.close.click(function () {
    toastLog("薅羊毛线程已经被关闭!");
    threads.shutDownAll();
});
ui.btnSaveWoolConfig.click(function () {
    var woolStorage = storages.create("abc11ss13");//创建本地存储
    woolStorage.put("foreachTimes", "" + ui.txtForeachTimes.getText() + "");
    woolStorage.put("screenSileTimes", "" + ui.txtScreenSileTimes.getText() + "");
    woolStorage.put("isShowConsole", "" + ui.switchIsShowConsole.isChecked() + "");
    woolStorage.put("timesInterval", "" + ui.txtScreenSileTimesInterval.getText() + "");
    toastLog("薅羊毛配置保存成功!");
});
 
 
 
function initializeRightMenu() {
    ui.menu.setDataSource([
        { title: "更新日志",icon:"" },
        { title: "检查更新",icon:"" },
        { title: "教程",icon:"" },
        { title: "关于",icon:"" },
        { title: "退出" ,icon:""}
    ]);
    ui.menu.on("item_click", item => {
        switch (item.title) {
            case "更新日志":
                app.openUrl("http://file.superdalan.com//dc46f1aa1f71787000f4252f2453ad3e~800");
                break;
            case "检查更新":
                threads.start(function () {
                    let titileAndVersion = ui.toolbar.getTitle();
                    let appNameAndVersionArray = titileAndVersion.split("v");
                    let appName = appNameAndVersionArray[0];
                    let appVersion = appNameAndVersionArray[1];
                    var url = "http://file.superdalan.com//dc46f1aa1f71787000f4252f2453ad3e~800";
                    var version = appVersion;
                    var res = http.post(url, { "appName": appName, "version": version });
                    var returnString = res.body.string();
                    let json = JSON.parse(returnString);
                    if (json.success == "true") {
                        if (json.data.upgrade == "true") {
                            app.openUrl("http://file.superdalan.com//dc46f1aa1f71787000f4252f2453ad3e~800");
                        } else {
                            toastLog("已经是最新版");
                        }
                    } else {
                        toastLog("请求远端服务器出现异常!请稍后重试!");
                    }
                });
                break;
            case "教程":
                    app.openUrl("https://blog.csdn.net/zy0412326/article/details/104767602");
                    break;
            case "关于":
                dialogs.build({
                    title: "关于",
                    positive: "确定",
                    items: ["薅羊毛UI版纯属个人爱好,如果涉及到侵权请通知作者,作者会尽快解决相应问题。作者邮箱:zy0412326@sina.com"]
                }).on("show", (dialog) => { }).show();
                break;
            case "退出":
                ui.finish();
                break;
        }
    });
    //让工具栏左上角可以打开侧拉菜单
    ui.toolbar.setupWithDrawer(ui.drawer);
} 
 
 
/**
 * 初始化UI和数据
 */
function initializeData() {
    // threads.start(function () {
    //     console.show();
    // });
    var woolStorage = storages.create("abc11ss13");//创建本地存储
    var foreachTimes = woolStorage.get("foreachTimes");
    var screenSileTimes = woolStorage.get("screenSileTimes");
    var isShowConsole = woolStorage.get("isShowConsole");
    var timesInterval = woolStorage.get("timesInterval");
    var appInstallDateTime = woolStorage.get("appInstallDateTime");
    if (foreachTimes != null) {
        ui.txtForeachTimes.setText(foreachTimes);
    }
    if (screenSileTimes != null) {
        ui.txtScreenSileTimes.setText(screenSileTimes);
    }
    if (isShowConsole != null && isShowConsole == "true") {
        ui.switchIsShowConsole.setChecked(true);
    } else {
        ui.switchIsShowConsole.setChecked(false);
    }
    if (timesInterval != null) {
        ui.txtScreenSileTimesInterval.setText(timesInterval);
    }
    if (appInstallDateTime != null) {
        var curTime = new Date();
        var currentTime = new Date(parseInt(curTime.getFullYear()), parseInt(curTime.getMonth() + 1), parseInt(curTime.getDate()), parseInt(curTime.getHours()), parseInt(curTime.getMinutes()), parseInt(curTime.getSeconds()));
        var appInstallDate = appInstallDateTime.toString().split("-");
        var getDay = appInstallDate[2].split(" ")[0]; //
        var hourMM = appInstallDate[2].split(" ")[1];//时分秒
        var appInstallTime = new Date(parseInt(appInstallDate[0]), parseInt(appInstallDate[1]), parseInt(getDay), hourMM.split(":")[0], hourMM.split(":")[1], parseInt(0));
        var seconds=currentTime - appInstallTime;
        if (seconds/(1000 * 60 * 60 * 24)>3) {
            alert("薅羊毛已经过去3天了,烦请打赏一下作者,您的支持是作者最大的动力!");
            woolStorage.put("appInstallDateTime", "" + getTime() + "");
        }
    } else {
        woolStorage.put("appInstallDateTime", "" + getTime() + "");
    }
}
 
 
/**
 * 获取被选择的app
 */
function getAppList() {
    var appArray = new Array(); //app集合
    var toutiao = ui.toutiao.isChecked();
    if (toutiao) {
        appArray.push(ui.toutiao.getText());
    }
    return appArray;
}
 
 
 
/**
 * 主程序
 * @param {应用列表} appArray 
 * @param {应用打开次数} foreach_count 
 * @param {屏幕滑动次数} see_count 
 * @param {是否显示控制台} isShowConsole 
 * @param {延迟时间} timesInterval 
 */
function wool(appArray, foreach_count, see_count, isShowConsole, timesInterval) {
    threads.start(function () {
        if (isShowConsole) {
            console.show();
            console.setSize(device.width, device.height / 4);
        }
    });
    for (x = 1; x <= foreach_count; x++) {
        for (y = 0; y < appArray.length; y++) {
            let appName = appArray[y];
            toastLog("当前程序:" + appName);
            //app.launchApp(appName);
            sleep(10000);//目前无法判断网速和splash时间,只能延迟久一点。10秒延迟。
            if (appName == '今日头条极速版') {
                
                toutiaorun();
            }
            //滑动次数
            for (z = 1; z <= see_count; z++) {
               
            }
            console.clear();//
        }
    }
 
    toastLog("程序执行完毕3秒后即将关闭...");
    console.error("程序执行完毕3秒后即将关闭...");
    for (let i = 3; i >= 1; i--) {
        console.error(i);
        sleep(1000);
        if (i == 1) {
            home();//返回主页面
            return;
        }
    }
}
 
 
 
/**
 * 一键签到
 * @param {签到程序得app} appArray 
 * @param {是否显示控制台} isShowConsole 
 */
function sign(appArray, isShowConsole) {
 
}
  
/**
 * 屏幕向下滑动并延迟8至12秒
 */
function slideScreenDown(startX, startY, endX, endY, pressTime, timesInterval) {
    swipe(startX, startY, endX, endY, pressTime);
    let randomMin = timesInterval * 1000;
    let randomMax = (parseInt(timesInterval) + 2) * 1000;
    let delayTime = random(randomMin, randomMax);
    sleep(delayTime);
}
 
/**
 *关闭广告
 */
function caiDanCloseAd() {
    if (id("btn_back").exists()) {
        console.log("关闭广告");
        id("btn_back").findOne().click();
    }
}
 
 
/**
 *点击一下屏幕
 */
function clickScreen() {
    var x = device.width / 2;
    var y = device.height / 2;
    click(x, y);
}
 
 
 
 
/**
 *向右侧滑动
 */
function sildeScreenRight() {
    pressTime = random(250, 600);
    swipe(750, 1000, 100, 1000, pressTime);//750, 120, 100, 120, 100
    delayTime = random(25000, 30000);
    sleep(delayTime);
}
 
/**
 * 随机点赞
 * @param {点赞ID}} view_id 
 */
function randomHeart(view_id) {
    index = random(1, 100);
    if (index == 66) {
        var target = id(view_id).findOnce();
        if (target == null) {
            return;
        } else {
            target.click();
            sleep(1000);
        }
    }
}
 
/**
 * 随机关注
 * @param {*} follow_view_id 
 */
function randomFollow(follow_view_id) {
    index = random(1, 100);
    if (index == 66) {
        var target = id(follow_view_id).findOnce();
        if (target == null) {
            return;
        } else {
            target.click();
            sleep(1000);
        }
    }
}
 
 
 
 
/**
 * 随机上滑(防止被判定是机器)上滑后停留时间至少是10S,造成假象表示是对内容感兴趣
 * 点赞和关注先不搞。
 */
function randomUpSildeScreen() {
    let randomIndex = random(1, 50);
    if (randomIndex == 1) {
        console.log("随机上滑被执行了!!!");
        pressTime = random(200, 500);
        swipe(device.width / 2, 500, device.width / 2, device.height - 200, 300);
        delayTime = random(10000, 15000);
        sleep(delayTime);
    }
}
 
/**
 * 连续下滑对上一个无兴趣
 * 其实得和上滑做个排他,既然无兴趣不要在上滑
 */
function randomDownSildeScreen() {
    let randomIndex = random(1, 20);
    if (randomIndex == 1) {
        console.log("连续下滑被执行了");
        swipe(device.width / 2, device.height - 200, device.width / 2, 500, 300);
        sleep(2000);
        swipe(device.width / 2, device.height - 200, device.width / 2, 500, 300);
        delayTime = random(8000, 10000);
        sleep(delayTime);
    }
}
 
 
/**
 *  
 * 获取当前时间
 */
function getTime() {
    var date = new Date();
    var year = date.getFullYear();
    var month = date.getMonth() + 1;
    if (month < 10) {
        month = "0" + month;
    };
    var day = date.getDate();
    if (day < 10) {
        day = "0" + day;
    };
    var hour = date.getHours();
    if (hour < 10) {
        hour = "0" + hour;
    };
    var minute = date.getMinutes();
    if (minute < 10) {
        minute = "0" + minute;
    };
    return year +"-"+ month +"-"+ day +" "+ hour +":"+ minute+":"+ "0";
    
};
 
View Code

 

 

 

 

相关连接:

https://xiaoxigua.blog.csdn.net/article/details/105057667 ...................................界面ui布局,,事件绑定与监听 ,,UI控件基础

https://blog.csdn.net/qq_30931547/category_10042765.html ...........................autojs文章博客,,停止脚本的6种方法

https://www.freesion.com/article/9484393257/ ....................................................实战教程---终极福利APK

https://www.cnblogs.com/microWhite/p/12966705.html ......................................UI悬浮窗 ,,控制台相关命令

https://blog.csdn.net/qq_29176323/article/details/126216800 ...........................UI编程的注意事项,,

posted on 2022-08-22 18:06  chen_2987  阅读(1975)  评论(0编辑  收藏  举报

导航