mirror of
https://github.com/jerryc127/hexo-theme-butterfly.git
synced 2026-04-17 04:40:53 +08:00
Breaking change 1. 手機端界面卡片化,同時,手機端也可以顯示側邊欄的內容 2. 修復當menu過多時,header界面出現錯亂的bug。當menu過多時,會變為sidebar模式 3. 增加medium-zoom大圖查看模式 4. 增加鼠標點擊特效:文字和愛心 兩個點擊特效 5. 主頁subtitle可以調用第三方api(金山詞霸每日一句、一言網的一句話、一句網、今日詩詞) 6. 添加 snackbar 彈窗 7. 修改nightshift為darkmode,darkmode可隨系統設置而自動切換,可設置隨時間而切換darkmode 8. 修復hexo自帶的標籤外掛(Tag Plugins)顯示bug(Block Quote、Code Block With caption、Gist、Youtube、Vimeo) 9. 主題所需要的css和js可根據需要配置CDN 10. 更改darkmode的加載方式,網站設置dark mode後,現在進入網頁不會在'閃'一下 11. 背景特效和背景圖片在手機界面也會顯示 12. 增加justified-gallery圖片顯示(Tag Plugins) Feature 1. 文章頁面,字數統計、閲讀時長和閲讀量前面添加icon 2. 更改懶加載js 3. 升級typed.js/instantpage.js到最新版 4. 搜索和右下角按鈕添加退出特效 Fixed 1. 修復在 Hexo 4.0.0下,一些按鈕點擊會跳出一個空白頁的bug 2. 修復在 Hexo 4.0.0下,分頁按鈕出現代碼的bug 3. 修復當沒有設置評論時,右下角依舊出現'直達評論'按鈕的bug 4. 優化sidebar的打開速度 5. 修復文章頁標題左右邊距不平等的bug 6. 修復keywords讀取的bug 7. 修復當post/page 內容為空時,footer位置錯亂的bug 8. 修復在手機safari,toc sidebar底部內容被遮擋的bug 9. 完善Dark mode,一些界面的配色 10. 修復 card-archives 查看更多 跳轉bug Remove 1. 移除Gitment 2. 移除Gallery
91 lines
2.2 KiB
JavaScript
91 lines
2.2 KiB
JavaScript
/**
|
|
* Copyright (c) 2016 hustcc
|
|
* License: MIT
|
|
* Version: v1.0.1
|
|
* GitHub: https://github.com/hustcc/ribbon.js
|
|
**/
|
|
|
|
!(function () {
|
|
|
|
var script = document.getElementById('ribbon');
|
|
var mb = script.getAttribute("mobile");
|
|
if (mb == 'false' && (/Android|webOS|iPhone|iPod|iPad|BlackBerry/i.test(navigator.userAgent))) {
|
|
return;
|
|
}
|
|
|
|
config = {
|
|
z: attr(script, 'zIndex', -1), // z-index
|
|
a: attr(script, 'alpha', 0.6), // alpha
|
|
s: attr(script, 'size', 90), // size
|
|
c: attr(script, 'data-click', true) // click-to-change
|
|
}
|
|
|
|
|
|
function attr (node, attr, default_value) {
|
|
if (default_value === true) {
|
|
return node.getAttribute(attr) || default_value
|
|
}
|
|
return Number(node.getAttribute(attr)) || default_value
|
|
}
|
|
|
|
var canvas = document.createElement('canvas'),
|
|
g2d = canvas.getContext('2d'),
|
|
pr = window.devicePixelRatio || 1,
|
|
width = window.innerWidth,
|
|
height = window.innerHeight,
|
|
f = config.s,
|
|
q,
|
|
t,
|
|
m = Math,
|
|
r = 0,
|
|
pi = m.PI * 2,
|
|
cos = m.cos,
|
|
random = m.random
|
|
canvas.width = width * pr
|
|
canvas.height = height * pr
|
|
g2d.scale(pr, pr)
|
|
g2d.globalAlpha = config.a
|
|
canvas.style.cssText =
|
|
'opacity: ' +
|
|
config.a +
|
|
';position:fixed;top:0;left:0;z-index: ' +
|
|
config.z +
|
|
';width:100%;height:100%;pointer-events:none;'
|
|
// create canvas
|
|
document.getElementsByTagName('body')[0].appendChild(canvas)
|
|
|
|
function redraw () {
|
|
g2d.clearRect(0, 0, width, height)
|
|
q = [{ x: 0, y: height * 0.7 + f }, { x: 0, y: height * 0.7 - f }]
|
|
while (q[1].x < width + f) draw(q[0], q[1])
|
|
}
|
|
function draw (i, j) {
|
|
g2d.beginPath()
|
|
g2d.moveTo(i.x, i.y)
|
|
g2d.lineTo(j.x, j.y)
|
|
var k = j.x + (random() * 2 - 0.25) * f,
|
|
n = line(j.y)
|
|
g2d.lineTo(k, n)
|
|
g2d.closePath()
|
|
r -= pi / -50
|
|
g2d.fillStyle =
|
|
'#' +
|
|
(
|
|
((cos(r) * 127 + 128) << 16) |
|
|
((cos(r + pi / 3) * 127 + 128) << 8) |
|
|
(cos(r + (pi / 3) * 2) * 127 + 128)
|
|
).toString(16)
|
|
g2d.fill()
|
|
q[0] = q[1]
|
|
q[1] = { x: k, y: n }
|
|
}
|
|
function line (p) {
|
|
t = p + (random() * 2 - 1.1) * f
|
|
return t > height || t < 0 ? line(p) : t
|
|
}
|
|
if (config.c !== 'false') {
|
|
document.onclick = redraw
|
|
document.ontouchstart = redraw
|
|
}
|
|
redraw()
|
|
})() |