xiguacwsedu

storehouse

当前为 2024-03-08 提交的版本,查看 最新版本

此脚本不应直接安装。它是供其他脚本使用的外部库,要使用该库请加入元指令 // @require https://update.cn-greasyfork.org/scripts/479975/1339495/xiguacwsedu.js

  1. // ==UserScript==
  2. // @name xiguacwsedu
  3. // @version 0.0.6
  4. // @description storehouse
  5. // @author Xiguayaodade
  6. // @license MIT
  7. // @match *://cws.edu-edu.com/*
  8. // @grant GM_info
  9. // @grant GM_getTab
  10. // @grant GM_saveTab
  11. // @grant GM_setValue
  12. // @grant GM_getValue
  13. // @grant GM_addStyle
  14. // @grant unsafeWindow
  15. // @grant GM_listValues
  16. // @grant GM_deleteValue
  17. // @grant GM_setClipboard
  18. // @grant GM_notification
  19. // @grant GM_xmlhttpRequest
  20. // @grant GM_getResourceText
  21. // @grant GM_registerMenuCommand
  22. // @grant GM_unregisterMenuCommand
  23. // @grant GM_addValueChangeListener
  24. // @grant GM_removeValueChangeListener
  25. // @namespace http://tampermonkey.net/
  26. // @homepage http://8.130.116.135/?member/login/
  27. // @source http://8.130.116.135/?member/login/
  28. // @icon https://picx.zhimg.com/v2-ce62b58ab2c7dc67d6cabc3508db5795_l.jpg?source=32738c0c
  29. // @connect icodef.com
  30. // @connect localhost
  31. // @require https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js
  32. // ==/UserScript==
  33.  
  34. (function() {
  35. 'use strict';
  36. /* globals jQuery, $, waitForKeyElements */
  37.  
  38.  
  39. var speedonoff = false;
  40. var speedIn = null;
  41. var ddds3 = null;
  42. var addMessage = null;
  43.  
  44. let btn1=GM_registerMenuCommand ("\u4f5c\u8005\uff1a\ud83c\udf49\u897f\u74dc\u8981\u5927\u7684\ud83c\udf49", function(){
  45. confirm("Hello,\u611f\u8c22\u4f7f\u7528\ud83c\udf49\u897f\u74dc\u5237\u8bfe\u52a9\u624b\ud83c\udf49\uff01\u591a\u591a\u53cd\u9988\u54e6");
  46. GM_unregisterMenuCommand(btn1);
  47. }, "");
  48. let btn2=GM_registerMenuCommand ("\u4ed8\u8d39\u5185\u5bb9", function(){
  49. alert("\u9650\u65f6\u514d\u8d39\uff0c\u5168\u529b\u5f00\u53d1\u4e2d...");
  50. }, "p");
  51.  
  52. //存储当前课程章节数量
  53. var chapterCount = 0;
  54. //存储当前课程章节索引
  55. var chapterId = 1;
  56. //存储课后练习小题数量
  57. var questionCount = 0;
  58. //存放播放器组件
  59. var elevideo;
  60. //课后练习选择框索引
  61. var rediosIndex = 0;
  62. //课程索引
  63. var courseId = GM_getValue("courseId");
  64. //课程总数
  65. var courseCount = null;
  66. //课程列表与问卷分离索引
  67. var courseIndex = null;
  68.  
  69. //----解决重复监听start----
  70. //视频开始的公共方法
  71. var vdplay = null;
  72. //视频正在播放的公共方法
  73. var vdplaying = null;
  74. //视频暂停的公共方法
  75. var vdpause = null;
  76. //视频结束的公共方法
  77. var vdended = null;
  78. //监听音量的公共方法
  79. var vdvolume = null;
  80. //----解决重复监听end----
  81.  
  82. //-----添加监听start------
  83. var addLisenner = function(){
  84.  
  85. //获取播放器组件
  86. elevideo = document.querySelector("video");
  87.  
  88. vdplay = function(){
  89. let tm = 5 * 60 * 1000;
  90. console.log("xigua:\u5f00\u59cb\u64ad\u653e");
  91. addMessage("xigua:\u5f00\u59cb\u64ad\u653e");
  92. speedIn = setInterval(function(){
  93. speedff();
  94. },tm);
  95. };
  96. vdplaying = function(){
  97. console.log("xigua:\u6b63\u5728\u64ad\u653e");
  98. addMessage("xigua:\u6b63\u5728\u64ad\u653e");
  99. };
  100. vdpause = function(){
  101. clearInterval(speedIn);
  102. console.log("xigua:\u6682\u505c\u64ad\u653e");
  103. addMessage("xigua:\u6682\u505c\u64ad\u653e");
  104. setTimeout(function(){
  105. if(document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByTagName("div")[1].className == 'ivu-modal-wrap'){
  106. console.log("xigua:课堂练习");
  107. addMessage("xigua:课堂练习");
  108. answer();
  109. }else if(document.getElementsByClassName("alert-modal v-transfer-dom")[1].getElementsByTagName("div")[1].className == 'ivu-modal-wrap'){
  110. console.log("xigua:提示");
  111. addMessage("xigua:提示");
  112. //document.getElementsByClassName("alert-modal v-transfer-dom")[1].getElementsByTagName("button")[0].click();
  113. //setTimeout(function(){
  114. //elevideo.play();
  115. //},1000);
  116. }else{
  117. console.log("xigua:手动暂停,无需操作");
  118. addMessage("xigua:手动暂停,无需操作");
  119. try{
  120. console.log("xigua:调用补丁函数");
  121. addMessage("xigua:调用补丁函数");
  122. document.getElementsByClassName("alert-modal v-transfer-dom")[1].getElementsByTagName("button")[0].click();
  123. setTimeout(function(){
  124. elevideo.play();
  125. },1000);
  126. }catch(e){
  127. console.log("xigua:补丁异常");
  128. addMessage("xigua:补丁异常");
  129. }
  130. }
  131. },1500);
  132. };
  133. vdended = function(){
  134. clearInterval(speedIn);
  135. console.log("xigua:结束播放");
  136. addMessage("xigua:结束播放");
  137. };
  138. vdvolume = function(){
  139. if(elevideo.volume < 1 && elevideo.volume > 0){
  140. let vlum = elevideo.volume.toString();
  141. console.log("xigua:当前音量("+vlum.substring(2,4)+"%)");
  142. addMessage("xigua:当前音量("+vlum.substring(2,4)+"%)");
  143. }else if(elevideo.volume == 0){
  144. console.log("xigua:当前音量(0%)");
  145. addMessage("xigua:当前音量(0%)");
  146. }else{
  147. console.log("xigua:当前音量(100%)");
  148. addMessage("xigua:当前音量(100%)");
  149. }
  150. }
  151.  
  152. elevideo.addEventListener('play',vdplay);
  153. elevideo.addEventListener('playing',vdplaying);
  154. elevideo.addEventListener('pause',vdpause);
  155. elevideo.addEventListener('ended',vdended);
  156. elevideo.addEventListener('volumechange',vdvolume);
  157.  
  158. setTimeout(function(){
  159. //elevideo.play();
  160. elevideo.volume = 0;
  161. },3000);
  162. }
  163. //-----添加监听end------
  164. function lisenLoop(){
  165. if(document.getElementsByClassName("alert-modal v-transfer-dom")[1].getElementsByTagName("div")[1].className == 'ivu-modal-wrap'){
  166. console.log("xigua:提示lisenLoop");
  167. addMessage("xigua:提示lisenLoop");
  168. document.getElementsByClassName("alert-modal v-transfer-dom")[1].getElementsByTagName("button")[0].click();
  169. setTimeout(function(){
  170. elevideo.play();
  171. },1000);
  172. }
  173. setTimeout(function(){
  174. lisenLoop();
  175. },1500);
  176. }
  177.  
  178. //-----移除监听start---
  179. var removeLisenner = function(){
  180. if(vdplay != null){
  181. elevideo.removeEventListener("play", vdplay);
  182. }
  183. if(vdplaying != null){
  184. elevideo.removeEventListener("playing", vdplaying);
  185. }
  186. if(vdpause != null){
  187. elevideo.removeEventListener("pause", vdpause);
  188. }
  189. if(vdended != null){
  190. elevideo.removeEventListener("ended", vdended);
  191. }
  192. if(vdended != null){
  193. elevideo.removeEventListener("ended", vdended);
  194. }
  195. if(vdvolume != null){
  196. elevideo.removeEventListener("volumechange",vdvolume);
  197. }
  198. }
  199. //-----移除监听end---
  200.  
  201. //-----倍速start-----
  202. var speedff = function(){
  203. if(speedonoff){
  204. let vdText = document.getElementsByClassName("video-progress clearfix not-start")[0].getElementsByClassName("text")[0].getElementsByTagName("span")[1].innerText;
  205. if(parseFloat(vdText) <= 70){
  206. setTimeout(function(){
  207. document.querySelector("video").playbackRate=16;
  208. console.log("X16");
  209. setTimeout(function(){
  210. document.querySelector("video").playbackRate=1;
  211. console.log("X1");
  212. },800);
  213. },1000);
  214. }
  215. }else{
  216. addMessage("断点倍速状态:关闭");
  217. }
  218. }
  219. //-----倍速end-----
  220.  
  221. //------检索未完成章节start------
  222. var search = function(){
  223. if(chapterId <= chapterCount){
  224. let learningPace = document.getElementsByClassName("row flex")[chapterId].getElementsByTagName("span")[3].innerText.substring(0,3);
  225. let chapterName = document.getElementsByClassName("row flex")[chapterId].getElementsByTagName("span")[1].innerText;
  226. switch(learningPace)
  227. {
  228. case'学习中':
  229. addMessage(chapterName+"|未完成,开始学习");
  230. console.log(chapterName+"|未完成,开始学习");
  231. setTimeout(function(){
  232. document.getElementsByClassName("row flex")[chapterId].getElementsByTagName("span")[4].getElementsByTagName("a")[0].click();
  233. },2000);
  234. break;
  235. case'未学习':
  236. addMessage(chapterName+"|未完成,开始学习");
  237. console.log(chapterName+"|未完成,开始学习");
  238. setTimeout(function(){
  239. document.getElementsByClassName("row flex")[chapterId].getElementsByTagName("span")[4].getElementsByTagName("a")[0].click();
  240. },2000);
  241. break;
  242. case'未考试':
  243. // addMessage(chapterName+"|未完成");
  244. // console.log(chapterName+"|未完成");
  245. addMessage(chapterName+"|暂不考试,学习下一科");
  246. console.log(chapterName+"|暂不考试,学习下一科");
  247. setTimeout(function(){
  248. //document.getElementsByClassName("row flex")[chapterId].getElementsByTagName("span")[4].getElementsByTagName("a")[0].click();
  249. document.getElementsByClassName("wrap flex-column")[0].getElementsByClassName("address")[0].getElementsByClassName("btn")[0].click();
  250. },2000);
  251. break;
  252. case'未通过':
  253. // addMessage(chapterName+"|未通过");
  254. // console.log(chapterName+"|未通过");
  255. addMessage(chapterName+"|暂不考试,学习下一科");
  256. console.log(chapterName+"|暂不考试,学习下一科");
  257. setTimeout(function(){
  258. //document.getElementsByClassName("row flex")[chapterId].getElementsByTagName("span")[4].getElementsByTagName("a")[0].click();
  259. document.getElementsByClassName("wrap flex-column")[0].getElementsByClassName("address")[0].getElementsByClassName("btn")[0].click();
  260. },2000);
  261. break;
  262. case'未操作':
  263. // addMessage(chapterName+"|须填写");
  264. // console.log(chapterName+"|须填写");
  265. addMessage(chapterName+"|暂不填写问卷,学习下一科");
  266. console.log(chapterName+"|暂不填写问卷,学习下一科");
  267. setTimeout(function(){
  268. // document.getElementsByClassName("row flex")[chapterId].getElementsByTagName("span")[4].getElementsByTagName("a")[0].click();
  269. document.getElementsByClassName("wrap flex-column")[0].getElementsByClassName("address")[0].getElementsByClassName("btn")[0].click();
  270. },2000);
  271. break;
  272. default:
  273. addMessage(chapterName+"|已完成");
  274. console.log(chapterName+"|已完成");
  275. chapterId++;
  276. search();
  277. }
  278. }else{
  279. addMessage("本课程已完成,退出!");
  280. console.log("本课程已完成,退出!");
  281. }
  282.  
  283. }
  284. //------检索未完成章节end------
  285.  
  286. //------单选题答题方法start------
  287. var onlyRe = function(){
  288. setTimeout(function(){
  289. let positiveSolution = document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("positiveSolution")[0].innerText.substring(4);
  290. let array = positiveSolution.split(' ');
  291. let str2 = array.join('');
  292. console.log("xigua:答案:"+str2);
  293. setTimeout(function(){
  294. switch(str2[0])
  295. {
  296. case 'A':
  297. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("question-options")[0].getElementsByClassName("question-option")[0].getElementsByClassName("mark")[0].click();
  298. console.log("点击A");
  299. break;
  300. case 'B':
  301. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("question-options")[0].getElementsByClassName("question-option")[1].getElementsByClassName("mark")[0].click();
  302. console.log("点击B");
  303. break;
  304. case 'C':
  305. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("question-options")[0].getElementsByClassName("question-option")[2].getElementsByClassName("mark")[0].click();
  306. break;
  307. case 'D':
  308. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("question-options")[0].getElementsByClassName("question-option")[3].getElementsByClassName("mark")[0].click();
  309. console.log("点击D");
  310. break;
  311. }
  312. },1500);
  313. setTimeout(function(){
  314. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("ivu-btn ivu-btn-primary")[0].click();
  315. if(document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByTagName("div")[1].className == 'ivu-modal-wrap'){
  316. console.log("xigua:回答完毕");
  317. addMessage("xigua:回答完毕");
  318. setTimeout(function(){
  319. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("ivu-btn ivu-btn-primary")[0].click();
  320. },1000);
  321. }else{
  322. console.log("xigua:回答正确");
  323. addMessage("xigua:回答正确");
  324. }
  325. },3000);
  326. },500);
  327. }
  328. //------单选题答题方法end------
  329.  
  330. //------多选题答题方法start------
  331. var mostRe = function(){
  332. setTimeout(function(){
  333. let positiveSolution = document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("positiveSolution")[0].innerText.substring(4);
  334. let array = positiveSolution.split(' ');
  335. let str2 = array.join('');
  336. console.log("xigua:答案:"+str2);
  337. setTimeout(function(){
  338. for(var j=0;j<str2.length;j++){
  339. switch(str2[j])
  340. {
  341. case 'A':
  342. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("question-options")[0].getElementsByClassName("question-option")[0].getElementsByClassName("mark")[0].click();
  343. console.log("点击A");
  344. break;
  345. case 'B':
  346. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("question-options")[0].getElementsByClassName("question-option")[1].getElementsByClassName("mark")[0].click();
  347. console.log("点击B");
  348. break;
  349. case 'C':
  350. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("question-options")[0].getElementsByClassName("question-option")[2].getElementsByClassName("mark")[0].click();
  351. break;
  352. case 'D':
  353. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("question-options")[0].getElementsByClassName("question-option")[3].getElementsByClassName("mark")[0].click();
  354. console.log("点击D");
  355. break;
  356. case 'E':
  357. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("question-options")[0].getElementsByClassName("question-option")[4].getElementsByClassName("mark")[0].click();
  358. console.log("点击E");
  359. break;
  360. case 'F':
  361. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("question-options")[0].getElementsByClassName("question-option")[5].getElementsByClassName("mark")[0].click();
  362. console.log("点击F");
  363. break;
  364. case 'G':
  365. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("question-options")[0].getElementsByClassName("question-option")[6].getElementsByClassName("mark")[0].click();
  366. console.log("点击G");
  367. break;
  368. default:
  369. console.log("当前多选题选项过多,系统需更新!");
  370. }
  371. }
  372. },1500);
  373. setTimeout(function(){
  374. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("ivu-btn ivu-btn-primary")[0].click();
  375. if(document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByTagName("div")[1].className == 'ivu-modal-wrap'){
  376. console.log("xigua:回答完毕");
  377. addMessage("xigua:回答完毕");
  378. setTimeout(function(){
  379. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("ivu-btn ivu-btn-primary")[0].click();
  380. },1000);
  381. }else{
  382. console.log("xigua:回答正确");
  383. addMessage("xigua:回答正确");
  384. }
  385. },3000);
  386. },500);
  387. }
  388. //------多选题答题方法end------
  389.  
  390. //------判断题答题方法start------
  391. var judgRe = function(){
  392. setTimeout(function(){
  393. let positiveSolution = document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("positiveSolution")[0].innerText.substring(4);
  394. let array = positiveSolution.split(' ');
  395. let str2 = array.join('');
  396. console.log("xigua:答案:"+str2);
  397. setTimeout(function(){
  398. switch(str2[0])
  399. {
  400. case 'A':
  401. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("question-options")[0].getElementsByClassName("question-option")[0].getElementsByClassName("mark")[0].click();
  402. console.log("点击A");
  403. break;
  404. case 'B':
  405. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("question-options")[0].getElementsByClassName("question-option")[1].getElementsByClassName("mark")[0].click();
  406. console.log("点击B");
  407. break;
  408. }
  409. },1500);
  410. setTimeout(function(){
  411. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("ivu-btn ivu-btn-primary")[0].click();
  412. if(document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByTagName("div")[1].className == 'ivu-modal-wrap'){
  413. console.log("xigua:回答完毕");
  414. addMessage("xigua:回答完毕");
  415. setTimeout(function(){
  416. document.getElementsByClassName("preview-modal v-transfer-dom")[0].getElementsByClassName("ivu-btn ivu-btn-primary")[0].click();
  417. },1000);
  418. }else{
  419. console.log("xigua:回答正确");
  420. addMessage("xigua:回答正确");
  421. }
  422. },3000);
  423. },1500);
  424. }
  425. //------判断题答题方法end------
  426.  
  427. //------课堂练习start------
  428. var answer = function(){
  429. let tName = document.getElementsByClassName("preview-modal v-transfer-dom")[0].querySelector(".question-stem-content-preview").innerText;
  430. if(tName === '单选题'){
  431. console.log("xigua:单选题,开始作答");
  432. addMessage("xigua:单选题,开始作答");
  433. onlyRe();
  434. }
  435. if(tName === '多选题'){
  436. console.log("xigua:多选题,开始作答");
  437. addMessage("xigua:多选题,开始作答");
  438. mostRe();
  439. }
  440. if(tName === '判断题'){
  441. console.log("xigua:判断题,开始作答");
  442. addMessage("xigua:判断题,开始作答");
  443. judgRe();
  444. }
  445. }
  446. //------课堂练习end------
  447.  
  448. //------考试start------
  449. var exam = function(){
  450. //获取考题数量
  451. questionCount = document.getElementsByClassName("shijuanlist flex-column")[0].getElementsByClassName("sjitem flex-column").length;
  452. addMessage("开始考试,共"+questionCount+"题");
  453. console.log("开始考试,共"+questionCount+"题");
  454. for(let i=0; i<questionCount; i++){
  455. var questionType = document.getElementsByClassName("shijuanlist flex-column")[0].getElementsByClassName("sjitem flex-column")[i].getElementsByClassName("timu flex")[0].getElementsByClassName("sp")[0].innerText.substring(9,11);
  456. if(questionType === '单选'){
  457. addMessage("第"+(i+1)+"题|单选题");
  458. console.log("第"+(i+1)+"题|单选题");
  459. let randomInteger = Math.floor(Math.random() * 4);
  460. addMessage((i+1)+"随机数="+randomInteger);
  461. console.log((i+1)+"随机数="+randomInteger);
  462. document.getElementsByClassName("shijuanlist flex-column")[0].getElementsByClassName("sjitem flex-column")[i].getElementsByClassName("item flex")[randomInteger].click();
  463. }
  464. if(questionType === '多选'){
  465. addMessage("第"+(i+1)+"题|多选题");
  466. console.log("第"+(i+1)+"题|多选题");
  467. let choicesCount = document.getElementsByClassName("shijuanlist flex-column")[0].getElementsByClassName("sjitem flex-column")[i].getElementsByClassName("item flex").length;
  468. let randomIntegerOne = Math.floor(Math.random() * 2);
  469. let randomIntegerTow = Math.floor(Math.random() * 2)+2;
  470. if(choicesCount < 3){
  471. addMessage((i+1)+"随机数="+randomIntegerOne);
  472. console.log((i+1)+"随机数="+randomIntegerOne);
  473. document.getElementsByClassName("shijuanlist flex-column")[0].getElementsByClassName("sjitem flex-column")[i].getElementsByClassName("item flex")[randomIntegerOne].click();
  474. }else{
  475. addMessage((i+1)+"随机数="+randomIntegerOne,randomIntegerTow);
  476. console.log((i+1)+"随机数="+randomIntegerOne,randomIntegerTow);
  477. document.getElementsByClassName("shijuanlist flex-column")[0].getElementsByClassName("sjitem flex-column")[i].getElementsByClassName("item flex")[randomIntegerOne].click();
  478. document.getElementsByClassName("shijuanlist flex-column")[0].getElementsByClassName("sjitem flex-column")[i].getElementsByClassName("item flex")[randomIntegerTow].click();
  479. }
  480. }
  481. if(questionType === '简答'){
  482. addMessage("第"+(i+1)+"题|简答题,简答题模板需更新!");
  483. console.log("第"+(i+1)+"题|简答题,简答题模板需更新!");
  484. }
  485. }
  486. //提交
  487. setTimeout(function(){
  488. document.getElementsByClassName("btns flex")[0].getElementsByClassName("blue-btn")[1].click();
  489. setTimeout(function(){
  490. if(document.getElementsByClassName("tanchuang")[0] != null){
  491. let backBtn = document.getElementsByClassName("tanchuang")[0].getElementsByClassName("btn")[0].innerText;
  492. if(backBtn === '返回课程'){
  493. addMessage("考试通过");
  494. console.log("考试通过");
  495. document.getElementsByClassName("tanchuang")[0].getElementsByClassName("btn")[0].click();
  496. }
  497. if(backBtn === '重答'){
  498. addMessage("考试未通过");
  499. console.log("考试未通过");
  500. document.getElementsByClassName("tanchuang")[0].getElementsByClassName("btn")[0].click();
  501. setTimeout(function(){
  502. exam();
  503. },1000);
  504. }
  505. }else{
  506. addMessage("无弹窗");
  507. console.log("无弹窗");
  508. }
  509. },1500);
  510. },1500);
  511. }
  512. //------考试end------
  513.  
  514. const panel = function(){
  515. var container = $('<div id="gm-interface"></div>');
  516. var titleBar = $('<div id="gm-title-bar">\ud83c\udf49\u897f\u74dc\u7f51\u8bfe\u52a9\u624b\ud83c\udf49</div>');
  517. var minimizeButton = $('<div title="\u6536\u8d77" style="display:black"><svg id="gm-minimize-button" class="bi bi-dash-square" viewBox="0 0 16 16" fill="currentColor" xmlns="http://www.w3.org/2000/svg"><path fill-rule="evenodd" d="M14 1H2a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1zM2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z"/><path fill-rule="evenodd" d="M3.5 8a.5.5 0 0 1 .5-.5h8a.5.5 0 0 1 0 1H4a.5.5 0 0 1-.5-.5z"/></svg></div>');
  518. var maxButton = $('<div title="\u5c55\u5f00" style="display:none"><svg id="gm-minimize-button" class="bi bi-plus-square" viewBox="0 0 16 16" fill="currentColor" xmlns="http://www.w3.org/2000/svg"><path fill-rule="evenodd" d="M8 3.5a.5.5 0 0 1 .5.5v4a.5.5 0 0 1-.5.5H4a.5.5 0 0 1 0-1h3.5V4a.5.5 0 0 1 .5-.5z"/><path fill-rule="evenodd" d="M7.5 8a.5.5 0 0 1 .5-.5h4a.5.5 0 0 1 0 1H8.5V12a.5.5 0 0 1-1 0V8z"/><path fill-rule="evenodd" d="M14 1H2a1 1 0 0 0-1 1v12a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V2a1 1 0 0 0-1-1zM2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2z"/></svg></div>');
  519. var content = $('<div id="gm-content"></div>');
  520. var tips = $('<div class="tip" style="display:none;">\u957f\u6309\u62d6\u62fd</div>');
  521. var scrollText = $('<marquee>').text('\u4e7e\u5764\u672a\u5b9a\uff0c\u4f60\u6211\u7686\u662f\u9ed1\u9a6c----\u4f5c\u8005\uff1a\u897f\u74dc\u8981\u5927\u7684\uff08\u611f\u8c22\u652f\u6301\uff01\uff09').css({
  522. 'position': 'absolute',
  523. 'top': '15%',
  524. 'left': '50%',
  525. 'transform': 'translate(-50%, -50%)',
  526. 'width': '90%',
  527. 'height': '25px',
  528. 'font-size': '16px',
  529. 'line-height': '1.5',
  530. 'white-space': 'nowrap'
  531. }).appendTo(content);
  532. //var ddds1 = $('<div style="position: absolute;top: 20%;width:90%;height:10%;padding: 3px;background: #ffedf0;border-radius: 5px;">\u70b9\u51fb\u542f\u52a8\uff1a<button id="startxg" style="position: absolute;width:48px;right: 10px;background-color: #ffe5e5;border-radius: 4px;border-color: #ffc0c0;color: grey;">\u542f\u52a8</button></div>');
  533. //var ddds5 = $('<div style="position: absolute;top: 35%;width:90%;height:10%;padding: 3px;background: #ffedf0;border-radius: 5px;">\u70b9\u51fb\u542f\u52a8\uff1a<button id="stopxg" style="position: absolute;width:48px;right: 10px;background-color: #ffe5e5;border-radius: 4px;border-color: #ffc0c0;color: grey;">暂停</button></div>');
  534. var ddds2 = $('<div style="position: absolute;top: 73%;width:94%;height:10%;padding: 3px;background: #ffedf0;border-radius: 5px;">\u65ad\u70b9\u500d\u901f\uff1a<button id="switchButton" style="position: absolute;width:88px;right: 180px;background-color: #ffe5e5;border-radius: 4px;border-color: #ffc0c0;color: grey;">当前:关闭</button><button id="speedxgone" style="position: absolute;width:58px;right: 80px;background-color: #ffe5e5;border-radius: 4px;border-color: #ffc0c0;color: grey;">清空缓存</button></div>');
  535. ddds3 = $('<div id="message-container" style="position: absolute;display: grid;align-content: center;justify-content: center;top: 20%;width:94%;height:52%;max-height:62%;overflow-y:auto;padding: 3px;background: #ffffff;border-radius: 5px;">-------------------------------------------------------------------------------</div>');
  536. var ddds4 = $('<div style="position: absolute;top: 85%;width:94%;height:10%;padding: 3px;background: #ffedf0;border-radius: 5px;"><a href="http://8.130.116.135/?member/login/" style="position: absolute;right: 10px;text-decoration: none;color: pink;">\u003e\u003e\u003e\u8054\u7cfb\u003a\u0031\u0039\u0030\u0038\u0032\u0034\u0035\u0033\u0030\u0032\u0040\u0071\u0071\u002e\u0063\u006f\u006d</a></div>');
  537.  
  538. container.append(titleBar);
  539. //content.append(ddds1);
  540. //content.append(ddds5);
  541. content.append(ddds2);
  542. content.append(ddds3);
  543. content.append(ddds4);
  544. container.append(content);
  545. container.append(maxButton);
  546. container.append(minimizeButton);
  547. $('body').append(container);
  548. $('body').append(tips);
  549.  
  550. GM_addStyle(`
  551. #gm-interface {
  552. position: fixed;
  553. top: 50%;
  554. left: 50%;
  555. border-radius: 5px;
  556. background-color: white;
  557. z-index: 9999;
  558. }
  559.  
  560. #gm-title-bar {
  561. padding: 5px;
  562. background-color: #ffc0c0;
  563. border: 1px solid black;
  564. border-radius: 5px;
  565. cursor: grab;
  566. }
  567.  
  568. #gm-minimize-button {
  569. position: absolute;
  570. top: 2px;
  571. right: 2px;
  572. width: 30px;
  573. height: 30px;
  574. border-radius: 5px;
  575. padding: 0;
  576. font-weight: bold;
  577. background-color: #ffc0c0;
  578. cursor: pointer;
  579. }
  580.  
  581. #gm-content {
  582. padding: 10px;
  583. border: 1px solid black;
  584. border-radius: 2px 2px 5px 5px;
  585. background-color: #ffe5e5;
  586. width: 400px;
  587. height: 300px;
  588. }
  589. .tip{
  590. font-family: "黑体";
  591. color: black;
  592. -webkit-transform: scale(0.8);
  593. position:absolute;
  594. padding: 6px 5px;
  595. background-color:#ffe8f0;
  596. border-radius: 4px;
  597. z-index: 9999;
  598. }
  599. `);
  600.  
  601. titleBar.on('mousemove',function(e){
  602. tips.attr("style", "display:black;");
  603. var top = e.pageY+5;
  604. var left = e.pageX+5;
  605. tips.css({
  606. 'top' : top + 'px',
  607. 'left': left+ 'px'
  608. });
  609. });
  610.  
  611. titleBar.on('mouseout',function(){
  612. tips.hide();
  613. });
  614.  
  615. titleBar.on('mousedown', function(e) {
  616. var startX = e.pageX - container.offset().left + window.scrollX;
  617. var startY = e.pageY - container.offset().top + window.scrollY;
  618.  
  619. $(document).on('mousemove', function(e) {
  620. e.preventDefault();
  621. var newX = e.pageX - startX;
  622. var newY = e.pageY - startY;
  623. container.css({ left: newX, top: newY });
  624. });
  625.  
  626. $(document).on('mouseup', function() {
  627. $(document).off('mousemove');
  628. $(document).off('mouseup');
  629. });
  630. });
  631.  
  632.  
  633. minimizeButton.on('click', function() {
  634. minimizeButton.attr("style", "display:none;");
  635. maxButton.attr("style", "display:black;");
  636. content.slideToggle(0);
  637. container.css({ width: 200 });
  638. });
  639.  
  640. maxButton.on('click', function() {
  641. minimizeButton.attr("style", "display:black;");
  642. maxButton.attr("style", "display:none;");
  643. content.slideToggle(0);
  644. container.css({ width: 400 });
  645. });
  646.  
  647. // $("#speedxgsex").on('click',function(){
  648. // document.querySelector("video").playbackRate=16;
  649. // addMessage("\u500d\u901f\uff1a\u0058\u0031\u0036");
  650. // });
  651.  
  652. $("#speedxgone").on('click',function(){
  653. GM_deleteValue("courseId");
  654. ddds3.children().remove();
  655. addMessage("已清空缓存");
  656. });
  657.  
  658. $("#switchButton").on('click',function(){
  659. if (speedonoff) {
  660. speedonoff = false;
  661. addMessage("\u500d\u901f\uff1a\u5173\u95ed");
  662. $("#switchButton").text("当前:关闭");
  663. } else {
  664. speedonoff = true;
  665. addMessage("\u500d\u901f\uff1a\u5f00\u542f");
  666. $("#switchButton").text("当前:开启");
  667. }
  668. });
  669.  
  670. // 监听鼠标滚轮事件,实现消息框滚动
  671. ddds3.on('mousewheel', function(event) {
  672. event.preventDefault();
  673. var scrollTop = ddds3.scrollTop();
  674. ddds3.scrollTop(scrollTop + event.originalEvent.deltaY);
  675. });
  676.  
  677. // 添加新消息
  678. addMessage = function(message){
  679. // 检查消息数量,移除最早的一条消息
  680. if (ddds3.children().length >= 288) {
  681. ddds3.children().first().remove();
  682. }
  683. // 创建消息元素并添加到消息框容器
  684. var messageElement = $('<div class="message"></div>').text(message).css({
  685. 'margin-bottom': '10px'
  686. }).appendTo(ddds3);
  687. }
  688.  
  689. }
  690.  
  691. panel();
  692. addMessage("正在启动,请稍后...");
  693.  
  694. //------等待网页加载完成start-----
  695. var wait = setInterval(function (){
  696. let nowUrl = window.location.href;
  697. if(nowUrl.substring(0,35) === 'https://cws.edu-edu.com/page/client'){
  698. addMessage("播放页");
  699. console.log("播放页");
  700. // removeLisenner();
  701. // addLisenner();
  702. if(document.getElementsByClassName("ivu-switch ivu-switch-default")[0].getElementsByClassName("ivu-switch-inner")[0].innerText == '关'){
  703. document.getElementsByClassName("ivu-switch ivu-switch-default")[0].click();
  704. }
  705. lisenLoop();
  706. }else {
  707. addMessage("请进入要学习的课程章节页");
  708. console.log("请进入要学习的课程章节页");
  709. }
  710. clearInterval(wait);
  711. }, 5000);
  712. //------等待网页加载完成end-----
  713.  
  714. setInterval(function (){
  715. removeLisenner();
  716. addLisenner();
  717. }, 500);
  718.  
  719. })();