mirror of
https://ghfast.top/https://github.com/zsjy/halo-theme-dream2.0-plus.git
synced 2025-03-15 15:29:41 +08:00
feat:新增鼠标点击特效 - 爱心特效 (#74)
This commit is contained in:
parent
e6feff2e13
commit
00aaeb871a
@ -986,6 +986,8 @@ spec:
|
||||
label: 粒子爆炸
|
||||
- value: prosperous
|
||||
label: 富强民主
|
||||
- value: heart
|
||||
label: 爱心特效
|
||||
- $formkit: radio
|
||||
name: enable_sw
|
||||
label: "启用 Service Worker 优化"
|
||||
|
51
src/js/cursor/click/heart.js
Normal file
51
src/js/cursor/click/heart.js
Normal file
@ -0,0 +1,51 @@
|
||||
!function (e, t, a) {
|
||||
function r() {
|
||||
for (var e = 0; e < s.length; e++) s[e].alpha <= 0 ? (t.body.removeChild(s[e].el), s.splice(e, 1)) : (s[
|
||||
e].y--, s[e].scale += .004, s[e].alpha -= .013, s[e].el.style.cssText = 'left:' + s[e].x +
|
||||
'px;top:' + s[e].y + 'px;opacity:' + s[e].alpha + ';transform:scale(' + s[e].scale + ',' + s[e].scale + ') rotate(45deg);background:' + s[e].color + ';z-index:99999')
|
||||
requestAnimationFrame(r)
|
||||
}
|
||||
|
||||
function n() {
|
||||
var t = 'function' == typeof e.onclick && e.onclick
|
||||
e.onclick = function (e) {
|
||||
t && t(), o(e)
|
||||
}
|
||||
}
|
||||
|
||||
function o(e) {
|
||||
var a = t.createElement('div')
|
||||
a.className = 'heart', s.push({
|
||||
el: a,
|
||||
x: e.clientX - 5,
|
||||
y: e.clientY - 5,
|
||||
scale: 1,
|
||||
alpha: 1,
|
||||
color: c()
|
||||
}), t.body.appendChild(a)
|
||||
}
|
||||
|
||||
function i(e) {
|
||||
var a = t.createElement('style')
|
||||
a.type = 'text/css'
|
||||
try {
|
||||
a.appendChild(t.createTextNode(e))
|
||||
} catch (t) {
|
||||
a.styleSheet.cssText = e
|
||||
}
|
||||
t.getElementsByTagName('head')[0].appendChild(a)
|
||||
}
|
||||
|
||||
function c() {
|
||||
return 'rgb(' + ~~(255 * Math.random()) + ',' + ~~(255 * Math.random()) + ',' + ~~(255 * Math
|
||||
.random()) + ')'
|
||||
}
|
||||
|
||||
var s = []
|
||||
e.requestAnimationFrame = e.requestAnimationFrame || e.webkitRequestAnimationFrame || e
|
||||
.mozRequestAnimationFrame || e.oRequestAnimationFrame || e.msRequestAnimationFrame || function (e) {
|
||||
setTimeout(e, 1e3 / 60)
|
||||
}, i(
|
||||
'.heart{width: 10px;height: 10px;position: fixed;background: #f00;transform: rotate(45deg);-webkit-transform: rotate(45deg);-moz-transform: rotate(45deg);}.heart:after,.heart:before{content: \'\';width: inherit;height: inherit;background: inherit;border-radius: 50%;-webkit-border-radius: 50%;-moz-border-radius: 50%;position: fixed;}.heart:after{top: -5px;}.heart:before{left: -5px;}'
|
||||
), n(), r()
|
||||
}(window, document)
|
1
templates/assets/js/cursor/click/heart.min.js
vendored
Normal file
1
templates/assets/js/cursor/click/heart.min.js
vendored
Normal file
@ -0,0 +1 @@
|
||||
!function(e,a){var r,o=[],t=(e.requestAnimationFrame=e.requestAnimationFrame||e.webkitRequestAnimationFrame||e.mozRequestAnimationFrame||e.oRequestAnimationFrame||e.msRequestAnimationFrame||function(e){setTimeout(e,1e3/60)},".heart{width: 10px;height: 10px;position: fixed;background: #f00;transform: rotate(45deg);-webkit-transform: rotate(45deg);-moz-transform: rotate(45deg);}.heart:after,.heart:before{content: '';width: inherit;height: inherit;background: inherit;border-radius: 50%;-webkit-border-radius: 50%;-moz-border-radius: 50%;position: fixed;}.heart:after{top: -5px;}.heart:before{left: -5px;}"),i=a.createElement("style");i.type="text/css";try{i.appendChild(a.createTextNode(t))}catch(e){i.styleSheet.cssText=t}a.getElementsByTagName("head")[0].appendChild(i),r="function"==typeof e.onclick&&e.onclick,e.onclick=function(e){var t;r&&r(),e=e,(t=a.createElement("div")).className="heart",o.push({el:t,x:e.clientX-5,y:e.clientY-5,scale:1,alpha:1,color:"rgb("+~~(255*Math.random())+","+~~(255*Math.random())+","+~~(255*Math.random())+")"}),a.body.appendChild(t)},function e(){for(var t=0;t<o.length;t++)o[t].alpha<=0?(a.body.removeChild(o[t].el),o.splice(t,1)):(o[t].y--,o[t].scale+=.004,o[t].alpha-=.013,o[t].el.style.cssText="left:"+o[t].x+"px;top:"+o[t].y+"px;opacity:"+o[t].alpha+";transform:scale("+o[t].scale+","+o[t].scale+") rotate(45deg);background:"+o[t].color+";z-index:99999");requestAnimationFrame(e)}()}(window,document);
|
Loading…
x
Reference in New Issue
Block a user