您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
快捷展开微博全文,轻松查看微博视频
// ==UserScript== // @name 快捷展开微博&查看微博视频 // @namespace https://greasyfork.org/zh-CN/users/1073-hzhbest // @version 1.2 // @description 快捷展开微博全文,轻松查看微博视频 // @author hzhbest // @match https://weibo.com/* // @match https://s.weibo.com/* // @icon  // @grant none // @license MIT // ==/UserScript== (function() { 'use strict'; var pinned, cursize, videotimeout, popuptimeout, mvouttimeout; // 设置选项 === pinned = false; // 默认钉住视频窗口?true:是,false:不钉住 cursize = 1; // 默认视频窗口大小?1:大,2:中,3:小 popuptimeout = 0.5; // 鼠标悬停弹出视频延时(秒) mvouttimeout = 1; // 鼠标移出视频窗口关闭延时(秒);钉住时不关闭 videotimeout = 3; // 视频播放完后自动关闭延时(秒);钉住时不关闭 // 设置选项 ||= const waitimg = ""; let bbox = creaElemIn('div', document.body); bbox.id = "__wb_fbox"; let tb = creaElemIn('div', bbox); tb.className = "__title" let tbox = creaElemIn('div', tb); tbox.className = "__move" tbox.innerHTML = "░░░░░░░"; let sizebtn = creaElemIn('div', tb); sizebtn.innerHTML = "S"; sizebtn.title = "切换视频大小"; sizebtn.className = "__btn"; let pinbtn = creaElemIn('div', tb); pinbtn.innerHTML = "T"; pinbtn.title = "切换小窗保持不关状态"; pinbtn.className = "__btn"; let closebtn = creaElemIn('div', tb); closebtn.innerHTML = "X"; closebtn.title = "关闭小窗"; closebtn.className = "__btn"; let fbox = creaElemIn('video', bbox); fbox.src = waitimg; fbox.controls = true; fbox.autoplay = true; endrag(bbox, { x: 'right', y: 'top' }, tbox); var exptime, bboxtime, ctltime, clstime; var curelem; var firstopen, vsrc, mt = ""; let css = ` #__wb_fbox { position:fixed; z-index:10000; display: none; box-shadow: 0 0 10px 2px #777d; background: black; } #__wb_fbox>video{ max-height: 600px; max-width: 800px; resize: both; } #__wb_fbox.size2>video{ max-height: 400px; max-width: 533px; } #__wb_fbox.size3>video { max-height: 300px; max-width: 400px; } #__wb_fbox .__title { width: 100%; height: 18px; display: flex; } #__wb_fbox .__move { flex: auto; color: #6f6f6f; cursor: move; display: inline-block; font-size: 14px; line-height: 19px; height: 17px; } #__wb_fbox .__btn { margin: auto 3px auto 0; border: 1px solid #ae7108; color: #ae7108; font-size: 12px; vertical-align: middle; text-align: center; display: inline-block; width: 17px; height: 17px; cursor: default; } #__wb_fbox.size2 .__btn.s { background: #575516; } #__wb_fbox.size3 .__btn.s { background: #716e1b; } #__wb_fbox .__btn.p { background: #1b711b; } #__wb_fbox .__btn:hover { border-color: #f39e0b; color: #f39e0b; } `; fbox.addEventListener('loadeddata', () => { fbox.play(); ctltime = setTimeout(() => { fbox.controls = false; }, 1000); }, false); fbox.addEventListener('play', () => { firstopen = false; }, false); fbox.addEventListener('ended', () => { clstime = setTimeout(() => { if (!pinned) reset(); }, videotimeout * 1000); }, false); bbox.addEventListener('mouseleave', ()=>{ if (pinned) { return; } bboxtime = setTimeout(() => { reset(); }, mvouttimeout * 1000); }, false); bbox.addEventListener('mouseover', () => { clearTimeout(bboxtime); if (firstopen) fbox.play(); }, false); bbox.addEventListener('mouseup', () => { clearTimeout(bboxtime); }, false); bbox.addEventListener('mousemove', () => { clearTimeout(ctltime); clearTimeout(clstime); fbox.controls = true; ctltime = setTimeout(() => { fbox.controls = false; }, 1000); }, false); closebtn.addEventListener('click', reset, false); pinbtn.addEventListener('click', switchpin, false); sizebtn.addEventListener('click', switchsize, false); document.body.addEventListener('mouseover', texpand, false); addCSS(css); function texpand(event){ let tnode = event.target; if (tnode !== curelem) { clearTimeout(exptime); } //console.log('tnode: ', tnode, 'tnode.src: ', tnode.src); if (!tnode.className) { return; } let btnexpand; if (tnode.nodeName == 'DIV' && tnode.className.indexOf('detail_wbtext_') == 0) { btnexpand = tnode.querySelector('span.expand'); } else if (tnode.nodeName == 'P' && tnode.className == 'txt') { btnexpand = tnode.querySelector('a[action-type="fl_unfold"]'); } else if (true || !/weibo\.com\/\d{10}\/[a-z0-9A-Z]{9}\??/.test(location.href)) { var tvnode = getVideoBox(tnode, event); //console.log('tvnode159: ', tvnode); if (!!tvnode) { exptime = setTimeout(() => { expandvideo(tvnode, event); }, popuptimeout * 1000); //console.log("167:", exptime, tvnode); } else { //console.log("181c:", exptime); clearTimeout(exptime); } } if (!!btnexpand) { btnexpand.click(); } curelem = tnode; } function reset() { bbox.style.display = "none"; fbox.src = waitimg; firstopen = true; vsrc = ""; pinned = false; pinbtn.classList.remove("p"); } function getVideoBox(elem, event) { var velem, telem; if (!!elem) { if (elem.nodeName == 'VIDEO') { velem = elem; } else { telem = elem.parentNode.querySelector('video'); if (!!telem && isCursorInElem(telem, event)) { velem = telem; } } if (!!velem && velem.parentNode.nodename !== 'a' && velem.parentNode.id !== "__wb_fbox") { return velem; } } return false; } function expandvideo(vnode, event) { //快捷展开动图 if (vsrc == vnode.src) { return; } clearTimeout(clstime); fbox.src = vnode.src; vsrc = fbox.src; fbox.controls = true; bbox.style.display = "block"; // let mx = event.screenX, my = event.screenY; // mx -= 50; // my = 10; //Math.min(my - 50, window.innerHeight - fbox.offsetHeight - 50);console.log('fboxh2: ', fbox.offsetHeight); bbox.style.top = 40 + "px"; bbox.style.right = 50 + "px"; vnode.addEventListener('mouseleave', (event) => { //console.log("222c:", exptime); clearTimeout(exptime); }, false); } function switchpin() { pinned = !pinned; pinbtn.classList.toggle("p"); } function switchsize() { switch (cursize) { case 1: cursize = 2; bbox.className = "size2"; sizebtn.classList.add("s"); break; case 2: cursize = 3; bbox.className = "size3"; break; case 3: cursize = 1; bbox.className = ""; sizebtn.classList.remove("s"); break; } } function creaElemIn(tagname, destin) { //在 destin 内末尾创建元素 tagname let theElem = destin.appendChild(document.createElement(tagname)); return theElem; } function addCSS(css, cssid) { let stylenode = creaElemIn('style',document.getElementsByTagName('head')[0]); stylenode.textContent = css; stylenode.type = 'text/css'; stylenode.id = cssid || ''; } function isCursorInElem(elem, event) { var x = Number(event.clientX) // 鼠标相对屏幕横坐标 var y = Number(event.clientY) // 鼠标相对屏幕纵坐标 var elemLeft = Number(elem.getBoundingClientRect().left) // obj相对屏幕的横坐标 var elemRight = Number( elem.getBoundingClientRect().left + elem.clientWidth ) // obj相对屏幕的横坐标+width var elemTop = Number(elem.getBoundingClientRect().top) // obj相对屏幕的纵坐标 var elemBottom= Number( elem.getBoundingClientRect().top + elem.clientHeight ) // obj相对屏幕的纵坐标+height return (x > elemLeft && x < elemRight && y > elemTop && y < elemBottom); } // 对target拖动handle时,实现拖动的功能 // 输入:目标元素target,拖动位置参考系opt,拖动手柄handle // 输入opt:形如【{x:'right',y:'bottom'}】 function endrag(target, opt, handle) { var p_x, p_y, isDragging; endrag = function(target, opt, handle){ return new endrag.proto(target, opt||{}, handle); } endrag.proto = function (target, opt, handle) { var self = this; this.target = target; this.style = target.style; this.handle = handle; var _x = opt.x !== 'right'; var _y = opt.y !== 'bottom'; this.x = _x ? 'left' : 'right'; this.y = _y ? 'top' : 'bottom'; p_x = this.x; p_y = this.y; this.xd = _x ? -1 : 1; this.yd = _y ? -1 : 1; this.computed_style = document.defaultView.getComputedStyle(target, ''); this.drag_begin = function(e){self.__drag_begin(e);}; this.handle.addEventListener('mousedown', this.drag_begin, false); //only drag on handler this.dragging = function(e){self.__dragging(e);}; document.addEventListener('mousemove', this.dragging, false); this.drag_end = function(e){self.__drag_end(e);}; document.addEventListener('mouseup', this.drag_end, false); }; endrag.proto.prototype = { __drag_begin:function(e){ if (e.button == 0) { var _c = this.computed_style; this.isDragging = isDragging = true; this.position = { _x:parseFloat(_c[this.x]), _y:parseFloat(_c[this.y]), x:e.pageX, y:e.pageY }; e.preventDefault(); } }, __dragging:function(e){ if (!this.isDragging) return; var x = Math.floor(e.pageX), y = Math.floor(e.pageY), p = this.position; // prevent moving out of window var x_border = window.innerWidth - 40, y_border = window.innerHeight - 20; if (x - window.pageXOffset > x_border) x = window.pageXOffset + x_border; if (y - window.pageYOffset > y_border) y = window.pageYOffset + y_border; p._x = p._x + (p.x - x) * this.xd; p._y = p._y + (p.y - y) * this.yd; this.style[this.x] = p._x + 'px'; this.style[this.y] = p._y + 'px'; p.x = x; p.y = y; }, __drag_end:function(e){ if (e.button == 0) { if (this.isDragging) { this.isDragging = isDragging = false; } } }, hook:function(method,func){ if (typeof this[method] === 'function') { var o = this[method]; this[method] = function(){ if (func.apply(this,arguments) === false) { return; } o.apply(this,arguments); }; } } }; return endrag(target, opt, handle); } })();