Skip to content

Commit

Permalink
support pjax
Browse files Browse the repository at this point in the history
  • Loading branch information
volio committed Jan 12, 2020
1 parent acc422b commit 26c6bd9
Show file tree
Hide file tree
Showing 7 changed files with 108 additions and 128 deletions.
133 changes: 58 additions & 75 deletions Plugin.php
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,8 @@
*
* @package DPlayer
* @author Volio
* @version 1.0.4
* @link http://github.com/volio/DPlayer-for-typecho
* @version 1.1.0
* @link https://niconiconi.org
*/
class DPlayer_Plugin implements Typecho_Plugin_Interface
{
Expand All @@ -20,8 +20,8 @@ class DPlayer_Plugin implements Typecho_Plugin_Interface
*/
public static function activate()
{
Typecho_Plugin::factory('Widget_Abstract_Contents')->contentEx = ['DPlayer_Plugin', 'parsePlayer'];
Typecho_Plugin::factory('Widget_Abstract_Contents')->excerptEx = ['DPlayer_Plugin', 'parsePlayer'];
Typecho_Plugin::factory('Widget_Abstract_Contents')->contentEx = ['DPlayer_Plugin', 'replacePlayer'];
Typecho_Plugin::factory('Widget_Abstract_Contents')->excerptEx = ['DPlayer_Plugin', 'replacePlayer'];
Typecho_Plugin::factory('Widget_Archive')->header = ['DPlayer_Plugin', 'playerHeader'];
Typecho_Plugin::factory('Widget_Archive')->footer = ['DPlayer_Plugin', 'playerFooter'];
Typecho_Plugin::factory('admin/write-post.php')->bottom = ['DPlayer_Plugin', 'addEditorButton'];
Expand All @@ -44,10 +44,8 @@ public static function deactivate()
*/
public static function playerHeader()
{
$url = Helper::options()->pluginUrl . '/DPlayer';
echo <<<EOF
<link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/npm/dplayer/dist/DPlayer.min.css" />
<script>var dPlayerOptions = [];</script>
EOF;
}

Expand All @@ -66,29 +64,26 @@ public static function playerFooter()
}
echo <<<EOF
<script type="text/javascript" src="https://cdn.jsdelivr.net/npm/dplayer/dist/DPlayer.min.js"></script>
<script type="text/javascript" src="$url/dist/util.js"></script>
<script type="text/javascript" src="$url/assets/player.js"></script>
EOF;
}

/**
* 内容标签替换
*
* @param string $content
* @param $text
* @param $widget
* @param $lastResult
* @param $last
* @return string
*/
public static function parsePlayer($content, $widget, $lastResult)
public static function replacePlayer($text, $widget, $last)
{
$content = empty($lastResult) ? $content : $lastResult;
$text = empty($last) ? $text : $last;
if ($widget instanceof Widget_Archive) {
if (false === strpos($content, '[')) {
return $content;
}
$pattern = self::get_shortcode_regex(['dplayer']);
$content = preg_replace_callback("/$pattern/", ['DPlayer_Plugin', 'parseCallback'], $content);
$text = preg_replace_callback("/$pattern/", ['DPlayer_Plugin', 'parseCallback'], $text);
}
return $content;
return $text;
}

/**
Expand All @@ -114,87 +109,75 @@ public static function parseCallback($matches)
}
//还原转义后的html
//[dplayer title=&quot;Test Abc&quot; artist=&quot;haha&quot; id=&quot;1234543&quot;/]
$attr = htmlspecialchars_decode($matches[3]);
$tag = htmlspecialchars_decode($matches[3]);
//[dplayer]标签的属性,类型为array
$atts = self::shortcode_parse_atts($attr);
//播放器id
$id = md5(isset($atts['url']) ? $atts['url'] : 'default id');
$attrs = self::shortcode_parse_atts($tag);
return DPlayer_Plugin::parsePlayer($attrs);
}

public static function parsePlayer($attrs)
{
//播放器设置
$theme = Typecho_Widget::widget('Widget_Options')->plugin('DPlayer')->theme;
$theme = Typecho_Widget::widget('Widget_Options')->plugin('DPlayer')->theme ?: '#FADFA3';
$api = Typecho_Widget::widget('Widget_Options')->plugin('DPlayer')->api;
if (!$theme) $theme = '#FADFA3';

//输出代码
$playerCode = '<div id="player' . $id . '" class="dplayer">';
$playerCode .= "</div>\n";

$video = array(
'url' => isset($atts['url']) ? $atts['url'] : '',
'pic' => isset($atts['pic']) ? $atts['pic'] : '',
'type' => isset($atts['type']) ? $atts['type'] : 'auto',
'thumbnails' => isset($atts['thumbnails']) ? $atts['thumbnails'] : '',
);
//弹幕部分配置文件
$subtitle = [
'url' => isset($atts['subtitleurl']) ? $atts['subtitleurl'] : '',
'type' => isset($atts['subtitletype']) ? $atts['subtitletype'] : 'webvtt',
'fontSize' => isset($atts['subtitlefontsize']) ? $atts['subtitlefontsize'] : '25px',
'bottom' => isset($atts['subtitlebottom']) ? $atts['subtitlebottom'] : '10%',
'color' => isset($atts['subtitlecolor']) ? $atts['subtitlecolor'] : '#b7daff',
];
$danmaku = [
'id' => $id,
'api' => $api,
'maximum' => isset($atts['maximum']) ? $atts['maximum'] : 1000,
'addition' => isset($atts['addition']) ? [$atts['addition']] : null,
'user' => isset($atts['user']) ? $atts['user'] : 'DIYgod',
'bottom' => isset($atts['bottom']) ? $atts['bottom'] : '15%',
'unlimited' => true,
];

//播放器默认属性
$data = [
'id' => $id,
//播放器属性
$config = [
'live' => false,
'autoplay' => false,
'theme' => isset($atts['theme']) ? $atts['theme'] : '#FADFA3',
'loop' => (isset($atts['loop']) && $atts['loop'] == 'true') ? true : false,
'screenshot' => (isset($atts['screenshot']) && $atts['screenshot'] == 'true') ? true : false,
'autoplay' => isset($attrs['autoplay']) && $attrs['autoplay'] == 'true',
'theme' => isset($attrs['theme']) ? $attrs['theme'] : $theme,
'loop' => isset($attrs['loop']) && $attrs['loop'] == 'true',
'screenshot' => isset($attrs['screenshot']) && $attrs['screenshot'] == 'true',
'hotkey' => true,
'preload' => 'metadata',
'lang' => isset($atts['lang']) ? $atts['lang'] : 'zh-cn',
'logo' => isset($atts['logo']) ? $atts['logo'] : null,
'volume' => isset($atts['volume']) ? $atts['volume'] : 0.7,
'lang' => isset($attrs['lang']) ? $attrs['lang'] : 'zh-cn',
'logo' => isset($attrs['logo']) ? $attrs['logo'] : null,
'volume' => isset($attrs['volume']) ? $attrs['volume'] : 0.7,
'mutex' => true,
'video' => [
'url' => isset($attrs['url']) ? $attrs['url'] : null,
'pic' => isset($attrs['pic']) ? $attrs['pic'] : null,
'type' => isset($attrs['type']) ? $attrs['type'] : 'auto',
'thumbnails' => isset($attrs['thumbnails']) ? $attrs['thumbnails'] : null,
],
];
$data['video'] = $video;
$data['danmaku'] = (isset($atts['danmu']) && $atts['danmu'] == 'true') ? $danmaku : null;
$data['subtitle'] = isset($atts['subtitleurl']) ? $subtitle : null;
$data['autoplay'] = (isset($atts['autoplay']) && $atts['autoplay'] == 'true') ? true : false;
$data['theme'] = isset($atts['theme']) ? $atts['theme'] : $theme;
//加入头部数组
$js = json_encode($data);
$playerCode .= <<<EOF
<script>dPlayerOptions.push({$js});</script>
EOF;
return $playerCode;
if (isset($attrs['danmu']) && $attrs['danmu'] == 'true') {
$config['danmaku'] = [
'id' => md5(isset($attrs['url']) ? $attrs['url'] : ''),
'api' => $api,
'maximum' => isset($attrs['maximum']) ? $attrs['maximum'] : 1000,
'user' => isset($attrs['user']) ? $attrs['user'] : 'DIYgod',
'bottom' => isset($attrs['bottom']) ? $attrs['bottom'] : '15%',
'unlimited' => true,
];
}
if (isset($attrs['subtitle']) && $attrs['subtitle'] == 'true') {
$config['subtitle'] = [
'url' => isset($attrs['subtitleurl']) ? $attrs['subtitleurl'] : null,
'type' => isset($attrs['subtitletype']) ? $attrs['subtitletype'] : 'webvtt',
'fontSize' => isset($attrs['subtitlefontsize']) ? $attrs['subtitlefontsize'] : '25px',
'bottom' => isset($attrs['subtitlebottom']) ? $attrs['subtitlebottom'] : '10%',
'color' => isset($attrs['subtitlecolor']) ? $attrs['subtitlecolor'] : '#b7daff',
];
}
$json = json_encode($config);
return "<div class=\"dplayer\" data-config='{$json}'></div>";
}

public static function addEditorButton()
{
$dir = Helper::options()->pluginUrl . '/DPlayer/dist/editor.js';
$dir = Helper::options()->pluginUrl . '/DPlayer/assets/editor.js';
echo "<script type=\"text/javascript\" src=\"{$dir}\"></script>";
}

public static function config(Typecho_Widget_Helper_Form $form)
{
$theme = new Typecho_Widget_Helper_Form_Element_Text(
'theme', null, '#FADFA3',
_t('默认主题颜色'), _t('播放器默认的主题颜色, #372e21、#75c、red、blue,该设定会被[dplayer]标签中的theme属性覆盖,默认为 #FADFA3'));
_t('默认主题颜色'), _t('播放器默认的主题颜色,例如 #372e21、#75c、red、blue,该设定会被[dplayer]标签中的theme属性覆盖,默认为 #FADFA3'));
$api = new Typecho_Widget_Helper_Form_Element_Text(
'api', null, 'https://api.prprpr.me/dplayer/v3/',
_t('弹幕服务器地址'), _t('用于保存视频弹幕,默认为 https://api.prprpr.me/dplayer/v3/'));
'api', null, '',
_t('弹幕服务器地址'), _t('用于保存视频弹幕,例如 https://api.prprpr.me/dplayer/v3/'));
$hls = new Typecho_Widget_Helper_Form_Element_Radio('hls', array('0' => _t('不开启HLS支持'), '1' => _t('开启HLS支持')), '0', _t('HLS支持'), _t("开启后可解析 m3u8 格式视频"));
$flv = new Typecho_Widget_Helper_Form_Element_Radio('flv', array('0' => _t('不开启FLV支持'), '1' => _t('开启FLV支持')), '0', _t('FLV支持'), _t("开启后可解析 flv 格式视频"));
$form->addInput($theme);
Expand Down
17 changes: 10 additions & 7 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,23 +9,26 @@
[dplayer url="http://xxx.com/xxx.mp4" pic="http://xxx.com/xxx.jpg"/]
```

关闭弹幕
开启弹幕
```
[dplayer url="http://xxx.com/xxx.mp4" pic="http://xxx.com/xxx.jpg" danmu="false"/]
[dplayer url="http://xxx.com/xxx.mp4" pic="http://xxx.com/xxx.jpg" danmu="true"/]
```

开启自动播放
```
[dplayer url="http://xxx.com/xxx.mp4" pic="http://xxx.com/xxx.jpg" autoplay="true"/]
```

添加额外弹幕源(例:bilibili弹幕)
更多参数待补充

### FAQ

#### 1. Pjax页面切换?

重新加载播放器回调函数
```
[dplayer url="http://xxx.com/xxx.mp4" pic="http://xxx.com/xxx.jpg" autoplay="true" addition="https://api.prprpr.me/dplayer/bilibili?aid=7286894"/]
loadDPlayer();
```

### 设置截图
![](https://raw.githubusercontent.com/volio/DPlayer-for-typecho/master/assets/screenshot.png)

### LICENSE
MIT © [Volio](https://niconiconi.org)
50 changes: 24 additions & 26 deletions dist/editor.js → assets/editor.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,14 +6,14 @@ $(function () {
$(document).on('click', '#wmd-dplayer-button', function () {
$('body').append(
'<div id="DPlayer-Panel">' +
'<div class="wmd-prompt-background" style="position: absolute; top: 0px; z-index: 1000; opacity: 0.5; height: 875px; left: 0px; width: 100%;"></div>' +
'<div class="wmd-prompt-background" style="position: absolute; top: 0; z-index: 1000; opacity: 0.5; height: 875px; left: 0; width: 100%;"></div>' +
'<div class="wmd-prompt-dialog">' +
'<div>' +
'<p><b>插入视频</b></p>' +
'<p>在下方输入参数</p>' +
'<p><input type="text" id="DP-url" value="" placeholder="链接"></input></p>' +
'<p><input type="text" id="DP-pic" value="" placeholder="封面图"></input></p>' +
'<p><input type="text" id="DP-addition" value="" placeholder="额外弹幕源"></input></p>' +
'<p><input type="text" id="DP-url" value="" placeholder="链接"/></p>' +
'<p><input type="text" id="DP-pic" value="" placeholder="封面图"/></p>' +
'<p><input type="text" id="DP-addition" value="" placeholder="额外弹幕源"/></p>' +
'<p><input type="checkbox" id="DP-danmu" checked>开启弹幕</input></p>' +
'<p><input type="checkbox" id="DP-autoplay">自动播放</input></p>' +
'</div>' +
Expand All @@ -31,40 +31,38 @@ $(function () {
});
//ok
$(document).on('click', '#ok', function () {
var DP_url = document.getElementById('DP-url').value,
DP_pic = document.getElementById('DP-pic').value,
DP_danmu = document.getElementById('DP-danmu').checked ? true : false,
DP_autoplay = document.getElementById('DP-autoplay').checked ? true : false,
DP_addition = document.getElementById('DP-addition').value;
var tag = '[dplayer url="' + DP_url + '" pic="' + DP_pic + '" ';
if (!DP_danmu) tag += 'danmu="' + DP_danmu + '" ';
if (DP_autoplay) tag += 'autoplay="' + DP_autoplay + '" ';
if (DP_addition) tag += 'addition="' + DP_addition + '" ';
var url = document.getElementById('DP-url').value,
pic = document.getElementById('DP-pic').value,
danmu = !!document.getElementById('DP-danmu').checked,
autoplay = !!document.getElementById('DP-autoplay').checked;
var tag = '[dplayer url="' + url + '" pic="' + pic + '" ';
if (!danmu) tag += 'danmu="' + danmu + '" ';
if (autoplay) tag += 'autoplay="' + autoplay + '" ';
tag += '/]\n';

myField = document.getElementById('text');
var editor = document.getElementById('text');

if (document.selection) {
myField.focus();
editor.focus();
sel = document.selection.createRange();
sel.text = tag;
myField.focus();
editor.focus();
}
else if (myField.selectionStart || myField.selectionStart == '0') {
var startPos = myField.selectionStart;
var endPos = myField.selectionEnd;
else if (editor.selectionStart || editor.selectionStart === '0') {
var startPos = editor.selectionStart;
var endPos = editor.selectionEnd;
var cursorPos = startPos;
myField.value = myField.value.substring(0, startPos)
editor.value = editor.value.substring(0, startPos)
+ tag
+ myField.value.substring(endPos, myField.value.length);
+ editor.value.substring(endPos, myField.value.length);
cursorPos += tag.length;
myField.focus();
myField.selectionStart = cursorPos;
myField.selectionEnd = cursorPos;
editor.focus();
editor.selectionStart = cursorPos;
editor.selectionEnd = cursorPos;
}
else {
myField.value += tag;
myField.focus();
editor.value += tag;
editor.focus();
}

$('#DPlayer-Panel').remove();
Expand Down
16 changes: 16 additions & 0 deletions assets/player.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
var dPlayers = [];
var loadDPlayer = function () {
var load = function (d, conf) {
conf.container = d;
dPlayers.push(new DPlayer(conf));
};
for (var i = 0; i < dPlayers.length; i++) {
dPlayers[i].destroy();
}
dPlayers = [];
for (var j = 0, k = document.querySelectorAll('.dplayer'); j < k.length; j++) {
load(k[j], JSON.parse(k[j].dataset.config));
}
};

document.addEventListener('DOMContentLoaded', loadDPlayer, !1);
Binary file removed assets/screenshot.png
Binary file not shown.
Binary file removed assets/screenshot_editor.png
Binary file not shown.
20 changes: 0 additions & 20 deletions dist/util.js

This file was deleted.

0 comments on commit 26c6bd9

Please sign in to comment.