// ==UserScript== // @name BilibiliTimer // @version 2.2.4 // @description B站H5播放器全屏时实时显示当前系统时间和播放进度 // @author AnnAngela // @namespace https://greasyfork.org/users/129402 // @mainpage https://greasyfork.org/zh-CN/scripts/30367-bilibilitimer // @supportURL https://greasyfork.org/zh-CN/scripts/30367-bilibilitimer/feedback // @compatible chrome 自Chrome 50开始兼容 // @match *://www.bilibili.com/video/av* // @match *://www.bilibili.com/watchlater* // @match *://www.bilibili.com/html/*layer.htm* // @match *://www.bilibili.com/blackboard/*layer.htm* // @match *://www.bilibili.com/bangumi/play/* // @match *://live.bilibili.com/* // @run-at document-start // @grant unsafeWindow // @grant GM_addStyle // @grant GM_setValue // @grant GM_getValue // @grant GM_deleteValue // @icon  // @icon64  // @downloadURL none // ==/UserScript== (function() { 'use strict'; /* 防止重复加载 */ if (unsafeWindow.BilibiliTimer) return; unsafeWindow.console.debug('%c' + GM_info.script.name + '@' + GM_info.script.version + ' by ' + GM_info.script.author + ' is running!', "padding: 32px 66px 32px 64px; line-height: 64px; background:url('" + GM_info.script.icon64 + "') top left no-repeat;"); unsafeWindow.BilibiliTimerUninit = false; unsafeWindow.BilibiliTimerGM = { set: GM_setValue, get: GM_getValue, delete: GM_deleteValue }; unsafeWindow.BilibiliTimer = {}; /* * 出于实现上的考虑,以下代码被保存为纯文本,并通过unsafeWindow.eval运行,以操作真实环境下的DOM节点 */ var code = [ "(function() {", " 'use strict';", " if (window.BilibiliTimerUninit || !window.jQuery) return false;", " if (!String.prototype.includes) String.prototype.includes = function includes(s) {", " return this.indexOf(s) !== -1;", " };", " var BilibiliTimer = window.BilibiliTimer || (window.BilibiliTimer = {});", " var LF = String.fromCharCode(10);", " BilibiliTimer._loop_count = 0;", " BilibiliTimer.date = function bilibiliPlayerDate() {", " var _date = new Date();", " ['getDate', 'getFullYear', 'getHours', 'getMilliseconds', 'getMinutes', 'getMonth', 'getSeconds', 'getTime', 'getUTCDate', 'getUTCFullYear', 'getUTCHours', 'getUTCMilliseconds', 'getUTCMinutes', 'getUTCMonth', 'getUTCSeconds', 'getYear'].forEach(function(key) {", " _date[key] = function() {", " var result = Date.prototype[key].apply(_date, arguments);", " if (key.includes('Month')) result++;", " if (typeof result === 'number' && (result + '').length === 1) return '0' + result;", " else return result + '';", " };", " });", " return _date;", " };", " try {", " BilibiliTimer.isBangumiEmbedded = location.host === 'www.bilibili.com' && location.pathname === '/blackboard/html5player.html' && top !== window && top.location.host === 'bangumi.bilibili.com';", " } catch(_) {", " BilibiliTimer.isBangumiEmbedded = false;", " }", " BilibiliTimer.realWindow = BilibiliTimer.isBangumiEmbedded ? top : window;", " BilibiliTimer.isLive = function bilibiliIsLive(a, b) {", " return location.host === 'live.bilibili.com' ? (a !== undefined ? a : true) : (b !== undefined ? b : false);", " };", " BilibiliTimer.selector = BilibiliTimer.isLive({", " container: '.bilibili-live-player-video-area',", " controller: '.bilibili-live-player-video-controller',", " fullscreenSendbar: null,", " autoHideButton: '.attend-button .right-part',", " autoHideButtonText: '.BilibiliTimerAutoHideButtonText',", " autoHideCheck: null,", " pageTitle: null,", " watchlaterPageTitle: null,", " watchlaterVideoTitle: null", " }, {", " container: '.bilibili-player-video-wrap',", " controller: '.bilibili-player-video-control',", " fullscreenSendbar: '.bilibili-player-video-sendbar.active',", " autoHideButton: '.bgray-btn-wrap .bgray-btn.show',", " autoHideButtonText: '.BilibiliTimerAutoHideButtonText',", " autoHideCheck: '.bilibili-player-no-cursor',", " pageTitle: '#plist .curPage ',", " watchlaterPageTitle: '.bilibili-player-auxiliary-area .bilibili-player-watchlater-part-item[data-state-play=true] .bilibili-player-watchlater-plist-chapter',", " watchlaterVideoTitle: '.bilibili-player-auxiliary-area .bilibili-player-watchlater-item[data-state-play=true] .bilibili-player-watchlater-info-title'", " });", " BilibiliTimer.classList = BilibiliTimer.isLive({", " timer: 'bilibili-live-player-video-info-container',", " closeButton: 'bilibili-live-player-video-info-close',", " panel: 'bilibili-live-player-video-info-panel',", " restartButton: 'live-icon-reload',", " autoHideButton: 'mid-part BilibiliTimerAutoHideButton',", " autoHideButtonText: 'BilibiliTimerAutoHideButtonText'", " }, {", " timer: 'bilibili-player-video-info-container',", " closeButton: 'bilibili-player-video-info-close',", " panel: 'bilibili-player-video-info-panel',", " restartButton: 'bilibili-player-iconfont icon-24repeaton',", " autoHideButton: 'bgray-btn show BilibiliTimerAutoHideButton',", " autoHideButtonText: 'BilibiliTimerAutoHideButtonText'", " });", " BilibiliTimer.closeButtonText = BilibiliTimer.isLive('x', '[x]');", " BilibiliTimer.globallock = false;", " BilibiliTimer.widthSet = false;", " BilibiliTimer.onResizing = 0;", " if (BilibiliTimer.selector.autoHideCheck) BilibiliTimer.mousemoveCount = 0;", " BilibiliTimer.getControllerTop = function BilibiliTimerGetControllerTop() {", " var controller = $(BilibiliTimer.selector.controller);", " if (controller.closest('.mode-miniscreen')[0]) return $(window).height();", " var _top = $(window).height() - controller.height();", " var fullscreenSendbar = $(BilibiliTimer.selector.fullscreenSendbar);", " if (fullscreenSendbar[0]) _top -= fullscreenSendbar.outerHeight(true);", " return _top;", " };", " $(window).on('resize.BilibiliTimer', function() {", " BilibiliTimer.onResizing = 1;", " });", " $(document).on({", " 'mousemove.BilibiliTimer': function(e) {", " var BilibiliTimer = window.BilibiliTimer;", " if (BilibiliTimer && BilibiliTimer.timer) {", " if (BilibiliTimer.timer.data('onMousedown')) {", " var maxTop = BilibiliTimer.getControllerTop() - BilibiliTimer.timer.outerHeight() - 10;", " var maxLeft = $(window).width() - BilibiliTimer.timer.outerWidth() - 10;", " BilibiliTimer.timer.css({", " left: Math.max(Math.min(BilibiliTimer.timer.data('baseOffset').left + e.clientX, maxLeft), 10),", " top: Math.max(Math.min(BilibiliTimer.timer.data('baseOffset').top + e.clientY, maxTop), 10)", " });", " window.getSelection().removeAllRanges();", " }", " if (BilibiliTimer.selector.autoHideCheck) BilibiliTimer.mousemoveCount = 0;", " }", " },", " 'mouseup.BilibiliTimer': function(e) {", " var BilibiliTimer = window.BilibiliTimer;", " if (BilibiliTimer && BilibiliTimer.timer && BilibiliTimer.timer.data('onMousedown')) {", " BilibiliTimer.timer.data('onMousedown', false);", " BilibiliTimerGM.set('offset', {", " top: BilibiliTimer.timer.css('top'),", " left: BilibiliTimer.timer.css('left')", " });", " }", " }", " });", " BilibiliTimer.template = {};", " var timer = BilibiliTimer.template.timer = $('
');", " timer.attr('id', 'BilibiliTimer').addClass(BilibiliTimer.classList.timer);", " var closeButton = BilibiliTimer.template.closeButton = $('');", " closeButton.text(BilibiliTimer.closeButtonText).attr({", " href: 'javascript:void(0);',", " id: 'BilibiliTimerCloseButton'", " });", " closeButton.addClass(BilibiliTimer.classList.closeButton);", " var restartButton = BilibiliTimer.template.restartButton = $('');", " restartButton.attr({", " href: 'javascript:void(0);',", " id: 'BilibiliTimerRestartButton',", " title: '如果发现浮窗出现问题,' + LF + '例如无法正常拖动,无法正常显示时间等,' + LF + '请点击该按钮重建浮窗尝试修复!'", " });", " restartButton.addClass(BilibiliTimer.classList.closeButton).addClass(BilibiliTimer.classList.restartButton);", " var panel = BilibiliTimer.template.panel = $('');", " panel.addClass(BilibiliTimer.classList.panel);", " panel.append(\"