独清独醒

举世皆浊我独清,众人皆醉我独醒。

2020年10月6日更新-新版智慧树自动答题,跳过,调倍速(挂机)

智慧树网课辅助脚本,享受一口气看二十课的畅快体验。

2020年10月6日更新

由于新版智慧树没有了“返回旧版”的按钮,于是只好自己重新写一个咯。(哼)

特性

  • 自动 1.5 倍速播放
  • 自动静音
  • 自动回答网课中弹题
  • 自动切换下一节、下一章
  • 自动点击之前,会随机等待0~60秒,模拟人类操作延迟
  • 视频左上角显示是否开启脚本

使用方法

  1. 下载Chrome(理论上只要有控制台的浏览器皆可。)

  2. 打开智慧树视频播放地址

  3. 按下F12

  4. 找到Console《2020年10月6日更新-新版智慧树自动答题,跳过,调倍速(挂机)》

  5. 输入以下代码后回车

    /**
    *  author: 乖乖龙
    *  description: 自动播放、自动下一集、自动选择视频弹窗题目、自动关闭答题窗口、刷智慧树网课必备
    *  use-method: 打开智慧树播放课程界面 按F12 -> Console -> 粘贴本代码 ->按回车键
    *  use-method: 视频左上方出现一个图标点击图标开始刷课 显示‘已开’脚本开始监听 再次点击图标关闭
    *  upadteTime: 2020/10/6
    */
    //定时器
    var timer;
    //++++++++ 以下为可设置的参数 ++++++++++
    //初始状态 0 开启 1关闭
    var startstatus = 0;
    //次数
    var number = 0;
    //视频播放到100%时候切换下一个
    var percent = 100;
    //速率
    var speed = "1.5";
    //静音
    var vol = true;
    //答题?不答题将会移除答题框
    var answer = true;
    //++++++++ 可设置的参数结束 ++++++++++
    //查找节点
    var tips = $(".video-study");
    //创建新节点
    var option = $("<div>");
    //添加样式
    var args = {
       "color":"DarkOrange",
       "text-align":"center",
       "line-height":"90px",
       "font-size":"30px",
       "background-image": "url()",
       "background-repeat": "no-repeat",
       "background-size": "100%",
       "width": "90px",
       "height": "90px",
       "border-radius": "45px",
       "position":"fixed",
       "left":"60px",
       "top":"200px",
       "z-index":"999"
    };
    option.css(args);
    //添加点击事件
    option.attr("onClick","StartOrStop()");
    option.attr("id","rains");
    option.text("Rains");
    //插入节点到页面
    tips[0].parentNode.insertBefore(option[0],tips[0]);
    //函数
    function start(){
       if(number % 200 == 0){
           console.clear();
       }
       number += 1;
    
       //获取视频速率
       var speedSpan = $(".speedBox>span").text().replace("X ","");
       if(speedSpan != speed){
           switch(speed){
               case "1.0":
                   $("div[rate='1.0']").click();
                   break;
               case "1.25":
                   $("div[rate='1.25']").click();
                   break;
               case "1.5":
                   $("div[rate='1.5']").click();
                   break;
           }
       }
       //判断音量
       var volume = parseInt($(".volumeBox .passVolume")[0].style.height);
       if(volume > 0 && vol == true){
           $(".volumeIcon").click();
       }
       //获取进度条
       var pass = $(".passTime");
       //获取答题框状态
       var dialog = $(".el-dialog__wrapper.dialog-test")[0];
       if(dialog != undefined){
           if(answer == false){
               //移除答题框
               $(".v-modal").remove();
               $(".el-dialog__wrapper.dialog-test")[0].remove();
               $("body").removeClass("el-popup-parent--hidden");
           }else{
               //如果是单选题或者判断题选择一个答案否则移除答题框
               if($(".title-tit").text() == "【单选题】" || $(".title-tit").text() == "【判断题】"|| $(".title-tit").text() == "【多选题】"){
                   //选择选项的第一个用于获取正确答案
                   $(".topic-list .topic-option-item")[0].click();
                   //取消已经选择的
                   $(".topic-list .topic-option-item").each(function(){
                       if($(this).hasClass("active")){
                           $(this).click();
                       }
                   })
                   //选择答案
                   let answer = $(".answer span").text().split(",");
                   $.each(answer,function(index,value){
                       let option = value.charCodeAt() - 65;
                       $(".topic-list .topic-option-item")[option].click();
    
                   });
                   //延时关闭弹窗
                   setTimeout("$(\".el-dialog__wrapper.dialog-test .el-dialog__footer .dialog-footer .btn\")[0].click();",1000);
               }else{
                   //如果不是这3个选项移除答题框以后弹框将不会出现
                   $(".v-modal").remove();
                   $(".el-dialog__wrapper.dialog-test")[0].remove();
                   $("body").removeClass("el-popup-parent--hidden");
               }
           }
           let play  = $(".bigPlayButton.pointer")[0];
           //如果暂停继续播放
           if(play.style.display == "block"){
               play.click();
           }
       }else{
           let play  = $(".bigPlayButton.pointer")[0];
           //如果暂停继续播放
           if(play.style.display == "block"){
               play.click();
           }
       }
       //判断播放进度是否大于83%
       if(parseInt(pass[0].style.width) > percent){
           //切换下一个视频
           $("#nextBtn").click();
       }
       console.log("执行第"+ number + "次");
    }
    function StartOrStop(){
       var rains = $("#rains");
       //获取播放状态
       var play  = $(".bigPlayButton.pointer")[0];
       if (startstatus == 0){
           //开始脚本
           timer = setInterval(start, 3000);
           //已经暂停 点击开始按钮 block时视频播放暂停
           if(play.style.display == "block"){
               play.click();
           }
           startstatus = 1;
           rains.text("已开");
           rains.css("color","blue");
           console.log("刷课开始执行");
       }else if (startstatus == 1) {
           //停止脚本
           clearInterval(timer);
           //已经播放 暂停播放
           if(play.style.display == "none"){
               play.click();
           }
           startstatus = 0;
           rains.text("已关");
           rains.css("color","red");
           console.log("刷课已停止");
       }
    }
    //执行监听方法 默认填入代码后开启脚本
    StartOrStop();
    

    6.看到视频左上角出现“已开”,说明操作正确。

    7.此时就可以愉快的奔放咯。

2019年11月7日更新(已失效)

有同学反映最近脚本没法用了,这是由于智慧树进行了改版而脚本还没改版。然而我本人又懒得重新写一个新的脚本,所以想到了一个折中的办法 嘻嘻~

进入智慧树的在线学习页面,点击右上角返回旧版,再根据下面的流程做一遍即可继续学习奔放

《2020年10月6日更新-新版智慧树自动答题,跳过,调倍速(挂机)》

特性

  • 自动 1.5 倍速播放
  • 自动静音
  • 自动切换流畅画质(摸鱼时网络更加通畅)
  • 自动关闭网课中弹题
  • 自动切换下一节、下一章
  • 自动点击之前,会随机等待0~60秒,模拟人类操作延迟

使用方法

  1. 下载Chrome(理论上只要有控制台的浏览器皆可。)

  2. 打开智慧树视频播放地址

  3. 按下F12

  4. 找到Console《2020年10月6日更新-新版智慧树自动答题,跳过,调倍速(挂机)》

  5. 输入以下代码后回车

    (function () {
    const MAX_DELAY = 60 // 切课时的最大延迟,单位:秒
    
    const sleep = (time) => new Promise((resolve) => setTimeout(resolve, time))
    
    const start = async function () {
        console.log('智慧树助手已启动')
    
        while (true) {
            console.log('正在检查')
            const delay = Math.floor(Math.random() * MAX_DELAY * 1000) + 1000
    
            if (!/1\.5/.test($('.speedBox').attr('style'))) {
                console.log('提升到1.5倍速')
                $('.speedTab15').click()
            }
    
            if ($('.volumeBox').find('.passVolume').width() != 0) {
                console.log('静音')
                $('.volumeIcon').click()
            }
    
            if ($('.playButton').length > 0) {
                console.log('点击播放')
                $('.playButton').click()
            }
    
            if ($('.popbtn_cancel')[0]) {
                console.log('发现弹题,将在' + delay / 1000 + ' 秒后点击关闭')
                await sleep(delay / 2)
                const iframe = document.getElementById('tmDialog_iframe').contentWindow
                iframe.document.querySelector('.answerOption label').click()
                await sleep(delay / 2)
                $('.popbtn_cancel').click()
            }
    
            if ($('.current_play').find('.progressbar').width() == $('.current_play').find('.progressbar_box').width()) {
                console.log('本节完成,' + delay / 1000 + ' 秒后将切到下一课')
                await sleep(delay)
                $('.current_play').nextAll('.video')[0].click()
            }
    
            await sleep(1000)
        }
    }
    
    start()
    }())
    

    6.看到智慧树助手已启动,说明操作正确。

    7.此时就可以愉快的奔放咯。

注意

本文旨在讨论研究算法,请勿非法使用,使用者出现任何问题概不负责。本人保留法律追究的权利

点赞