FloatingPlayer

FloatingPlayer!悬浮窗

Fra og med 11.08.2022. Se den nyeste version.

// ==UserScript==
// @name        FloatingPlayer
// @namespace   https://greasyfork.org/zh-CN/scripts/449323/
// @version     0.2
// @description FloatingPlayer!悬浮窗
// @author      Ylanty
// @license     GPLv3
// @match       http*://*/*
// @icon        
// @noframes
// ==/UserScript==
var run=1;
(function() {
    'use strict';
    if(run>1) return;
    run++;
    var zindex=999999999;
    var maxrect=5;
    var maxrspeed=10;
    var findedVideoElement=false,touchedVideoElement=false,floatingFlag=false,isIframe=false,isRotate=false,isFloatingbtnContainDisplay=false;
    var rotate=0;
    var screenSize=1,screenSizeChange=0,screenPosition='default';
    var videoratio={width:0,height:0};
    var allElements={};
    var containSize={width:0,height:0};
    var cw,ch;
    var mouseoverbtn,showMsgT;
    var touchInfo={},mouseInfo={};
    var floatingPlayerData = {
        display: {name: '背景黑色',colspan: 2},
        time: {name: '时间',colspan: 4,nolistener:true},

        videorect: {name: '🗔'},
        videorect_001: {name: '-5%',value: -0.05},
        videorectrange: {name: '滑动',colspan: 2,buttontype: 'range'},
        videorect001: {name: '+5%',value: 0.05},
        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%'},

        videoratio34: {name: '3:4'},
        videoratio43: {name: '4:3'},
        videoratio916: {name: '9:16'},
        videoratio169: {name: '16:9'},
        videoratioauto: {name: '拉伸'},
        videoratiosource: {name: '原比'},

        positionlefttop: {name: '◰'},
        rotate: {name: '↻',value: 90},
        positioncenter: {name: '⧈',colspan: 2},
        rotate_: {name: '↺',value: -90},
        positionrighttop: {name: '◳'},

        positionleftbottom: {name: '◱'},
        rewind: {name: '⏮ 20s',value: -20},
        play: {name: '⏵/⏸',colspan: 2},
        fastwind: {name: '⏭ 20s',value: 20},
        positionrightbottom: {name: '◲'}
    };

    //showFloatingBtn();
    var findVideoElementInterval = setInterval(function(){
        findVideoElement();
        if(findedVideoElement){
            clearInterval(findVideoElementInterval);
            showFloatingBtn();
        }
    }, 1000);

    function findVideoElement(){
       //alert(document.querySelector('iframe').contentWindow.document.querySelectorAll('video'));
        if(document.querySelector('video')){
            allElements.videoElement=document.querySelector('video');
            if(allElements.videoElement.readyState >= 2 && allElements.videoElement.duration>=2){
                allElements.floatElement=allElements.videoElement;
                allElements.floatElementContain=allElements.floatElement.parentElement;
                findedVideoElement=true;
            }
        }else if(document.querySelector('iframe').contentWindow.document.querySelector('video')){
            allElements.videoElement=document.querySelector('iframe').contentWindow.document.querySelector('video');
            if(allElements.videoElement.readyState >= 2 && allElements.videoElement.duration>=2){
                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;}
                    .floatingvideo{object-fit: fill!important;}
                    #floatingbtn{width: 32px;height:32px;z-index: `+(zindex+3)+`!important;position: fixed;text-align:center;line-height:1;font-size:30px;color: #717171;}
                    #floatingshowmsg{z-index: `+(zindex+4)+`!important;position: fixed;text-align:center;line-height:1;font-size:30px;color: #717171;}
                    #floatingbtn:hover{color: green;}
                    .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;line-height:32px;}
                    .cellcss{width:100%;heght:100%;color: #fff;text-shadow: 1px 1px 0 rgb(0 0 0 / 70%);}</style>`;
        document.querySelector('head').insertAdjacentHTML('beforeend',btnCss);
        //&#9771;&#x21BB;
        var floatingbtnstr='<a id="floatingbtn" title="打开/关闭悬浮窗" class="floatingbtn" style="right:12px;bottom:40px;">&#1422;</a>';
        var floatingshowmsgstr='<span id="floatingshowmsg" class="floatingshowmsg" style="right:40px;top:40px;display:none;">floatingshowinfo</a>';
        var floatingbtnContainstr='<div id="floatingbtnContain">'+floatingbtnstr+floatingshowmsgstr+'</div>';
        if(isIframe){
            allElements.floatElementContain.insertAdjacentHTML('beforeend',floatingbtnContainstr);
            allElements.floatingbtnContain=document.getElementById('floatingbtnContain');
            allElements.floatingbtnContain.append(allElements.floatElement);
            findedVideoElement=false;
            var findVideoElementInterval = setInterval(function(){
                findVideoElement();
                if(findedVideoElement){
                    clearInterval(findVideoElementInterval);
                    allElements.floatElement.contentWindow.document.querySelector('head').insertAdjacentHTML('beforeend','<style type="text/css">.floatingvideo{object-fit: fill!important;}div.dplayer-menu{display:none!important;}</style>');
                    floating();
                    //showFloatingBtn();
                }
            }, 1000);
        }else{
            floating();
            document.body.insertAdjacentHTML('beforeend',floatingbtnContainstr);
            allElements.floatingbtnContain=document.getElementById('floatingbtnContain');
            allElements.floatingbtnContain.append(allElements.floatElement);
        }
        allElements.floatingbtnContain.insertAdjacentHTML('beforeend',create_table());
        allElements.floatingbtn=document.getElementById('floatingbtn');
        allElements.floatingshowmsg=document.getElementById('floatingshowmsg');
        allElements.floatingplayer_setting=document.getElementById('floatingplayer_setting');
        setEventListener();
        //showFloatingInfo();
    }
    function create_table() {
        const rows = 6;
        var htmlTable = `<div id="floatingplayer_setting" style="right:12px;bottom:80px;display:none;"><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}"></td>`;
            }else{
                htmlTbody += `<td ${tdInfo}><div id="floatingplayer_${index}" class="cellcss" dataname="${index}" datavalue="${datavalue}">${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;
            cw=document.documentElement.clientWidth;
            ch=document.documentElement.clientHeight;
            var vw=videoratio.width;
            var vh=videoratio.height;
            //var fw=cw<ch*vw/vh?cw:ch*vw/vh;
            //var fh=ch<cw*vh/vw?ch:cw*vh/vw;
            allElements.floatElementRect=allElements.floatElement.getBoundingClientRect();
            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;
            //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');
            allElements.floatElement.style='';
            allElements.floatElement.style.position='fixed';
            allElements.floatElement.style.zIndex=zindex;
            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';
            //if(isIframe) allElements.floatElement.contentWindow.document.querySelector('head').insertAdjacentHTML('beforeend','<style type="text/css">.floatingvideo{object-fit: fill!important;}div.dplayer-menu{display:none!important;}</style>');
            //if(isIframe) allElements.videoElement=allElements.floatElement.contentWindow.document.querySelector('video');
            allElements.floatElement.addEventListener("touchstart",touchStartHandler,true);
            allElements.floatElement.addEventListener("mousedown",mouseDownHandler,true);
        }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 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)+'%';

            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) clearTimeout(showMsgT);
        allElements.floatingshowmsg.textContent=msg;
        allElements.floatingshowmsg.style.display='block';
        showMsgT = setTimeout(function() {
            allElements.floatingshowmsg.style.display='none';
        }, 500);
    }

    function floatingVidooAtrr(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');
        //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)';
            /*floatingplayer_setting.style.transform='rotate('+rotate+'deg)';}*/
        }else if(dataname.substring(0,8)=='position'){
            screenPosition=dataname.substring(8);
        }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();
        }
        showFloatingInfo();
    }
    function setVideoRect(dataname,datavalue,value){
        if(dataname=='videorect'){
            //setVideoRect();
        }else if(dataname=='videorect_001' || dataname=='videorect001'){
            screenSizeChange=datavalue;
            screenSize+=datavalue;
            screenSize=screenSize>maxrect?maxrect:(screenSize<0?0:screenSize);
        }else if(dataname=='videorectrange'){
            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=document.documentElement.clientHeight;
                videoratio.height=document.documentElement.clientWidth;
            }else{
                videoratio.width=document.documentElement.clientWidth;
                videoratio.height=document.documentElement.clientHeight;
            }
        }
    }
    function setFloatingVidooRect(){
        var left,top;
        cw=document.documentElement.clientWidth;
        ch=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{
            left=fel-(fw*screenSizeChange)/2;
            top=fet-(fh*screenSizeChange)/2;
        }
        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.floatingbtn.addEventListener("click",function(){
                if(allElements.floatingplayer_setting.style.display=='block'){
                    allElements.floatingplayer_setting.style.display='none';
                }else{
                    allElements.floatingplayer_setting.style.display='block';
                    showFloatingInfo();
                }
            });
            allElements.floatingbtn.addEventListener("touchstart",touchStartHandler,true);
        }else{
            allElements.floatingbtn.addEventListener("mouseover",function(){
                if(allElements.floatingplayer_setting.style.display=='none'){
                    allElements.floatingplayer_setting.style.display='block';
                    showFloatingInfo();
                }
            });
            allElements.floatingbtn.addEventListener("mouseleave",function(){
                if(allElements.floatingplayer_setting.style.display=='block'){
                    mouseoverbtn = setTimeout(function() {
                        allElements.floatingplayer_setting.style.display='none';
                    }, 500);
                }
            });
            allElements.floatingplayer_setting.addEventListener("mouseover",function(){
                if(mouseoverbtn) clearTimeout(mouseoverbtn);
            });
            allElements.floatingplayer_setting.addEventListener("mouseleave",function(){
                if(allElements.floatingplayer_setting.style.display=='block'){
                    mouseoverbtn = setTimeout(function() {
                        allElements.floatingplayer_setting.style.display='none';
                    }, 1000);
                }
            });
            allElements.floatElement.addEventListener("mouseover",feMouseOver,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', floatingVidooAtrr,true);
            }
        }
    }
    function feMouseOver(e){
        mouseInfo.scrollY=window.pageYOffset;
        document.body.classList.add('fixedscroll');
        document.body.style.top = `-${mouseInfo.scrollY}px`;
        allElements.floatElement.addEventListener("mousewheel",feMouseWheel,true);
        allElements.floatElement.addEventListener("mouseleave",feMouseLeave,true);
    }
    function feMouseWheel(e){
        var self=e;
        var deltaY=self.deltaY;
        screenSizeChange=deltaY<0?-0.05:(deltaY>0?0.05:0);
        screenSize+=screenSizeChange;
        screenSize=screenSize>maxrect?maxrect:(screenSize<0?0:screenSize);
        setFloatingVidooRect();
        showMsg((screenSize*100).toFixed(0)+'%');
    }
    function feMouseLeave(e){
        document.body.classList.remove('fixedscroll');
        document.body.style.top = `0px`;
        window.scrollTo({top: mouseInfo.scrollY});
        allElements.floatElement.removeEventListener("mousewheel",feMouseWheel,true);
        allElements.floatElement.removeEventListener("mouseleave",feMouseLeave,true);
    }

    function touchStartHandler(e){
        touchInfo.scrollY=window.pageYOffset;
        document.body.classList.add('fixedscroll');
        document.body.style.top = `-${touchInfo.scrollY}px`;
        cw=document.documentElement.clientWidth;
        ch=document.documentElement.clientHeight;
        var ele=e.target;
        touchInfo.startTouchFingers=e.touches.length;
        touchInfo.touchDownPt=e.touches[0];
        if(ele.id=='floatingbtn'){
            touchInfo.x=cw-ele.offsetLeft-ele.offsetWidth+touchInfo.touchDownPt.clientX;
            touchInfo.y=ch-ele.offsetTop-ele.offsetHeight+touchInfo.touchDownPt.clientY;
        }else{
            touchInfo.x=ele.offsetLeft-touchInfo.touchDownPt.clientX;
            touchInfo.y=ele.offsetTop-touchInfo.touchDownPt.clientY;
        }
        ele.addEventListener("touchend",touchEndHandler,true);
        ele.addEventListener("touchmove",touchMoveHandler,true);
    }
    function touchMoveHandler(e){
        var ele=e.target;
        if(touchInfo.touchDownPt==null) return;
        if(touchInfo.startTouchFingers==1){
            // 单个手指触摸
            var touchPt=e.touches[0];
            if(ele.id=='floatingbtn'){
                var x=touchInfo.x-touchPt.clientX;
                var y=touchInfo.y-touchPt.clientY;
                ele.style.right=x+'px';
                ele.style.bottom=y+'px';
                allElements.floatingplayer_setting.style.right=x+'px';
                allElements.floatingplayer_setting.style.bottom=y+40+'px';
            }else{
                ele.style.left=touchInfo.x+touchPt.clientX+'px';
                ele.style.top=touchInfo.y+touchPt.clientY+'px';
            }
            if(ele.tagName=='VIDEO') screenPosition='default';
        }
    }
    function touchEndHandler(e){
        document.body.classList.remove('fixedscroll');
        document.body.style.top = `0px`;
        window.scrollTo({top: touchInfo.scrollY});
        var ele=e.target;
        touchInfo.startTouchFingers=0;
        touchInfo.touchDownPt=null;
        touchInfo.x=null;
        touchInfo.y=null;
        ele.removeEventListener("touchmove",touchMoveHandler,true);
        ele.removeEventListener("touchend",touchEndHandler,true);
    }
    function mouseDownHandler(e){
        var self=e;
        cw=document.documentElement.clientWidth;
        ch=document.documentElement.clientHeight;
        var ele=e.target;
        if(ele.id=='floatingbtn'){
            mouseInfo.x=cw-ele.offsetLeft-ele.offsetWidth+self.clientX;
            mouseInfo.y=ch-ele.offsetTop-ele.offsetHeight+self.clientY;
        }else{
            mouseInfo.x=ele.offsetLeft-self.clientX;
            mouseInfo.y=ele.offsetTop-self.clientY;
        }
        ele.addEventListener("mouseleave",mouseUpHandler,true);
        ele.addEventListener("mouseup",mouseUpHandler,true);
        ele.addEventListener("mousemove",mouseMoveHandler,true);
    }
    function mouseMoveHandler(e){
        var self=e;
        var ele=e.target;
        if(mouseInfo.x==null) return;
        if(ele.tagName=='VIDEO') screenPosition='default';
        if(ele.id=='floatingbtn'){
            var x=mouseInfo.x-self.clientX;
            var y=mouseInfo.y-self.clientY;
            ele.style.right=x+'px';
            ele.style.bottom=y+'px';
            allElements.floatingplayer_setting.style.right=x+'px';
            allElements.floatingplayer_setting.style.bottom=y+40+'px';
        }else{
            ele.style.left=mouseInfo.x+self.clientX+'px';
            ele.style.top=mouseInfo.y+self.clientY+'px';
        }
    }
    function mouseUpHandler(e){
        var ele=e.target;
        mouseInfo.x=null;
        mouseInfo.y=null;
        ele.removeEventListener("mousemove",mouseMoveHandler,true);
        ele.removeEventListener("mouseleave",mouseMoveHandler,true);
        ele.removeEventListener("mouseup",mouseUpHandler,true);
    }
    // Your code here...
})();