// ==UserScript== // @name AcWing Better! // @version 3.15 // @description AcWing界面美化,功能增强,视频时间点标记跳转,代码markdown一键复制 // @author 北极小狐 // @match https://www.acwing.com/* // @icon https://www.google.com/s2/favicons?sz=64&domain=acwing.com // @grant GM_xmlhttpRequest // @grant GM_info // @connect greasyfork.org // @run-at document-start // @require https://cdn.bootcdn.net/ajax/libs/turndown/7.1.1/turndown.min.js // @license MIT // @namespace https://greasyfork.org/users/747162 // @downloadURL none // ==/UserScript== // 样式 function loadCssCode(code){ var style = document.createElement('style'); style.type = 'text/css'; style.rel = 'stylesheet'; style.appendChild(document.createTextNode(code)); var head = document.getElementsByTagName('head')[0]; head.appendChild(style); } loadCssCode(` /* 宽度自适应 */ .container { width: auto !important; margin: 0px 10vh; } /* 去除没用的图标 */ .file-explorer-main-field-item.file-explorer-main-field-item-desktop { width: 0px; height: 0px; overflow: hidden; } /* 背景bing壁纸 */ #acwing_body { background: white url(https://bingw.jasonzeng.dev) fixed !important; } /* 修复评论区某些同学发超长单词会导致整个页面显示x-scrollbar的**行为 */ .comment-conent { overflow-x: auto; } /* 其他 */ .fs-gui-taskbar { height: 3.5vh !important; background-color: #dde1e5 !important; } .fs-gui-taskbar-widgets-apps-item > img { height: 2.2vh !important; width: 2.2vh !important; margin: 0.5vh 0.5vh 0.5vh 0.5vh !important; } .fs-gui-taskbar-widgets-clock{ width: 0px !important; height: 0px !important; overflow: hidden !important; } .fs-gui-taskbar-widgets-apps-item { margin-right: 2vh !important; } #fs-gui-taskbar-search-field { font-size: 1.3vh !important; } .fs-gui-taskbar-search-icon { font-size: 1.6vh !important; top: 0.95vh !important; left: 4.3vh !important; } footer#acwing_footer .copyright { color: #fff; } footer#acwing_footer .copyright a, .links a, footer#acwing_footer .container { color: #fff; } .fs-gui-taskbar-begin { height: 3vh !important; width: 3vh !important; margin: 0.2vh !important; border-radius: 60%; background-color: #fffefe80 !important; } button.fs-gui-taskbar-begin.pull-left.btn.btn-default img { width: 83% !important; } #fs-gui-taskbar-search-field { height: 90% !important; margin: 0.15vh; border-radius: 100px; border-width: 0.2vh; border-style: solid; border-color: #c7d2dd; } #fs-gui-taskbar-search-field:focus-visible { border-width: 0.2vh; border-style: solid; border-color: #8bb2d9; outline: -webkit-focus-ring-color auto 0px; } /* 复制按钮 */ pre.hljs { display: flex; justify-content: space-between; } span.copy-button { cursor: pointer; background-color: #e6e6e6; color: #727378; height: 2vh; font-size: 1.3vh; border-radius: 0.3rem; padding: 1px 5px; margin: 5px; box-shadow: 0 0 1px #0000004d; } span.copy-button.copied { background-color: #07e65196; color: #104f2b; } /* html2md */ .html2md-panel { display: flex; justify-content: flex-end; } button.html2mdButton { height: 3vh; width: 3vh; } button.html2mdButton { cursor: pointer; background-color: #e6e6e6; color: #727378; height: 3vh; width: auto; font-size: 1.3vh; border-radius: 0.3rem; border: none; padding: 1px 5px; margin: 5px; box-shadow: 0 0 1px #0000004d; } button.html2mdButton.copied { background-color: #07e65196; color: #104f2b; } button.html2mdButton.html2md-view.mdViewed { background-color: #ff980057; color: #5a3a0c; } /* 打卡框 */ .ui.bottom.attached.tab.segment.active { padding: 0px; } /* 视频bar */ .embed-responsive { height: max-content; padding-bottom: 0px; } .player_bar { margin: 2px; display: flex; justify-content: space-between; } .player_bar_go { cursor: pointer; width: 50px; color: #999; height: auto; font-size: 1.3vh; border-radius: 0.3rem; padding: 1px 5px; margin: 5px; border: none; background: linear-gradient(-225deg,#d5dbe4,#f8f8f8); box-shadow: inset 0 -2px 0 0 #cdcde6,inset 0 0 1px 1px #fff,0 1px 2px 1px rgba(30,35,90,.4); display: flex; justify-content: center; align-items: center; } button#player_bar_list_add_new_item_btn { height: 30px; width: 50px; background-color: #00aeec; color: #ffffff; font-size: 1.3vh; border-radius: 0rem 0.5rem 0.5rem 0rem; padding: 1px 5px; margin: 5px 5px 5px 0px; border: none; box-shadow: 0 0 1px #0000004d; } div#player_bar_list { display: grid; width: 100%; border-radius: 0.3rem 0rem 0rem 0.3rem; margin: 5px 0px 5px 0px; border: 1px dashed #00aeeccc; } div#player_bar_list input[type="radio"] { appearance: none; width: 0; height: 0; overflow: hidden; } div#player_bar_list input[type=radio]:focus { outline: 0px; } label.player_bar_ul_li_text { max-width: 100%; height: 90px; overflow-x: auto; font-weight: 400; margin: 0px 4px; box-shadow: 0 0 1px #0000004d; padding: 3px; } ul#player_bar_ul li button { background-color: #e6e6e6; color: #727378; height: 23px; font-size: 14px; border-radius: 0.3rem; padding: 1px 5px; margin: 5px; border: none; box-shadow: 0 0 1px #0000004d; } ul#player_bar_ul { list-style-type: none; padding-inline-start: 0px; display: flex; overflow-x: auto; max-width: 100%; margin: 0px; } ul#player_bar_ul li { height: 100px; width: 8vh; display: grid; overflow: hidden; margin: 0.4vh 0.2vh; min-width: 100px; } label.player_bar_ul_li_text:hover { background-color: #eae4dc24; } input[type="radio"]:checked + .player_bar_ul_li_text { background: linear-gradient(-225deg,#ede0bc,#f8f8f8); box-shadow: inset 0 0px 0 0 #cdcde6, inset 0 0px 1px 1px #fff, 0 0px 2px 1px rgb(30 35 90 / 32%); } ul#player_bar_ul::-webkit-scrollbar { width: 5px; height: 8px; } ul#player_bar_ul::-webkit-scrollbar-thumb { border-radius: 2px; border: 1px solid rgba(56,56,56,.3411764706); background-clip: padding-box; background-color: #a29bb84a; background-image: -webkit-linear-gradient(45deg,hsla(0deg,0%,100%,.4) 25%,transparent 0,transparent 50%,hsla(0deg,0%,100%,.4) 0,hsla(0deg,0%,100%,.4) 75%,transparent 0,transparent); } ul#player_bar_ul::-webkit-scrollbar-track { background-color: #f1f1f1; border-radius: 5px; } label.player_bar_ul_li_text::-webkit-scrollbar { width: 5px; height: 7px; background-color: #aaa; } label.player_bar_ul_li_text::-webkit-scrollbar-thumb { border: 1px solid rgba(56,56,56,.3411764706); background-clip: padding-box; background-color: #a29bb84a; } label.player_bar_ul_li_text::-webkit-scrollbar-track { background-color: #f1f1f1; } .player_bar_list_add_div { display: flex; height: 4vh; margin: 4px 2px; } input#player_bar_list_add_input { width: 100%; height: 30px; background-color: #ffffff; color: #727378; font-size: 1.3vh; border-radius: 0.3rem 0rem 0rem 0.3rem; padding: 1px 5px; margin: 5px 0px 5px 0px; border: 1px solid #00aeeccc; border-right: none; box-shadow: 0 0 1px #0000004d; } input#player_bar_list_add_input:focus-visible { border-width: 0.2vh; border-style: solid; border-color: #8bb2d9; outline: -webkit-focus-ring-color auto 0px; } button#player_bar_list_add_new_item_btn.added { background-color: #07e65196; color: #104f2b; } div#player_bar_go.gone { color: #3f5a14; font-weight: 600; background: linear-gradient(-225deg,#9CCC65,#E6EE9C); box-shadow: inset 0 -2px 0 0 #cde3e6, inset 0 0 1px 1px #c6fd7d, 0 1px 2px 1px rgb(30 90 44 / 40%); } /* bar修改菜单 */ div#player_bar_menu { position: absolute; border-width: 2px; border-style: solid; border-color: #8bb2d9; box-shadow: 1px 1px 4px 0px #0000004d; } div#player_bar_menu_edit { cursor: pointer; background-color: #ffffff; color: black; box-shadow: inset 0px -1px 0px 0px #8bb2d9; padding: 2px 6px; } div#player_bar_menu_delete { cursor: pointer; background-color: #ffff; box-shadow: inset 0px 1px 0px 0px #8bb2d9; color: black; padding: 2px 6px; } div#player_bar_menu_edit:hover { background-color: #00aeec; color: white; } div#player_bar_menu_delete:hover { background-color: #FF5722; color: white; } /*更新检查*/ div#update_panel { position: fixed; top: 50%; left: 50%; width: 240px; transform: translate(-50%, -50%); background-color: #fdfdfd; border: 1px solid #00aeeccc; border-radius: 5px; box-shadow: 2px 2px 3px #0000004d; padding: 10px 20px 20px 20px; color: #444242; } `); // 更新检查 (function checkScriptVersion() { function compareVersions(version1 = "0", version2 = "0") { const v1Array = String(version1).split("."); const v2Array = String(version2).split("."); const minLength = Math.min(v1Array.length, v2Array.length); let result = 0; for (let i = 0; i < minLength; i++) { const curV1 = Number(v1Array[i]); const curV2 = Number(v2Array[i]); if (curV1 > curV2) { result = 1; break; } else if (curV1 < curV2) { result = -1; break; } } if (result === 0 && v1Array.length !== v2Array.length) { const v1IsBigger = v1Array.length > v2Array.length; const maxLenArray = v1IsBigger ? v1Array : v2Array; for (let i = minLength; i < maxLenArray.length; i++) { const curVersion = Number(maxLenArray[i]); if (curVersion > 0) { v1IsBigger ? result = 1 : result = -1; break; } } } return result; } GM_xmlhttpRequest({ method: "GET", url: "https://greasyfork.org/zh-CN/scripts/464981.json", timeout: 10 * 1e3, onload: function(response) { const scriptData = JSON.parse(response.responseText); if (scriptData.name === GM_info.script.name && compareVersions(scriptData.version, GM_info.script.version) === 1) { $("body").append(`