下载插件和效果图
这是一个让你的浏览器冒泡泡的插件, 浏览网页的时候仿佛置身于海底世界;
插件下载地址:http://files.cnblogs.com/files/diligenceday/chromeExtension.crx.zip
效果图:
%26nbsp;
在线预览页面
%26lt;!DOCTYPE html%26gt; %26lt;html lang="en"%26gt; %26lt;head%26gt; %26lt;meta charset="UTF-8"%26gt; %26lt;title%26gt;Document%26lt;/title%26gt; %26lt;style%26gt; body, html{ margin:0; width:100%; height:100%; background:#eee; } %26lt;/style%26gt; %26lt;/head%26gt; %26lt;body%26gt; %26lt;script%26gt; 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()%26gt;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()%26gt;0.8) { this.bubbles.push( new Bubble(x, y) ); } } calc() { for(var b in this.bubbles) { if(this.bubbles[b].y%26lt;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 %26amp;%26amp; 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 %26gt; 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; //计算??游到的位置 this.fish.nowX = this.lerp( this.fish.nowX, this.fish.destX,.1); this.fish.nowY = this.lerp( this.fish.nowY, this.fish.destY-this.fish.imageH/2,.1); //更新到画布 this.context.clearRect(0, 0 ,this.can.width, this.can.height); this.context.save(); if(this.fish.destX%26lt;this.fish.nowX) { this.context.drawImage(this.fish.img, this.fish.nowX , this.fish.nowY , this.fish.imageW, this.fish.imageW); }else{ this.context.scale(-1, 1); this.context.drawImage(this.fish.img, -this.fish.nowX , this.fish.nowY , this.fish.imageW, _this.fish.imageW); } this.context.restore(); window.requestAnimationFrame(function() { _this.requestAni(); }); } } var fish = new Fish(); var can = new Can(document.body); var fly = new Fly(document.body, window, fish, can); new BubblePanel(); %26lt;/script%26gt; %26lt;/body%26gt; %26lt;/html%26gt;
如何安装:
1:下载插件并解压出 chromeExtension.crx;
2:打开浏览器的设置, 更多工具 -%26gt; 扩展程序, 或者直接打开 chrome://extensions/,这个地址:
3:选中插件, 左键拖拽插件到第二步中打开的界面, 界面会出现%26ldquo;拖放以安装%26rdquo;的提示, 然后松手, 并再确认安装;
原理
整体的内容分为 泡泡的构造函数和 鱼的构造函数;
泡泡的生成是利用canvas的API, context.arc() %26nbsp;画圆 ;
鱼的生成也是利用canvas的API,%26nbsp;context.drawImage() 画鱼??%26nbsp;
根据鼠标移动的位置, 利用运动效果把鱼拉过去, 根据鼠标的位置画泡泡;
github
发布到git:https://github.com/sqqihao/chromeBubbleExtension
插件下载地址
插件下载地址:http://files.cnblogs.com/files/diligenceday/chromeExtension.crx.zip
作者: NONO
出处:http://www.cnblogs.com/diligenceday/
企业网站:http://www.idrwl.com/
开源博客:http://www.github.com/sqqihao
QQ:287101329
微信:18101055830%26nbsp;