1
0
mirror of https://github.com/Dreamer-Paul/Pio.git synced 2025-03-27 12:30:34 +08:00

Fix & Update

修复上一版本的所有可见 Bug,并支持前台更换模型。还新增了切换夜间模式、开启时间小贴士等新的功能等你尝试。
This commit is contained in:
奇趣保罗 2018-12-30 22:34:47 +08:00
parent eaf4cb50f7
commit 6015bee6bb
5 changed files with 213 additions and 101 deletions

View File

@ -4,7 +4,7 @@
*
* @package Pio
* @author Dreamer-Paul
* @version 2.0
* @version 2.1
* @link https://paugram.com
*/
@ -39,7 +39,7 @@ class Pio_Plugin implements Typecho_Plugin_Interface{
echo "</div>";
}
paul_update("Pio", "2.0");
paul_update("Pio", "2.1");
// 读取模型文件夹
$models = array();
@ -51,7 +51,7 @@ class Pio_Plugin implements Typecho_Plugin_Interface{
};
// 自定义模型选择
$choose_models = new Typecho_Widget_Helper_Form_Element_Select('choose_models', $models, 'pio', _t('选择模型'), _t('选择插件 Models 目录下的模型,每个模型为一个文件夹,并确定配置文件名为 <a>model.json</a>'));
$choose_models = new Typecho_Widget_Helper_Form_Element_Checkbox('choose_models', $models, 'pio', _t('选择模型'), _t('选择插件 Models 目录下的模型,每个模型为一个文件夹,并确定配置文件名为 <a>model.json</a>'));
$form -> addInput($choose_models);
// 自定义定位
@ -74,6 +74,10 @@ class Pio_Plugin implements Typecho_Plugin_Interface{
$custom_model = new Typecho_Widget_Helper_Form_Element_Text('custom_model', NULL, NULL, _t('自定义配置文件地址'), _t('在这里填入一个模型 JSON 配置文件地址,可供使用外链模型,不填则使用插件目录下的模型'));
$form -> addInput($custom_model);
// 夜间模式函数
$night = new Typecho_Widget_Helper_Form_Element_Text('night', NULL, NULL, _t('夜间模式函数'), _t('如果你的主题支持夜间模式,请在这里填写主题对应的 JS 函数'));
$form -> addInput($night);
// 展现模式
$custom_mode = new Typecho_Widget_Helper_Form_Element_Radio('custom_mode',
array(
@ -93,12 +97,21 @@ class Pio_Plugin implements Typecho_Plugin_Interface{
'0', _t('浏览体验'), _t('是否在手机版上隐藏看板娘'));
$form -> addInput($hidden);
// 是否开启时间小贴士
$tips = new Typecho_Widget_Helper_Form_Element_Radio('tips',
array(
'0' => _t('关闭'),
'1' => _t('开启'),
),
'0', _t('时间小贴士'), _t('是否开启时间小贴士,在没有访问来源的情况下展示,将覆盖入站提示'));
$form -> addInput($tips);
// 自定义文字配置
$talk_content = new Typecho_Widget_Helper_Form_Element_Textarea('talk_content', NULL, '{}', _t('自定义提示内容'), _t('在这里填入你的自定义看板娘提示内容,如想保持默认,需要填写 "{}" 否则会导致插件无法运行'));
$form -> addInput($talk_content);
$dialog = new Typecho_Widget_Helper_Form_Element_Textarea('dialog', NULL, NULL, _t('自定义提示内容'), _t('在这里填入你的自定义看板娘提示内容,如想保持默认,需要填写 "{}" 否则会导致插件无法运行'));
$form -> addInput($dialog);
// 自定义选择器配置
$selector = new Typecho_Widget_Helper_Form_Element_Textarea('selector', NULL, '{}', _t('自定义内容选择器'), _t('在这里填入部分功能所用到的自定义选择器,如不想启用此类功能,需要填写 "{}" 否则会导致插件无法运行'));
$selector = new Typecho_Widget_Helper_Form_Element_Textarea('selector', NULL, NULL, _t('自定义内容选择器'), _t('在这里填入部分功能所用到的自定义选择器,如不想启用此类功能,需要填写 "{}" 否则会导致插件无法运行'));
$form -> addInput($selector);
}
@ -107,62 +120,110 @@ class Pio_Plugin implements Typecho_Plugin_Interface{
/* 插件实现方法 */
public static function header(){
echo "<link href='" . Helper::options() -> pluginUrl . "/Pio/static/pio.css' rel='stylesheet' type='text/css'/>\n";
$pos = Typecho_Widget::widget('Widget_Options') -> Plugin('Pio') -> position;
echo "<style>.pio-container{ $pos: 0 }</style>";
echo("<link href='" . Helper::options() -> pluginUrl . "/Pio/static/pio.css' rel='stylesheet' type='text/css'/>\n");
}
public static function footer(){
// 生成画布
function getCanvas(){
$height = Typecho_Widget::widget('Widget_Options') -> Plugin('Pio') -> custom_height;
$width = Typecho_Widget::widget('Widget_Options') -> Plugin('Pio') -> custom_width;
$width = Typecho_Widget::widget('Widget_Options') -> Plugin('Pio') -> custom_width;
if(!$width){ $width = 280; }
if(!$height){ $height = 250; }
return '<canvas id="pio" width="' . (!$width ? 280 : $width) . '" height="' . (!$height ? 250: $height) . '"></canvas>';
}
return "<canvas id='pio' width='".$width."' height='".$height."'></canvas>";
// 生成配置
function getConfig(){
$plugin = Typecho_Widget::widget('Widget_Options') -> Plugin('Pio');
$mode = $plugin -> custom_mode;
$hidden = $plugin -> hidden == 1 ? true : false;
$tips = $plugin -> tips == 1 ? true : false;
$content = $plugin -> dialog ? json_decode($plugin -> dialog, true) : "{}";
$selector = $plugin -> selector ? json_decode($plugin -> selector, true) : "{}";
if($plugin -> custom_model){
$model = array($plugin -> custom_model);
}
else if($plugin -> choose_models){
$model = $plugin -> choose_models;
if(is_array($model)){
foreach($model as &$item){
$item = Helper::options() -> pluginUrl . "/Pio/models/" . $item . "/model.json";
}
}
else{
$model = array(Helper::options() -> pluginUrl . "/Pio/models/" . $model . "/model.json");
}
}
else{
$model = array(Helper::options() -> pluginUrl . "/Pio/models/pio/model.json");
}
if($plugin -> night){
$night = $plugin -> night;
}
else{
$night = false;
}
return str_replace(
array("{mode}", "{hidden}", "{content}", "{selector}", "{model}", "{night}"),
array("mode:'" . $mode . "'", "hidden:" . $hidden, "content:" . $content, "selector:" . $selector, "model:" . $model, "night:" . $night),
"{mode},{hidden},{content},{selector},{model},{night}"
);
}
// 生成载入器
function getLoader(){
$config = array();
$plug = Typecho_Widget::widget('Widget_Options') -> Plugin('Pio');
$plugin = Typecho_Widget::widget('Widget_Options') -> Plugin('Pio');
if($plug -> custom_model){
$model = $plug -> custom_model;
$config = array(
"mode" => $plugin -> custom_mode,
"hidden" => $plugin -> hidden == 1 ? true : false,
"content" => $plugin -> dialog ? json_decode($plugin -> dialog, true) : "{}",
"selector" => $plugin -> selector ? json_decode($plugin -> selector, true) : "{}"
);
if($plugin -> custom_model){
$model = array($plugin -> custom_model);
}
else if($plug -> choose_models){
$model = Helper::options() -> pluginUrl . "/Pio/models/" . $plug -> choose_models . "/model.json";
else if($plugin -> choose_models){
$model = $plugin -> choose_models;
if(is_array($model)){
foreach($model as &$item){
$item = Helper::options() -> pluginUrl . "/Pio/models/" . $item . "/model.json";
}
}
else{
$model = array(Helper::options() -> pluginUrl . "/Pio/models/" . $model . "/model.json");
}
}
else{
$model = Helper::options() -> pluginUrl . "/Pio/models/pio/model.json";
$model = array(Helper::options() -> pluginUrl . "/Pio/models/pio/model.json");
}
$config["mode"] = $plug -> custom_mode;
$config["hidden"] = $plug -> hidden == 1 ? true : false;
if($plugin -> night){
$config["night"] = $plugin -> night;
}
$config["model"] = array();
$config["model"][0] = $model;
$config["content"] = json_decode($plug -> talk_content, true);
$config["selector"] = json_decode($plug -> selector, true);
if($plugin -> tips){
$config["tips"] = true;
}
return '<script>var pio = new poster_girl(' . json_encode($config, JSON_UNESCAPED_SLASHES) . ');</script>';
$config["model"] = $model;
return '<script>var pio = new Paul_Girl(' . json_encode($config, JSON_UNESCAPED_SLASHES) . ');</script>';
}
$canvas = getCanvas();
$loader = getLoader();
$position = Typecho_Widget::widget('Widget_Options') -> Plugin('Pio') -> position == "left" ? " left" : " right";
echo <<< Pio
<div class="pio-container">
<div class="action-menu">
<span class="home"></span>
<span class="skin"></span>
<span class="info"></span>
<span class="close"></span>
</div>
$canvas
</div>
Pio;
echo str_replace(array("{position}", "{canvas}"), array($position, $canvas),
'<div class="pio-container{position}"><div class="pio-action"></div>{canvas}</div>'
);
echo "<script src='" . Helper::options() -> pluginUrl . "/Pio/static/l2d.js'></script>" . "\n";
echo "<script src='" . Helper::options() -> pluginUrl . "/Pio/static/pio.js'></script>" . "\n";

View File

@ -5,12 +5,12 @@
## 使用方法
1. Star 本项目
2. Clone 本项目
2. 从这里 [下载](https://github.com/Dreamer-Paul/Pio/archive/master.zip) 本插件
3. 将插件文件夹重命名为 `Pio`
4. 上传本插件,并放置在 `usr/plugins/` 目录下
5. 登录你的 Typecho 后台,并进行安装即可食用~
5. 登录你的 Typecho 后台,选择启用插件即可食用~
6. 如果你有自己的模型,可以将模型放在 `models` 目录下,并在插件设置里选择(需要确认模型的配置文件名称是否为 `model.json`)。或是在插件设置填写一个绝对链接
7. 保罗自己搭建了一个模型资源收集站点 - [梦象](https://mx.paugram.com),你可以在这里下载到更多的模型,如果你有能力的话欢迎为我提供更多资源~
7. 保罗自己搭建了一个模型资源收集站点 - [梦象](https://mx-model.ga),你可以在这里下载到更多的模型,如果你有能力的话欢迎为我提供更多资源~
## 项目故事
详见我的博文:[给你的博客增加动态看板娘](https://paugram.com/coding/add-poster-girl-with-plugin.html)

File diff suppressed because one or more lines are too long

View File

@ -2,7 +2,7 @@
# Pio Plugin
# By: Dreamer-Paul
# Last Update: 2018.10.12
# Last Update: 2018.12.30
一个支持换模型的 Live2D 插件 Typecho 使用
@ -11,25 +11,26 @@
---- */
.pio-container{
left: 0;
bottom: 0;
z-index: 52;
position: fixed;
user-select: none;
}
.pio-container.left{ left: 0 }
.pio-container.right{ right: 0 }
.pio-container.active{ cursor: move }
.pio-container.static{ pointer-events: none }
.pio-container .action-menu{
.pio-container .pio-action{
top: 3em;
right: 0;
opacity: 0;
position: absolute;
transition: opacity .3s;
}
.pio-container:hover .action-menu{ opacity: 1 }
.pio-container:hover .pio-action{ opacity: 1 }
.pio-container .action-menu span{
.pio-action span{
color: #fff;
width: 1.5em;
height: 1.5em;
@ -41,19 +42,22 @@
border: 1px solid #666;
background: #fff center/70% no-repeat;
}
.pio-container .action-menu .home{
.pio-action .pio-home{
background-image: url();
}
.pio-container .action-menu .close{
.pio-action .pio-close{
background-image: url();
}
.pio-container .action-menu .skin{
.pio-action .pio-skin{
background-image: url();
}
.pio-container .action-menu .info{
.pio-action .pio-info{
background-image: url();
}
.pio-container .dialog{
.pio-action .pio-night{
background-image: url();
}
.pio-container .pio-dialog{
top: -2em;
left: 1em;
right: 1em;
@ -69,7 +73,7 @@
border: 1px solid #eee;
transition: opacity .3s, visibility .3s;
}
.pio-container .dialog.active{
.pio-container .pio-dialog.active{
opacity: 1;
visibility: visible;
}
@ -79,5 +83,5 @@
@media screen and (max-width: 768px){
#pio{ width: 8em }
.pio-container{ pointer-events: none }
.pio-container.hidden, .pio-container .action-menu, .pio-container .dialog{ display: none }
.pio-container.hidden, .pio-action, .pio-dialog{ display: none }
}

View File

@ -2,7 +2,7 @@
# Pio Plugin
# By: Dreamer-Paul
# Last Update: 2018.10.12
# Last Update: 2018.12.30
一个支持换模型的 Live2D 插件 Typecho 使用
@ -10,25 +10,15 @@
---- */
var poster_girl = function (prop) {
var Paul_Girl = function (prop) {
var current = {
idol: 0,
menu: document.querySelector(".pio-container .pio-action"),
canvas: document.getElementById("pio"),
body: document.getElementsByClassName("pio-container")[0],
root: document.location.protocol +'//' + document.location.hostname +'/'
};
var elements = {
home: current.body.getElementsByClassName("home")[0],
skin: current.body.getElementsByClassName("skin")[0],
info: current.body.getElementsByClassName("info")[0],
close: current.body.getElementsByClassName("close")[0]
};
var dialog = document.createElement("div");
dialog.className = "dialog";
current.body.appendChild(dialog);
/* - 方法 */
var modules = {
// 更换模型
@ -36,6 +26,12 @@ var poster_girl = function (prop) {
current.idol < (prop.model.length - 1) ? current.idol++ : current.idol = 0;
return current.idol;
},
// 创建内容
create: function (tag, prop) {
var e = document.createElement(tag);
if(prop.class) e.className = prop.class;
return e;
},
// 随机内容
rand: function (arr) {
return arr[Math.floor(Math.random() * arr.length + 1) - 1];
@ -65,6 +61,17 @@ var poster_girl = function (prop) {
}
};
var elements = {
home: modules.create("span", {class: "pio-home"}),
skin: modules.create("span", {class: "pio-skin"}),
info: modules.create("span", {class: "pio-info"}),
night: modules.create("span", {class: "pio-night"}),
close: modules.create("span", {class: "pio-close"})
};
var dialog = modules.create("div", {class: "pio-dialog"});
current.body.appendChild(dialog);
/* - 提示操作 */
var action = {
// 欢迎
@ -72,10 +79,43 @@ var poster_girl = function (prop) {
if(document.referrer !== "" && document.referrer.indexOf(current.root) === -1){
var referrer = document.createElement('a');
referrer.href = document.referrer;
prop.content.welcome && prop.content.welcome[1] ? modules.render(prop.content.welcome[1].replace(/%t/, "“" + referrer.hostname + "”")) : modules.render("欢迎来自 “" + document.referrer + "” 的朋友!");
prop.content.referer ? modules.render(prop.content.referer.replace(/%t/, "“" + referrer.hostname + "”")) : modules.render("欢迎来自 “" + document.referrer + "” 的朋友!");
}
else if(prop.tips){
var text, hour = new Date().getHours();
if (hour > 22 || hour <= 5) {
text = '你是夜猫子呀?这么晚还不睡觉,明天起的来嘛';
}
else if (hour > 5 && hour <= 8) {
text = '早上好!';
}
else if (hour > 8 && hour <= 11) {
text = '上午好!工作顺利嘛,不要久坐,多起来走动走动哦!';
}
else if (hour > 11 && hour <= 14) {
text = '中午了,工作了一个上午,现在是午餐时间!';
}
else if (hour > 14 && hour <= 17) {
text = '午后很容易犯困呢,今天的运动目标完成了吗?';
}
else if (hour > 17 && hour <= 19) {
text = '傍晚了!窗外夕阳的景色很美丽呢,最美不过夕阳红~';
}
else if (hour > 19 && hour <= 21) {
text = '晚上好,今天过得怎么样?';
}
else if (hour > 21 && hour <= 23) {
text = '已经这么晚了呀,早点休息吧,晚安~';
}
else{
text = "保罗说:这是无法被触发的吧";
}
modules.render(text);
}
else{
prop.content.welcome && prop.content.welcome[0] ? modules.render(prop.content.welcome[0]) : modules.render("欢迎来到保罗的小窝!");
prop.content.welcome ? modules.render(prop.content.welcome) : modules.render("欢迎来到本站");
}
},
// 文章
@ -107,47 +147,53 @@ var poster_girl = function (prop) {
// 右侧按钮
buttons: function () {
// 返回首页
if(elements.home){
elements.home.onclick = function () {
location.href = current.root;
};
elements.home.onmouseover = function () {
prop.content.home ? modules.render(prop.content.home) : modules.render("点击这里回到首页!");
};
}
elements.home.onclick = function () {
location.href = current.root;
};
elements.home.onmouseover = function () {
prop.content.home ? modules.render(prop.content.home) : modules.render("点击这里回到首页!");
};
current.menu.appendChild(elements.home);
// 更换模型
if(elements.skin){
elements.skin.onclick = function () {
loadlive2d("pio", prop.model[modules.idol()]);
prop.content.skin && prop.content.skin[1] ? modules.render(prop.content.skin[1]) : modules.render("新衣服真漂亮~");
};
elements.skin.onmouseover = function () {
prop.content.skin && prop.content.skin[0] ? modules.render(prop.content.skin[0]) : modules.render("想看看我的新衣服吗?");
};
}
elements.skin.onclick = function () {
loadlive2d("pio", prop.model[modules.idol()]);
prop.content.skin && prop.content.skin[1] ? modules.render(prop.content.skin[1]) : modules.render("新衣服真漂亮~");
};
elements.skin.onmouseover = function () {
prop.content.skin && prop.content.skin[0] ? modules.render(prop.content.skin[0]) : modules.render("想看看我的新衣服吗?");
};
if(prop.model.length > 1) current.menu.appendChild(elements.skin);
// 关于我
if(elements.info){
elements.info.onclick = function () {
window.open("https://paugram.com/coding/add-poster-girl-with-plugin.html");
elements.info.onclick = function () {
prop.content.link ? window.open(prop.content.link) : window.open("https://paugram.com/coding/add-poster-girl-with-plugin.html");
};
elements.info.onmouseover = function () {
modules.render("想了解更多关于我的信息吗?");
};
current.menu.appendChild(elements.info);
// 夜间模式
if(prop.night){
elements.night.onclick = function () {
eval(prop.night);
};
elements.info.onmouseover = function () {
modules.render("想了解更多关于我的信息吗?");
elements.night.onmouseover = function () {
modules.render("夜间点击这里可以保护眼睛呢");
};
current.menu.appendChild(elements.night);
}
// 关闭看板娘
if(elements.close){
elements.close.onclick = function () {
modules.destroy();
};
elements.close.onmouseover = function () {
prop.content.close ? modules.render(prop.content.close) : modules.render("QWQ 下次再见吧~");
};
document.cookie = "posterGirl=false;" + "path=/";
}
elements.close.onclick = function () {
modules.destroy();
};
elements.close.onmouseover = function () {
prop.content.close ? modules.render(prop.content.close) : modules.render("QWQ 下次再见吧~");
};
current.menu.appendChild(elements.close);
document.cookie = "posterGirl=false;" + "path=/";
}
};
@ -172,6 +218,7 @@ var poster_girl = function (prop) {
function move(e) {
body.classList.add("active");
body.classList.remove("right");
body.style.left = (event.clientX - location.x) + 'px';
body.style.top = (event.clientY - location.y) + 'px';
}