halo-theme-dream
Version:
梦之城,童话梦境,动漫类型博客主题。
138 lines (119 loc) • 3.46 kB
JavaScript
(function ($) {
$.fn.circleMagic = function (options) {
let width, height, canvas, ctx, animateHeader = true
const circles = []
const settings = $.extend({
color: 'rgba(255,255,255,.5)',
radius: 10,
density: 0.3,
clearOffset: 0.2,
mode: 'all'
}, options)
// Main
var container = this['0']
initContainer()
addListeners()
function initContainer() {
width = window.innerWidth
height = window.innerHeight
// create canvas element
canvas = initCanvas()
canvas.width = width
canvas.height = height
ctx = canvas.getContext('2d')
// create circles
for (let x = 0; x < width * settings.density; x++) {
const c = new Circle()
circles.push(c)
}
animate()
}
//Init canvas element
function initCanvas() {
const canvasElement = document.createElement('canvas')
canvasElement.setAttribute('class', `canvas_effects ${settings.mode}`)
container.prepend(canvasElement)
return canvasElement
}
// Event handling
function addListeners() {
window.addEventListener('scroll', scrollCheck, false)
window.addEventListener('resize', resize, false)
}
function scrollCheck() {
if (document.body.scrollTop > height) {
animateHeader = false
}
else {
animateHeader = true
}
}
function resize() {
width = window.innerWidth
height = window.innerHeight
canvas.width = width
canvas.height = height
}
function animate() {
const isNight = document.documentElement.classList.contains('night')
if (settings.mode === 'all' || (settings.mode === 'day' && !isNight) || (settings.mode === 'night' && isNight)) {
if (animateHeader) {
ctx.clearRect(0, 0, width, height)
for (const i in circles) {
circles[i].draw()
}
}
}
requestAnimationFrame(animate)
}
function randomColor() {
var r = Math.floor(Math.random() * 255)
var g = Math.floor(Math.random() * 255)
var b = Math.floor(Math.random() * 255)
var alpha = Math.random().toPrecision(2)
return 'rgba(' + r + ', ' + g + ', ' + b + ', ' + alpha + ')'
}
// Canvas manipulation
function Circle() {
var that = this;
// constructor
(function () {
that.pos = {}
init()
})()
function init() {
that.pos.x = Math.random() * width
that.pos.y = height + Math.random() * 100
that.alpha = 0.1 + Math.random() * settings.clearOffset
that.scale = 0.1 + Math.random() * 0.3
that.speed = Math.random()
if (settings.color === 'random') {
that.color = randomColor()
}
else {
that.color = settings.color
}
}
this.draw = function () {
if (that.alpha <= 0) {
init()
}
that.pos.y -= that.speed
that.alpha -= 0.0005
ctx.beginPath()
ctx.arc(that.pos.x, that.pos.y, that.scale * settings.radius, 0, 2 * Math.PI, false)
ctx.fillStyle = that.color
ctx.fill()
ctx.closePath()
}
}
}
$('body').circleMagic({
radius: 35,
density: 0.3,
color: 'rgba(255,255,255, .4)',
//color: 'random',
clearOffset: 0.3,
mode: DreamConfig.effects_circle_magic_mode
})
})(jQuery)