1. 程式人生 > >chrome瀏覽器美化外掛:讓您的瀏覽器頁面冒水泡, 遊小魚兒

chrome瀏覽器美化外掛:讓您的瀏覽器頁面冒水泡, 遊小魚兒

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>

    <style>
        body, html{
            margin:0;
            width:100%;
            height:100%;
            background:#eee;
        }
    </style>
</head>
<body>
    <script>
    var
imgBase64 = "
" class Bubble { constructor(_x, _y) { this.x = _x; this.y = _y; this.speedy = common.getBetween(1,4); this.w = common.getBetween(2, 16); this.smallB = Math.random()>0.7 ? true : false; } move() {
this.x += common.getBetween(0,5)-2; this.y = this.y-this.speedy; } } class Panel { constructor() { this.bubbles = new Array(); } create(x, y) { if(Math.random()>0.8) { this.bubbles.push( new Bubble(x, y) ); } } calc() { for(var b in this.bubbles) { if(this.bubbles[b].y<0) { this.bubbles.splice(b,1); }else{ this.bubbles[b].move(); } }; } draw(eCanvas, context) { context.clearRect(0,0,eCanvas.width,eCanvas.height); for(var b in this.bubbles) { // context.fillStyle = ["rgba(255,255,255,0.5)", "rgba(52,152,219,0.5)"][Math.floor(Math.random()*2)]; context.fillStyle = "rgba(255,255,255,0.5)"; context.beginPath(); context.arc(this.bubbles[b].x, this.bubbles[b].y, this.bubbles[b].w, 0, Math.PI*2,false); context.fill(); this.bubbles[b].smallB && this.drawEllipse(context, this.bubbles[b].x, this.bubbles[b].y, this.bubbles[b].w/4, this.bubbles[b].w/3); } } drawEllipse(context, x, y, a, b) { context.save(); var r = (a > b) ? a : b; var ratioX = a / r; var ratioY = b / r; var pos = [a,b,3][common.getBetween(0,2)] + 1; context.fillStyle = "rgba(255,255,255,0.6)"; context.scale(ratioX, ratioY); context.beginPath(); context.arc(x / ratioX - pos , y / ratioY - pos , r, 0, 2 * Math.PI, false); context.closePath(); context.fill(); context.restore(); } } class BubblePanel { constructor() { this.createCanvas(); this.events(); } createCanvas() { var eCan = this.eCan = document.createElement("canvas"); document.body.appendChild(eCan); eCan.style.top = "0"; eCan.style.left = "0"; eCan.style.position = "fixed"; eCan.style.zIndex = 100; eCan.style.pointerEvents = "none"; this.context = eCan.getContext("2d"); this.events(); this.clientX = 0; this.clientY = 0; //外掛canvas畫圖面板 this.panel = new Panel(); this.requestAni(); } events() { var _this = this; function resize() { _this.eCan.width = document.body.offsetWidth; _this.eCan.height = document.body.offsetHeight; } window.addEventListener('resize', resize); resize(); document.body.addEventListener("mousemove", function(ev) { _this.clientX = ev.clientX; _this.clientY = ev.clientY; }); } //生成泡泡 ==》 計算 ==》》 重新繪圖 requestAni() { this.panel.create(this.clientX, this.clientY); this.panel.calc(); this.panel.draw(this.eCan, this.context); requestAnimationFrame(this.requestAni.bind(this)); } } const common = { getBetween : function(start , end) { return Math.floor(Math.random()*(end-start))+start; } } /** * 魚的類 */ class Fish { constructor() { //小魚的地址 this.src= imgBase64; //小魚的寬度和高度 this.imageW = 40; this.imageH = 40; //小魚目前的位置 this.nowX = 0; this.nowY = 0; //小魚要到的地方 this.destX = 0; this.destY = 0; this.init(); } init() { this.img = new Image(); this.img.src = this.src; } } /** * 建立canvas, 並插入到DOM中 */ class Can { constructor(el) { var eCan = document.createElement("canvas"); el.appendChild(eCan); eCan.style.top = "0"; eCan.style.left = "0"; eCan.style.position = "fixed"; eCan.style.zIndex = 100; eCan.style.pointerEvents = "none"; return eCan; } } /** * 整體邏輯 */ class Fly { constructor(bd, window, fish, can) { this.body = bd; this.win = window; this.fish = fish; this.can = can; this.context = this.can.getContext("2d"); this.events(); this.requestAni(); } //繫結window的事件 events() { var _this = this; function move(ev) { _this.fish.destX = ev.clientX; _this.fish.destY = ev.clientY; } function resize() { _this.can.width = _this.body.offsetWidth; _this.can.height = _this.body.offsetHeight; } this.win.addEventListener("mousemove", move); this.win.addEventListener('resize', resize); resize(); } /** * return position X, Y; */ lerp(a, b, n) { return (1 - n) * a + n * b; } //重複重新整理, 更新canvas畫圖 requestAni() { var _this = this; //計算