智慧树网课辅助脚本,享受一口气看二十课的畅快体验。
2020年10月6日更新
由于新版智慧树没有了“返回旧版”的按钮,于是只好自己重新写一个咯。(哼)
特性
- 自动 1.5 倍速播放
- 自动静音
- 自动回答网课中弹题
- 自动切换下一节、下一章
- 自动点击之前,会随机等待0~60秒,模拟人类操作延迟
- 视频左上角显示是否开启脚本
使用方法
- 下载Chrome(理论上只要有控制台的浏览器皆可。)
-
打开智慧树视频播放地址
-
按下F12
-
找到Console
-
输入以下代码后回车
/** * 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日更新(已失效)
有同学反映最近脚本没法用了,这是由于智慧树进行了改版而脚本还没改版。然而我本人又懒得重新写一个新的脚本,所以想到了一个折中的办法 嘻嘻~
进入智慧树的在线学习页面,点击右上角返回旧版,再根据下面的流程做一遍即可继续学习奔放。
特性
- 自动 1.5 倍速播放
- 自动静音
- 自动切换流畅画质(摸鱼时网络更加通畅)
- 自动关闭网课中弹题
- 自动切换下一节、下一章
- 自动点击之前,会随机等待0~60秒,模拟人类操作延迟
使用方法
- 下载Chrome(理论上只要有控制台的浏览器皆可。)
-
打开智慧树视频播放地址
-
按下F12
-
找到Console
-
输入以下代码后回车
(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.此时就可以愉快的奔放咯。
注意
本文旨在讨论研究算法,请勿非法使用,使用者出现任何问题概不负责。本人保留法律追究的权利。