Apple CMS: Dplayer 1.27.0 Memory playback and automatic next episode

In the configuration of Apple cms, the default Dplayer player does not play automatically and does not have a memory playback function. You need to add an option to set the playback page and manually modify the Dplayer code. Currently, the Dplayer player is quite popular on the Internet, and its performance and functions are outstanding. Let's take a look at how to configure the Dplayer player.

Apple CMS sets Dplayer to automatically play the next episode

Dplayer In the configuration of Apple cms, the default player will not play automatically, nor does it have a memory playback function. You need to add an option to set the playback page and manually modify the Dplayer code. Currently, the Dplayer player is quite popular on the Internet, and its performance and functions are quite outstanding. Let's take a look at how to configure the Dplayer player.

Who is Dplayer?

Dplayer is a cute HTML5 barrage video player that helps people easily build videos and barrages.

Dplayer website address:https://dplayer.js.org/

Github project address:https://github.com/DIYgod/DPlayer

Integrate Dplayer player to increase memory, P2P playback and automatically play the next episode of Dplayer player code

Replace the following dplayer player code, replace the directory static/player/dplayer.html of Apple cms system and replace all the contents. FLV support requires flv.js library, and should be loaded before DPlayer.min.js. DPlayer is an HTML5 video player that supports bullet screen. Supports Bilibili video and danmaku, real-time video (HTTP Live Streaming, M3U8 format) and FLV format.

<!DOCTYPE html>
<html>
<head>
    <title>dplayer 1.27.0 Player p2p acceleration + memory playback</title>
    <meta http-equiv="content-type" content="text/html;charset=UTF-8"/>
    <meta http-equiv="content-language" content="zh-CN"/>
    <meta http-equiv="X-UA-Compatible" content="chrome=1"/>
    <meta http-equiv="pragma" content="no-cache"/>
    <meta http-equiv="expires" content="0"/>
    <meta name="referrer" content="never"/>
    <meta name="renderer" content="webkit"/>
    <meta name="msapplication-tap-highlight" content="no"/>
    <meta name="HandheldFriendly" content="true"/>
    <meta name="x5-page-mode" content="app"/>
    <meta content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=no" id="viewport" name="viewport">
    <style type="text/css">
        body,html{width:100%;height:100%;background:#000;padding:0;margin:0;overflow-x:hidden;overflow-y:hidden}
        *{margin:0;border:0;padding:0;text-decoration:none}
        #stats{position:fixed;top:5px;left:8px;font-size:12px;color:#fdfdfd;text-shadow:1px 1px 1px #000, 1px 1px 1px #000}
        #playerCnt{width:100%;height:100%;}
    </style>
    <link rel="stylesheet" href="/static/player/dplayer/DPlayer.min.css">
    <script type="text/javascript" src="/static/player/dplayer/flv.min.js"></script>
    <script type="text/javascript" src="/static/player/dplayer/hls.min.js"></script>
    <script type="text/javascript" src="/static/player/dplayer/dash.all.min.js"></script>
    <script type="text/javascript" src="/static/player/dplayer/webtorrent.min.js"></script>
    <script type="text/javascript" src="/static/player/dplayer/DPlayer.min.js"></script>
</head>
<body style="background:#000" leftmargin="0" topmargin="0" marginwidth="0" marginheight="0" oncontextmenu="window.event.returnValue=false">
<div id="playerCnt"></div>
<div id="stats"></div>
<script language="Javascript">
    document.oncontextmenu=new Function("event.returnValue=false");
    document.onselectstart=new Function("event.returnValue=false");
</script>
<script src="https://cdn.jsdelivr.net/npm/cdnbye@latest"></script>
<script>
    var type='normal';
    var live=false;
    if(parent.MacPlayer.PlayUrl.indexOf('.m3u8')>-1){
        type='hls';
        live=true;
    }
    else if(parent.MacPlayer.PlayUrl.indexOf('magnet:')>-1){
        type='webtorrent';
    }
    else if(parent.MacPlayer.PlayUrl.indexOf('.flv')>-1){
        type='flv';
    }
    else if(parent.MacPlayer.PlayUrl.indexOf('.mpd')>-1){
        type='dash';
    }
    var webdata = {
        set:function(key,val){
            window.sessionStorage.setItem(key,val);
        },
        get:function(key){
            return window.sessionStorage.getItem(key);
        },
        del:function(key){
            window.sessionStorage.removeItem(key);
        },
        clear:function(key){
            window.sessionStorage.clear();
        }
    };
    var _peerId = '', _peerNum = 0, _totalP2PDownloaded = 0, _totalP2PUploaded = 0;
    var dp = new DPlayer({
        container: document.getElementById('playerCnt'),
        autoplay: true, //自动播放视频,不支持移动浏览器
        volume: 1.0, //声音
        preload: 'auto',//预加载的方式可以是'none''metadata''auto',默认值:'auto'
        hotkey: true, //绑定热键,包括左右键和空格,默认值:true
        screenshot: true, //截屏
        theme: '#28FF28',//主题颜色
        video: {
            url: parent.MacPlayer.PlayUrl,//播放地址
            type: 'customHls', //播放协议
            pic: './loading.png', // 视频封面
            customType: {
                'customHls': function (video, player) {
                    const hls = new Hls({
                        debug: false,
                        // Other hlsjsConfig options provided by hls.js
                        p2pConfig: {
                            logLevel: false,
                            live: false,        // 如果是直播设为true
                            // Other p2pConfig options provided by CDNBye
                            getStats: function (totalP2PDownloaded, totalP2PUploaded, totalHTTPDownloaded) {
                                console.warn(totalP2PDownloaded ${totalP2PDownloaded} totalHTTPDownloaded ${totalHTTPDownloaded}; hls.loadSource(video.src); hls.attachMedia(video); } } }, contextmenu: [ //Barrage settings] }); dp.seek(webdata.get(&#039;pay&#039;+parent.MacPlayer.PlayUrl)); setInterval(function(){ webdata.set(&#039;pay&#039;+parent.MacPlayer.PlayUrl,dp.video.currentTime); },1000); dp.on(&#039;stats&#039;, function (stats) { _totalP2PDownloaded = stats.totalP2PDownloaded; _totalP2PUploaded = stats.totalP2PUploaded; updateStats(); }); dp.on(&#039;peerId&#039;, function (peerId) { _peerId = peerId; }); dp.on(&#039;peers&#039;, function (peers) { _peerNum = peers.length; updateStats(); }); dp.on(&#039;ended&#039;, function (){ if(parent.MacPlayer.PlayLinkNext!=&#039;&#039;){ top.location.href = parent.MacPlayer.PlayLinkNext; } }); function updateStats() { var text = &#039;P2P sharing is turned on&#039; + (_totalP2PUploaded/1024).toFixed(2) + &#039;MB&#039; + &#039;Accelerated&#039; + (_totalP2PDownloaded/1024).toFixed(2) + &#039;MB&#039; + &#039;This movie has &#039; + _peerNum + &#039; fans watching it&#039;; document.getElementById(&#039;stats&#039;).innerText = text }
</script>
</body>
</html>

Dplayer playback options

var dp = new DPlayer({ element: document.getElementById('player1'), // Optional, player element autoplay: false, // Optional, autoplay video, not supported on mobile browsers theme: '#FADFA3', // Optional, theme color, default: #b7daff loop: true, // Optional, loop music, default: true lang: 'zh', // Optional, language,zh' is used for Chinese,'For English, default: Navigator language screenshot: true, // Optional, enable screenshot function, default value: false, note: if set to true, video and video screenshot must enable cross-domain hotkey: true, // Optional, bind hotkeys, including left and right keys and space, default value: true preload: 'auto', // Optional, preload method can be 'none' 'metadata' 'auto', default value: 'auto' video: { // Required, video information url: '若能开花光.mp4', // Required, video URL pic: '若能开花光.png' // Optional, video screenshot }, danmaku: { // Optional, show danmaku, ignore this option to hide danmaku id: '9E2E3368B56CDBB4', // Required, danmaku id, note: it must be unique, can't use these in your new player: https://api.prprpr.me/dplayer/list
        api: 'https://api.prprpr.me/dplayer/', // Required, bullet discussion api token: 'tokendemo', // Optional, bullet discussion api token maximum: 1000, // Optional, maximum number of bullet discussion addition: ['https://api.prprpr.me/dplayer/bilibili?aid=4157142'] // Optional, additional bullet discussion, see:Bilibili barrage support
    }
});


Event Binding

dp.on(event, handler)Events: play: Triggered when DPlayer starts playing pause: Triggered when DPlayer is paused canplay: Triggered when there is enough data to play playing: Triggered periodically while DPlayer is playing ended: Triggered when DPlayer ends error: Triggered when an error occurs HLS support (live video, M3U8 format) It requires hls.js library and should be loaded before DPlayer.min.js. Real-time bullet screen is not supported yet.

 

Another player code:

Memory playback can be set by passing parameters via url. It is enabled by default and does not require any settings. It is disabled when nostorage=1 is passed (the resolved domain name is set to /dplayer.php/?nostorage=1&url=)

The settings button in the player is changed to the double-speed play button, and the full-screen button is removed.

The mobile version adds the double-click pause/play function, the left and right swipe screen fast forward/rewind function, and the default screen is horizontal after full screen.

Supported formats: m3u8, mp4
Playback Memory

P2P acceleration (remove P2P information in the video)

Automatically play the next episode (PC only)

Remove the barrage (remove the comments if necessary)

Added guidance on mobile phones to click and play pictures

How to use
Upload the file to your own website (for example, the file name is dplayer.php, upload it to the root directory)

Enable parsing in the Apple CMS backend player settings, and set the parsing domain name to /dplayer.php/?url=

The dplayer code is as follows:

<!DOCTYPE html>
<html>
        <head>
                <title>dplayer增加记忆+P2P播放</title>
                <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
                <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"><!-- IE内核 强制使用最新的引擎渲染网页 -->
                <meta name="renderer" content="webkit">  <!-- 启用360浏览器的极速模式(webkit) -->
                <meta name="viewport" content="width=device-width,initial-scale=1.0,minimum-scale=1.0 ,maximum-scale=1.0, user-scalable=no"><!-- 手机H5兼容模式 -->
                <meta name="x5-fullscreen" content="true" ><meta name="x5-page-mode" content="app" > <!-- X5  全屏处理 -->
                <meta name="full-screen" content="yes"><meta name="browsermode" content="application">  <!-- UC 全屏应用模式 -->
                <meta name=”apple-mobile-web-app-capable” content=”yes”>
                <meta name=”apple-mobile-web-app-status-bar-style” content=”black-translucent” /> <!--  苹果全屏应用模式 -->
                <link rel="stylesheet"  />
        </head>
        <body style="background:#000" leftmargin="0" topmargin="0" marginwidth="0" marginheight="0" oncontextmenu=window.event.returnValue=false>
                <div id="dplayer"></div>
                <div id="stats"></div>
                <div id="play_icon"></div>
                <script src="https://cdn.jsdelivr.net/npm/cdnbye@latest"></script>
                <script src="https://cdn.jsdelivr.net/npm/dplayer@latest"></script>
                <style type="text/css">
                                body,html{width:100%;height:100%;background:#000;padding:0;margin:0;overflow-x:hidden;overflow-y:hidden}
                                *{margin:0;border:0;padding:0;text-decoration:none}
                                #stats{position:fixed;top:5px;left:10px;font-size:10px;color:#fdfdfd;z-index:20719029;text-shadow:1px 1px 1px #000, 1px 1px 1px #000}
                                #dplayer{position:inherit}
                                .dplayer-menu.dplayer-menu-show{display:none}
                                #play_icon { 
                                                background-color: black; 
                                                height:100%;
                                                background-image: url(""); 
                                                background-size: contain; 
                                                background-repeat: no-repeat; 
                                                background-position: center;   
                                                display:flex; 
                                                align-items: center;   
                                                position: absolute; 
                                                top: 0px; 
                                                left: 0px; 
                                                width: 100%;
                                                z-index: 999;
                                }
                                #play_icon img {  
                                                width:10%; 
                                                margin-left: 45%;
                                } 
                </style>
                <script>
                        var url = '<?php echo($_REQUEST['url']);?>';
                        var url = '<?php echo($_REQUEST['url']);?>';
                        var nostorage = '<?php echo($_REQUEST['nostorage']);?>';
                        var isWap = navigator.userAgent.match(/iPad|iPhone|iPod|Baidu/i) != null; //百度浏览器和苹果移动端不使用P2P功能
                        var isMobile = !!navigator.userAgent.match(/AppleWebKit.*Mobile.*/); //是否手机端
                        if(!isWap){
                                if(url.indexOf(".m3u8") > 0){          
                                                var _peerId = '', _peerNum = 0, _totalP2PDownloaded = 0, _totalP2PUploaded = 0;        
                                                var type = 'customHls';
                                }
                                else {
                                                var type = 'normal'; //MP4格式P2P兼容性不好,不调用P2P。
                                }
                                var dp = new DPlayer({
                                        container: document.getElementById('dplayer'),
                                        autoplay: false,
                                        hotkey: true,  // 移动端全屏时向右划动快进,向左划动快退。
                                        airplay: true,
                                        logo: '',
                                        video: {
                                                url:url,
                                                pic: '',  //图片地址。
                                                type: type,
                                                customType: {
                                                        'customHls': function (video, player) {
                                                                const hls = new Hls({
                                                                        debug: false,
                                                                        p2pConfig: {
                                                                                logLevel: true,
                                                                                live: false,        // 如果是直播设为true
                                                                        }
                                                                });
                                                                hls.loadSource(video.src);
                                                                hls.attachMedia(video);
                                                                hls.p2pEngine.on('stats', function (stats) {
                                                                        _totalP2PDownloaded = stats.totalP2PDownloaded;
                                                                        _totalP2PUploaded = stats.totalP2PUploaded;
                                                                        //updateStats();
                                                                }).on('peerId', function (peerId) {
                                                                        _peerId = peerId;
                                                                }).on('peers', function (peers) {
                                                                        _peerNum = peers.length;
                                                                        //updateStats();
                                                                });
  
                                                        }
                                                }
                                        },                        
                                        /*danmaku: {
                                                id: 'E3368B56CDBB4IU',   //弹幕代码,可定义其他的ID,请修改;
                                                api: 'https://dplayer.moerats.com/',
                                                bottom: '25%',
                                                unlimited: false,
                                        }, */            
                                        contextmenu: [
                                        ],
                                        highlight: [
                                                {
                                                        text: '提示:点击下方状态栏可以发送字幕',
                                                        time: 360,
                                                },
                                                {
                                                        text: '警告:请不要相信视频中任何广告与字幕',
                                                        time: 1200,
                                                },
                                        ],
                                });
                                   
                                var webdata = {
                                        set:function(key,val){
                                                window.sessionStorage.setItem(key,val);
                                        },
                                        get:function(key){
                                                return window.sessionStorage.getItem(key);
                                        },
                                        del:function(key){
                                                window.sessionStorage.removeItem(key);
                                        },
                                        clear:function(key){
                                                window.sessionStorage.clear();
                                        }
                                };
                                if (!nostorage)  {
                                        dp.seek(webdata.get('vod'+url));
                                        setInterval(function(){
                                                        webdata.set('vod'+url,dp.video.currentTime);
                                        },1000);
                                }
                                dp.on('ended',function() {
                                        dp.notice("视频播放已结束");                   //可以替换成下一集调用等代码
                                        if(parent.MacPlayer.PlayLinkNext!=''){
                                                top.location.href = parent.MacPlayer.PlayLinkNext;
                                        }
                                });
                                  
                                if (isMobile) {
                                        //全屏事件
                                        dp.on('fullscreen',function() {
                                                screen.orientation.lock("landscape");
                                        });
                                        //退出全屏事件
                                        dp.on('fullscreen_cancel',function() {
                                                screen.orientation.unlock();
                                        });
                                          
                                        //左右滑动快进、后退
                                        let touchPointX = 0;
                                        let touchPointY = 0;
                                        let currentTime = 0;
                                        let isSeeked = false;
                                        document.addEventListener('touchstart', e => {
                                                let touch = e.touches[0];
                                                touchPointX = touch.clientX; // 获取触摸的初始位置
                                                touchPointY = touch.clientY;
                                                currentTime = dp.video.currentTime; // 获得当前播放时间
                                        });        
                                        document.addEventListener('touchmove', e => {
                                                let touch = e.touches[0];
                                                let diffX = touch.clientX - touchPointX; // 通过当前位置与初始位置之差计算改变的距离
                                                let diffY = touch.clientY - touchPointY;
                                                let totalTime = dp.video.duration;
                                                if (Math.abs(diffX) > Math.abs(diffY) && Math.abs(diffX) > 5) {
                                                        let seekTime = parseInt(currentTime + diffX); // 计算出快进时间
                                                        if (seekTime < 0) {
                                                                seekTime = 0;
                                                        }
                                                        if (seekTime > totalTime) {
                                                                seekTime = totalTime;
                                                        }
                                                        dp.seek(seekTime);
                                                        isSeeked = true;
                                                }
                                                let notice = document.getElementsByClassName("dplayer-notice");
                                                if (notice.length > 0) {
                                                        notice[0].style.display = "none";
                                                }
                                        });
                                        document.addEventListener('touchend', e => {
                                                if (isSeeked) {
                                                        let touch = e.changedTouches[0];
                                                        let diffX = touch.clientX - touchPointX;
                                                        let notice = document.getElementsByClassName("dplayer-notice");
                                                        if (notice.length > 0) {
                                                                notice[0].style.display = "block";
                                                        }
                                                        dp.notice((diffX>0?"快进":"快退") + parseInt(Math.abs(diffX)) + "秒", 2000);
                                                }
                                                isSeeked = false;
                                        });        
                                }
                        }
                        else{
                                document.getElementById('dplayer').innerHTML='<video src="'+url+'" controls="controls" preload="preload" poster="" width="100%" height="100%"></video>';
                        }
                        function updateStats() {
                                var text = '七星P2P正在为您加速' + (_totalP2PDownloaded/1024).toFixed(2)
                                                + 'MB 已分享' + (_totalP2PUploaded/1024).toFixed(2) + 'MB' + ' 连接节点' + _peerNum + '个';
                                document.getElementById('stats').innerText = text ;
                        }
                </script>
                <script>
                        var video = document.getElementsByTagName('video')[0];
                        //添加引导点击播放图片
                        var img = new Image();
                        img.src="";
                        document.getElementById("play_icon").appendChild(img);
                        video.setAttribute("playsinline", "true");
                        video.setAttribute("webkit-playsinline", "true");
                        video.setAttribute("x5-video-player-type", "h5");
                        video.setAttribute("x5-video-player-fullscreen", "false");
                        var state = 0;
                        video.onplaying = function(){
                                var icon = document.getElementById("play_icon"); 
                                if (icon) {
                                        icon.remove()
                                }
                                state=1; 
                        };
                        video.onplay = function(){
                                var icon = document.getElementById("play_icon"); 
                                if (icon) {
                                        icon.remove()
                                }
                                state=1; 
                        };
                        video.onpause = function(){
                                state = 0;
                        };
                        var playIcon = document.getElementById("play_icon");
                        if (playIcon.addEventListener) {
                                playIcon.addEventListener('click', function(){    
                                        if(state==0){        
                                                video.play();  
                                        }else {
                                                video.pause(); 
                                        }
                                }, false);
                        }
                          
                        document.addEventListener('dblclick', function(){    
                                if(state==0){        
                                        video.play();  
                                }else {
                                        video.pause(); 
                                }
                        }, false);
                        document.addEventListener("WeixinJSBridgeReady", function () {    
                                        video.play();
                        }, false);
                          
                        //把设置按钮改为速播
                        var settingIcon = document.getElementsByClassName("dplayer-setting-icon")[0];
                        settingIcon.innerHTML="倍速";
                        settingIcon.style.outline="none";
                        settingIcon.style.color="white";
                        settingIcon.style.padding="0 5px";
                        var speedIcon = document.getElementsByClassName("dplayer-setting-speed")[0];
                        settingIcon.onclick = function(){
                                speedIcon.click();
                                //速度选择框为横向显示
                                document.getElementsByClassName("dplayer-setting-box-speed")[0].style.width = "300px";
                                var speendItems = document.getElementsByClassName("dplayer-setting-speed-item");
                                for (let i=0; i<speendItems.length; i++) {
                                        speendItems[i].style.display = "inline";
                                }
                        };
                          
                        //去掉页面全屏按钮
                        document.getElementsByClassName("dplayer-full-in-icon")[0].remove();
                </script>
        </body>
</html>

 

score

Leave a Reply

Your email address will not be published. Required fields are marked *