您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
FloatingPlayer!悬浮窗
当前为
// ==UserScript== // @name FloatingPlayer // @namespace https://greasyfork.org/zh-CN/scripts/449323/ // @version 0.9.3 // @description FloatingPlayer!悬浮窗 // @author Ylanty // @license GPLv3 // @match http*://*/* // @icon  // ==/UserScript== var run=1; //// @noframes (function() { 'use strict'; if(run>1) return; run++; var zindex=999999999; var maxrect=5,minrect=0.25,steprect=0.05,maxrspeed=10,fastwinds=20; var findedVideoElement=false,touchedVideoElement=false,floatingFlag=false,isIframe=false,isRotate=false,isFloatingbtnContainDisplay=false; var rotate=0; var screenSize=1,screenSizeChange=0,screenPosition='default'; var videoInfo={}; var videoratio={width:0,height:0}; var allElements={}; var containSize={width:0,height:0}; var cw,ch; var showSettingsT=null,showMsgT=null,onLongPress=null,doubleTouchT=null; var touchInfo={},mouseInfo={}; var floatingPlayerData = { positionlefttop: {name: '◰'}, rotate: {name: '↻',value: 90}, positioncenter: {name: '⧈',colspan: 2}, rotate_: {name: '↺',value: -90}, positionrighttop: {name: '◳'}, videoratio34: {name: '3:4'}, videoratio43: {name: '4:3'}, videoratio916: {name: '9:16'}, videoratio169: {name: '16:9'}, videoratioauto: {name: '拉伸'}, videoratiosource: {name: '原比'}, //display: {name: '背景黑色',colspan: 2}, //time: {name: '时间',colspan: 6,nolistener:true}, videorect: {name: '🗔'}, videorect_001: {name: -steprect*100+'%',value: -steprect}, videorectrange: {name: '滑动',colspan: 2,buttontype: 'range'}, videorect001: {name: '+'+steprect*100+'%',value: steprect}, videorectshow: {name: '100%'}, volume: {name: '🔊'}, volume_010: {name: '-10%',value: -0.1}, volumerange: {name: '滑动',colspan: 2,buttontype: 'range'}, volume010: {name: '+10%',value: 0.1}, volumeshow: {name: '100%'}, speed: {name: '倍速'}, speed_001: {name: '-x0.1',value: -0.1}, speedrange: {name: '滑动',colspan: 2,buttontype: 'range'}, speed001: {name: '+x0.1',value: 0.1}, speedshow: {name: 'x1.0'}, progress: {name: '进度'}, progress_001: {name: '-1%',value: -0.01}, progressrange: {name: '滑动',colspan: 2,buttontype: 'range'}, progress001: {name: '+1%',value: 0.01}, progressshow: {name: '100%'}, positionleftbottom: {name: '◱'}, rewind: {name: '⏪ '+fastwinds+'s',value: -fastwinds}, play: {name: '⏯',colspan: 2}, fastwind: {name: '⏩ '+fastwinds+'s',value: fastwinds}, positionrightbottom: {name: '◲'} }; findVideoElement(); function findVideoElement(){ //alert(document.querySelector('iframe').contentWindow.document.querySelectorAll('video')); var k=0; var findVideoElementInterval = setInterval(function(){ if(document.querySelector('video')){ //alert(1); allElements.videoElement=document.querySelector('video'); if(allElements.videoElement.readyState >= 2){ //alert(window.top===window.self); if(window.top===window.self){ allElements.floatElement=allElements.videoElement; }else{ allElements.floatElement=window.top.document.querySelector('iframe'); isIframe=true; } allElements.floatElementContain=allElements.floatElement.parentElement; findedVideoElement=true; //clearInterval(findVideoElementInterval); if(window.top.document.querySelector('#fptlh')) window.top.document.querySelector('#fptlh').remove(); window.top.document.body.insertAdjacentHTML('beforeend','<input id="fptlh" value="'+window.top.location.href+'" style="display:none;">'); showFloatingBtn(); } } //k++; if(window.top.document.querySelector('#fptlh')){ var fptlh=window.top.document.querySelector('#fptlh'); if(fptlh.value==window.top.location.href) clearInterval(findVideoElementInterval); } }, 1000); } function isF(){ window.top.document.setValue('fptlh',window.top.location.href); } /*function findVideoElement(){ //alert(document.querySelector('iframe').contentWindow.document.querySelectorAll('video')); if(document.querySelector('video')){ //alert(1); allElements.videoElement=document.querySelector('video'); if(allElements.videoElement.readyState >= 2 && allElements.videoElement.duration>=20){ allElements.floatElement=allElements.videoElement; allElements.floatElementContain=allElements.floatElement.parentElement; findedVideoElement=true; } }else if(document.querySelector('iframe').contentWindow.document.querySelector('video')){ //alert(2); allElements.videoElement=document.querySelector('iframe').contentWindow.document.querySelector('video'); if(allElements.videoElement.readyState >= 2 && allElements.videoElement.duration>=20){ allElements.floatElement=document.querySelector('iframe'); //allElements.floatElement=allElements.videoElement; allElements.floatElementContain=allElements.floatElement.parentElement; findedVideoElement=true; isIframe=true; } } }*/ function showFloatingBtn(){ var btnCss=`<style type="text/css">.fixedscroll{position: fixed;overflow:hidden;width:100%;} .floatingvideo{object-fit: fill!important;}div.dplayer-menu{display:none!important;} #floatingshowmsg{z-index: `+(zindex+4)+`!important;position: fixed;text-align:center;line-height:1;font-size:30px;color: #717171;} .floatingbtnContain_display{position:fixed;z-index:`+(zindex-1)+`;background:black;width:100%;height:100%;left:0px;top:0px;} #floatingplayer_setting{border-collapse: separate;z-index: `+(zindex+2)+`!important;position: fixed;text-align:center;background: rgba(30, 29, 32, 0.5);} .tablecss{border-spacing:0;} .cellcss{width:100%;heght:100%;color: #fff;text-shadow: 1px 1px 0 rgb(0 0 0 / 70%);}</style>`; document.head.insertAdjacentHTML('beforeend',btnCss); //☫↻ //var floatingbtnstr='<a id="floatingbtn" title="打开/关闭悬浮窗" target="_blank" class="floatingbtn" style="right:12px;bottom:40px;">֎</a>'; //var floatingvideostr='<video id="floatingvideo" class="floatingvideo" style="position: fixed;"></video>'; var floatingshowmsgstr='<span id="floatingshowmsg" class="floatingshowmsg" style="left:40px;top:40px;display:none;">floatingshowinfo</span>'; var floatingbtnContainstr='<div id="floatingbtnContain">'+floatingshowmsgstr+create_table()+'</div>'; allElements.floatElementRect=allElements.floatElement.getBoundingClientRect(); document.body.insertAdjacentHTML('beforeend',floatingbtnContainstr); //allElements.floatingbtnContain.append(allElements.floatElement); allElements.floatingbtnContain=document.getElementById('floatingbtnContain'); //allElements.floatingbtnContain.append(allElements.floatElement); floating(); if(isIframe){ //allElements.floatingbtnContain=window.top.document.getElementById('floatingbtnContain'); window.top.document.querySelector('head').insertAdjacentHTML('beforeend','<style type="text/css">.fixedscroll{position: fixed;overflow:hidden;width:100%;}</style>'); }else{ allElements.floatingbtnContain.append(allElements.floatElement); } allElements.floatingshowmsg=document.getElementById('floatingshowmsg'); allElements.floatingplayer_setting=document.getElementById('floatingplayer_setting'); allElements.floatingplayer_setting_table=document.getElementById('floatingplayer_setting_table'); allElements.floatingbtnContain=document.getElementById('floatingbtnContain'); if(allElements.videoElement.paused) allElements.videoElement.play(); setEventListener(); //showFloatingInfo(); } function create_table() { const rows = 6; var htmlTable = `<div id="floatingplayer_setting" style="display:none;overflow: auto;"><table id="floatingplayer_setting_table" border="1" cellspacing="0" class="tablecss">`; let htmlTbody = ``; var datavalue=''; var tdInfo=''; var trEnd=0; for (let index in floatingPlayerData) { if (trEnd == 0) { htmlTbody += `<tr>`; } trEnd+=floatingPlayerData[index].colspan?floatingPlayerData[index].colspan:1; datavalue='undefined'; tdInfo=''; if(floatingPlayerData[index].value) datavalue=floatingPlayerData[index].value; if(floatingPlayerData[index].colspan) tdInfo+=`colspan="${floatingPlayerData[index].colspan}"`; //if(floatingPlayerData[index].rowspan) tdInfo+=`rowspan="${floatingPlayerData[index].rowspan}"`; //console.log('tableData[index].value',floatingPlayerData[index].value); if(floatingPlayerData[index].buttontype){ htmlTbody += `<td ${tdInfo}><input id="floatingplayer_${index}" type="range" class="cellcss range" dataname="${index}" datavalue="${datavalue}" datatitle="${floatingPlayerData[index].name}"></td>`; }else{ htmlTbody += `<td ${tdInfo}><div id="floatingplayer_${index}" class="cellcss" dataname="${index}" datavalue="${datavalue}" datatitle="${floatingPlayerData[index].name}">${floatingPlayerData[index].name}</div></td>`; } if (trEnd >= rows) { htmlTbody += `</tr>`; trEnd=0; } } htmlTable += `${htmlTbody}</table></div>`; return htmlTable; } function floating(){ floatingFlag=floatingFlag?false:true; if(floatingFlag){ videoratio.width=allElements.videoElement.videoWidth; videoratio.height=allElements.videoElement.videoHeight; //var fw=cw<ch*vw/vh?cw:ch*vw/vh; //var fh=ch<cw*vh/vw?ch:cw*vh/vw; //screenSize=vrfw/cw>vrfh/ch?vrfw/cw:vrfh/ch; //alert([cw,ch,vw,vh,vr,vrw,vrh,vrl,vrt,vrfw,vrfh,top,floatElement.querySelector('video')]); //allElements.floatingbtnContain.append(allElements.floatElementContain); //if(!isIframe) allElements.floatingbtnContain.append(allElements.floatElement); allElements.floatElement.className=''; allElements.videoElement.classList.add('floatingvideo'); /*if(!isIframe){ //allElements.videoElement.removeAttribute('controls'); //allElements.videoElement.className='floatingvideo'; allElements.videoElement.style=''; allElements.videoElement.id=''; //allElements.videoElement.controlsList='nofullscreen'; }*/ allElements.floatElement.style=''; allElements.floatElement.style.position='fixed'; allElements.floatElement.style.zIndex=zindex; if( /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent) ) { screenSize=1; screenPosition='lefttop'; setFloatingVidooRect(); }else{ cw=window.top.document.documentElement.clientWidth; ch=window.top.document.documentElement.clientHeight; var vw=allElements.videoElement.videoWidth; var vh=allElements.videoElement.videoHeight; var vr=allElements.floatElementRect; var vrw=vr.width; var vrh=vr.height; var vrl=vr.left; var vrt=vr.top; var vrfw=vrw<vrh*vw/vh?vrw:vrh*vw/vh; var vrfh=vrh<vrw*vh/vw?vrh:vrw*vh/vw; var top=vrt+(vrh-vrfh)/2<0?0:(vrt+(vrh-vrfh)/2>ch-vrfh?ch-vrfh:vrt+(vrh-vrfh)/2); screenSize=vrfw/cw>vrfh/ch?vrfw/cw:vrfh/ch; //screenPosition='default'; allElements.floatElement.style.width=vrfw+'px'; allElements.floatElement.style.height=vrfh+'px'; allElements.floatElement.style.left=vrl+(vrw-vrfw)/2+'px'; allElements.floatElement.style.top=top+'px'; } }/*else{ allElements.videoElement.classList.remove('floatingvideo'); //floatElement.style=''; //if(!isIframe) allElements.floatElementContain.prepend(allElements.floatElement); allElements.floatElement.style.position=null; allElements.floatElement.style.zIndex=null; allElements.floatElement.style.width=null; allElements.floatElement.style.height=null; allElements.floatElement.style.left=null; allElements.floatElement.style.top=null; allElements.floatElement.removeEventListener("touchstart",touchStartHandler,true); allElements.floatElement.removeEventListener("mousedown",mouseDownHandler,true); }*/ } function setSettings(){ var vr=allElements.videoElement.getBoundingClientRect(); //cw=document.documentElement.clientWidth; allElements.floatingplayer_setting.style.left=vr.left+'px'; allElements.floatingplayer_setting.style.top=vr.top+vr.height/2+'px'; var fer=allElements.floatingplayer_setting.getBoundingClientRect(); if(fer.top+fer.height>ch){ ch=document.documentElement.clientHeight; allElements.floatingplayer_setting.style.top=ch-fer.height+'px'; } //allElements.floatingplayer_setting.style.maxWidth=vr.width+'px'; //allElements.floatingplayer_setting.style.maxHeight=vr.height/2+'px'; allElements.floatingplayer_setting_table.style.width=vr.width+'px'; allElements.floatingplayer_setting_table.style.height=vr.height/2+'px'; } function showSettings(){ if(showSettingsT!=null) clearTimeout(showSettingsT); allElements.floatingplayer_setting.style.display='block'; setSettings(); showFloatingInfo(); showSettingsT = setTimeout(function() { showSettingsT=null; allElements.floatingplayer_setting.style.display='none'; }, 3000); } function showFloatingInfo(){ var showFloatingInfoInterval = setInterval(function(){ var ct=allElements.videoElement.currentTime; var dt=allElements.videoElement.duration; //allElements.floatingplayer_time.textContent=secondsToTimeStr(ct)+'/'+secondsToTimeStr(dt); allElements.floatingplayer_videorectrange.value=(screenSize*100/maxrect).toFixed(0); allElements.floatingplayer_videorectshow.textContent=(screenSize*100).toFixed(0)+'%'; var progressbarvalue=ct/dt*100; allElements.floatingplayer_progressrange.value=(progressbarvalue).toFixed(0); //allElements.floatingplayer_progressshow.textContent=(progressbarvalue).toFixed(0)+'%'; allElements.floatingplayer_progress.textContent=secondsToTimeStr(ct); allElements.floatingplayer_progressshow.textContent=secondsToTimeStr(dt); var speedanyvalue=allElements.videoElement.playbackRate; allElements.floatingplayer_speedrange.value=(speedanyvalue*100/maxrspeed).toFixed(0); allElements.floatingplayer_speedshow.textContent='x'+speedanyvalue.toFixed(1); var volumeanyvalue=allElements.videoElement.volume; allElements.floatingplayer_volumerange.value=(volumeanyvalue*100).toFixed(0); allElements.floatingplayer_volumeshow.textContent=(volumeanyvalue*100).toFixed(0)+'%'; if(allElements.floatingplayer_setting.style.display=='none'){ clearInterval(showFloatingInfoInterval); } }, 1000); } function showMsg(msg){ if(showMsgT!=null) clearTimeout(showMsgT); //setMsg(); var vr=allElements.videoElement.getBoundingClientRect(); allElements.floatingshowmsg.style.left=vr.left+'px'; allElements.floatingshowmsg.style.top=vr.top+'px'; allElements.floatingshowmsg.textContent=msg; allElements.floatingshowmsg.style.display='block'; showMsgT = setTimeout(function() { showMsgT=null; allElements.floatingshowmsg.style.display='none'; }, 2000); } function floatingVidooAttr(e){ //if(isIframe) videoElement=videoElementContain.querySelector('video'); var ele=e.target; var value=ele.value; var dataname=ele.getAttribute('dataname'); var datavalue=ele.getAttribute('datavalue'); var datatitle=ele.getAttribute('datatitle'); //alert([dataname,datavalue]); if(datavalue!='undefined') datavalue=parseFloat(datavalue); if(dataname=='display'){ isFloatingbtnContainDisplay=isFloatingbtnContainDisplay?false:true; if(isFloatingbtnContainDisplay){ allElements.floatingbtnContain.classList.add('floatingbtnContain_display'); }else{ allElements.floatingbtnContain.classList.remove('floatingbtnContain_display'); } }else if(dataname.substring(0,9)=='videorect'){ setVideoRect(dataname,datavalue,value); }else if(dataname.substring(0,8)=='progress'){ setProcess(dataname,datavalue,value); }else if(dataname.substring(0,5)=='speed'){ setSpeed(dataname,datavalue,value); }else if(dataname.substring(0,6)=='volume'){ setVolume(dataname,datavalue,value); }else if(dataname=='rewind' || dataname=='fastwind'){ allElements.videoElement.currentTime=allElements.videoElement.currentTime+datavalue; }else if(dataname=='play'){ allElements.videoElement.paused?allElements.videoElement.play():allElements.videoElement.pause(); }else if(dataname=='rotate' || dataname=='rotate_'){ screenSizeChange=0; rotate+=datavalue; if(rotate>=360) rotate-=360; else if(rotate<0) rotate+=360; allElements.floatElement.style.transform='rotate('+rotate+'deg)'; //allElements.floatingcontrols.style.transform='rotate('+rotate+'deg)'; /*floatingplayer_setting.style.transform='rotate('+rotate+'deg)';}*/ }else if(dataname.substring(0,8)=='position'){ screenPosition=dataname.substring(8); //setPosition(dataname); }else if(dataname.substring(0,10)=='videoratio'){ setVideoRatio(dataname); } if(dataname=='rotate' || dataname=='rotate_' || dataname.substring(0,5)=='video' || dataname.substring(0,8)=='position'){ setFloatingVidooRect(); } showSettings(); showMsg(datatitle); } function setVideoRect(dataname,datavalue,value){ if(dataname=='videorect'){ //setVideoRect(); }else if(dataname=='videorect_001' || dataname=='videorect001'){ var tempScreenSize=screenSize; screenSize+=datavalue; screenSize=screenSize>maxrect?maxrect:(screenSize<minrect?minrect:screenSize); screenSizeChange=screenSize-tempScreenSize; }else if(dataname=='videorectrange'){ value=value<minrect*100/maxrect?minrect*100/maxrect:value; screenSizeChange=value/100*maxrect-screenSize; screenSize=value/100*maxrect; }else if(dataname=='videorectshow'){ screenSizeChange=1-screenSize; screenSize=1; screenPosition='center'; } } function setProcess(dataname,datavalue,value){ if(dataname=='progress'){ //screenSize=1; }else if(dataname=='progress_001' || dataname=='progress001'){ allElements.videoElement.currentTime+=allElements.videoElement.duration*datavalue; }else if(dataname=='progressrange'){ allElements.videoElement.currentTime=allElements.videoElement.duration*value/100; }else if(dataname=='progressshow'){ //screenSize=1; } } function setSpeed(dataname,datavalue,value){ if(dataname=='speed' || dataname=='speedshow'){ allElements.videoElement.playbackRate=1; }else if(dataname=='speed_001' || dataname=='speed001'){ if(allElements.videoElement.playbackRate+datavalue>maxrspeed){ allElements.videoElement.playbackRate=maxrspeed; }else if(allElements.videoElement.playbackRate+datavalue<=0){ allElements.videoElement.playbackRate=0.1; }else{ allElements.videoElement.playbackRate+=datavalue; } }else if(dataname=='speedrange'){ allElements.videoElement.playbackRate=(value/100*maxrspeed).toFixed(1); } } function setVolume(dataname,datavalue,value){ if(dataname=='volume'){ allElements.videoElement.muted=allElements.videoElement.muted?false:true; }else if(dataname=='volume_010' || dataname=='volume010'){ if(allElements.videoElement.volume+datavalue>1) allElements.videoElement.volume=1; else if(allElements.videoElement.volume+datavalue<0) allElements.videoElement.volume=0; else allElements.videoElement.volume+=datavalue; }else if(dataname=='volumerange'){ allElements.videoElement.volume=value/100; }else if(dataname=='volumeshow'){ allElements.videoElement.muted=false; allElements.videoElement.volume=1; } } function setVideoRatio(dataname){ if(dataname=='videoratiosource'){ videoratio.width=allElements.videoElement.videoWidth; videoratio.height=allElements.videoElement.videoHeight; }else if(dataname=='videoratio34'){ videoratio.width=3; videoratio.height=4; }else if(dataname=='videoratio43'){ videoratio.width=4; videoratio.height=3; }else if(dataname=='videoratio916'){ videoratio.width=9; videoratio.height=16; }else if(dataname=='videoratio169'){ videoratio.width=16; videoratio.height=9; }else if(dataname=='videoratioauto'){ if(rotate==90||rotate==270){ videoratio.width=window.top.document.documentElement.clientHeight; videoratio.height=window.top.document.documentElement.clientWidth; }else{ videoratio.width=window.top.document.documentElement.clientWidth; videoratio.height=window.top.document.documentElement.clientHeight; } } } function setFloatingVidooRect(){ var left,top; cw=window.top.document.documentElement.clientWidth; ch=window.top.document.documentElement.clientHeight; var vw=videoratio.width; var vh=videoratio.height; var fw,fh; isRotate=rotate==90||rotate==270; if(isRotate){ fw=(ch<cw/vh*vw?ch:cw/vh*vw); fh=(cw<ch/vw*vh?cw:ch/vw*vh); }else{ fw=(cw<ch*vw/vh?cw:ch*vw/vh); fh=(ch<cw*vh/vw?ch:cw*vh/vw); } var sfw=fw*screenSize; var sfh=fh*screenSize; if(isIframe){ allElements.videoElement.style.width=sfw+'px'; allElements.videoElement.style.height=sfh+'px'; } allElements.floatElement.style.width=sfw+'px'; allElements.floatElement.style.height=sfh+'px'; //var vr=floatElement.getBoundingClientRect(); var fel=allElements.floatElement.offsetLeft; var fet=allElements.floatElement.offsetTop; var sfwh=-(sfw-sfh)/2; if(screenPosition=='lefttop'){ left=isRotate?sfwh:0; top=isRotate?-sfwh:0; }else if(screenPosition=='righttop'){ left=isRotate?cw-sfw-sfwh:cw-sfw; top=isRotate?-sfwh:0; }else if(screenPosition=='leftbottom'){ left=isRotate?sfwh:0; top=isRotate?ch-sfh+sfwh:ch-sfh; }else if(screenPosition=='rightbottom'){ left=isRotate?cw-sfw-sfwh:cw-sfw; top=isRotate?ch-sfh+sfwh:ch-sfh; }else if(screenPosition=='center'){ left=(cw-sfw)/2; top=(ch-sfh)/2; }else if(screenPosition=='mousewheel'){ left=fel-(fw*screenSizeChange)*videoInfo.cx/videoInfo.ew; top=fet-(fh*screenSizeChange)*videoInfo.cy/videoInfo.eh; }else if(screenPosition=='mousemove'){ left=fel-(fw*screenSizeChange)/2; top=fet-(fh*screenSizeChange)/2; }else{ left=fel; top=fet; } allElements.floatElement.style.left=left+'px'; allElements.floatElement.style.top=top+'px'; } function secondsToTimeStr(secs){ secs=secs.toFixed(0); var hour=parseInt(secs/3600); var min=parseInt(secs/60)-60*hour; var sec=secs%60; var ret=''; ret+=(hour>0?hour+':':'')+(min < 10? '0' + min : min) + ':' + (sec < 10? '0' + sec : sec); return ret; } function setEventListener(){ if( /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent) ) { allElements.videoElement.addEventListener("touchstart",videoEvent,true); }else{ allElements.videoElement.addEventListener("mouseover",videoEvent,true); allElements.videoElement.addEventListener("mousedown",videoEvent,true); } for (let index in floatingPlayerData) { allElements['floatingplayer_'+index]=document.getElementById('floatingplayer_'+index); if(!floatingPlayerData[index].nolistener){ allElements['floatingplayer_'+index].addEventListener(floatingPlayerData[index].buttontype?'input':'click', floatingVidooAttr,true); } } } function videoEvent(e){ var self=e; var ele=e.target; var etype=e.type; //ele.paused?ele.play():ele.play(); if(etype=='mouseover'){ videoInfo.scrollY=null; ele.addEventListener("mousewheel",videoEvent,true); ele.addEventListener("mouseleave",videoEvent,true); showSettings(); }else if(etype=='mousewheel'){ if(videoInfo.scrollY==null){ videoInfo.scrollY=window.top.scrollY; videoInfo.dw=window.top.document.documentElement.clientWidth; window.top.document.body.classList.add('fixedscroll'); window.top.document.body.style.top = `-${videoInfo.scrollY}px`; window.top.document.body.style.width = `${videoInfo.dw}px`; } var deltaY=self.deltaY; videoInfo.cx=self.clientX-ele.offsetLeft; videoInfo.cy=self.clientY-ele.offsetTop; videoInfo.ew=ele.offsetWidth; videoInfo.eh=ele.offsetHeight; var tempScreenSize=screenSize; var tempSizeChange=deltaY<0?-steprect:(deltaY>0?steprect:0); screenSize+=screenSize>2?tempSizeChange*2:tempSizeChange; screenSize=screenSize>maxrect?maxrect:(screenSize<minrect?minrect:screenSize); screenSizeChange=screenSize-tempScreenSize; screenPosition='mousewheel'; if(screenSizeChange!=0) setFloatingVidooRect(); setSettings(); showMsg((screenSize*100).toFixed(0)+'%'); }else if(etype=='touchstart' || etype=='mousedown'){ cw=document.documentElement.clientWidth; ch=document.documentElement.clientHeight; videoInfo.self=etype=='touchstart'?self.touches[0]:self; videoInfo.originalPlaybackRate=ele.playbackRate; if (onLongPress == null){ onLongPress = setTimeout(function() { if (doubleTouchT != null){ clearTimeout(doubleTouchT); doubleTouchT = null; } ele.playbackRate=5.0; showMsg('倍速x'+ele.playbackRate); }, 400); } if (doubleTouchT == null) { doubleTouchT = setTimeout(function () { doubleTouchT = null; showSettings(); //alert("single"); }, 500) }else{ clearTimeout(doubleTouchT); doubleTouchT = null; var cx=ele.offsetLeft+ele.offsetWidth/2; var cy=ele.offsetTop+ele.offsetHeight/2; var isfastwinds=false; if((rotate==0 && videoInfo.self.clientX>cx)||(rotate==90 && videoInfo.self.clientY>cy)||(rotate==180 && videoInfo.self.clientX<cx)||(rotate==270 && videoInfo.self.clientY<cy)){ isfastwinds=true; } ele.currentTime+=isfastwinds?fastwinds:-fastwinds; showMsg(String.fromCodePoint(isfastwinds?'0x23E9':'0x23EA')+fastwinds+'s'); } videoInfo.x=allElements.floatElement.offsetLeft-videoInfo.self.clientX; videoInfo.y=allElements.floatElement.offsetTop-videoInfo.self.clientY; if(etype=='touchstart'){ //videoInfo.startTouchFingers=e.touches.length; ele.addEventListener("touchend",videoEvent,true); ele.addEventListener("touchmove",videoEvent,true); }else{ ele.addEventListener("mouseleave",videoEvent,true); ele.addEventListener("mouseup",videoEvent,true); ele.addEventListener("mousemove",videoEvent,true); } }else if(etype=='touchmove' || etype=='mousemove'){ if(onLongPress!=null){ clearTimeout(onLongPress); onLongPress=null; ele.playbackRate=videoInfo.originalPlaybackRate; //showMsg(ele.playbackRate+'倍速播放'); } if (doubleTouchT != null){ clearTimeout(doubleTouchT); doubleTouchT = null; } //showSettings(e); screenPosition='mousemove'; videoInfo.self=etype=='touchmove'?self.touches[0]:self; allElements.floatElement.style.left=videoInfo.x+videoInfo.self.clientX+'px'; allElements.floatElement.style.top=videoInfo.y+videoInfo.self.clientY+'px'; setSettings(); }else if(etype=='touchend' || etype=='mouseup' || etype=='mouseleave'){ if(videoInfo.scrollY!=null){ window.top.document.body.classList.remove('fixedscroll'); window.top.document.body.style.top = `0px`; window.top.scrollTo({top:videoInfo.scrollY}); window.top.document.body.style.width = null; } if(onLongPress!=null){ clearTimeout(onLongPress); onLongPress=null; ele.playbackRate=videoInfo.originalPlaybackRate; //showMsg(ele.playbackRate+'倍速播放'); } videoInfo.self=null; videoInfo.x=null; videoInfo.y=null; if(etype=='touchend'){ ele.removeEventListener("touchmove",videoEvent,true); ele.removeEventListener("touchend",videoEvent,true); }else{ ele.removeEventListener("mousemove",videoEvent,true); ele.removeEventListener("mouseleave",videoEvent,true); ele.removeEventListener("mouseup",videoEvent,true); ele.removeEventListener("mousewheel",videoEvent,true); } } } // Your code here... })();