chrome浏览器美化插件:让你的浏览器页面冒水泡, 游小鱼儿

  下载插件和效果图

  这是一个让你的浏览器冒泡泡的插件, 浏览网页的时候仿佛置身于海底世界;

  插件下载地址:http://files.cnblogs.com/files/diligenceday/chromeExtension.crx.zip

  效果图:

chrome浏览器美化插件:让你的浏览器页面冒水泡, 游小鱼儿

chrome浏览器美化插件:让你的浏览器页面冒水泡, 游小鱼儿

  在线预览页面

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title> <style>
body, html{
margin:;
width:%;
height:%;
background:#eee;
}
</style>
</head>
<body>
<script>
var imgBase64 = ""
class Bubble {
constructor(_x, _y) {
this.x = _x;
this.y = _y;
this.speedy = common.getBetween(,);
this.w = common.getBetween(, );
this.smallB = Math.random()>0.7 ? true : false;
}
move() {
this.x += common.getBetween(,)-;
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<) {
this.bubbles.splice(b,);
}else{
this.bubbles[b].move();
}
};
}
draw(eCanvas, context) {
context.clearRect(,,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, , Math.PI*,false);
context.fill();
this.bubbles[b].smallB && this.drawEllipse(context, this.bubbles[b].x, this.bubbles[b].y, this.bubbles[b].w/, this.bubbles[b].w/);
}
}
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,][common.getBetween(,)] + ;
context.fillStyle = "rgba(255,255,255,0.6)";
context.scale(ratioX, ratioY);
context.beginPath();
context.arc(x / ratioX - pos , y / ratioY - pos , r, , * 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 = "";
eCan.style.left = "";
eCan.style.position = "fixed";
eCan.style.zIndex = ;
eCan.style.pointerEvents = "none";
this.context = eCan.getContext("2d");
this.events(); this.clientX = ;
this.clientY = ; //插件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 = ;
this.imageH = ;
//小鱼目前的位置
this.nowX = ;
this.nowY = ;
//小鱼要到的地方
this.destX = ;
this.destY = ;
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 = "";
eCan.style.left = "";
eCan.style.position = "fixed";
eCan.style.zIndex = ;
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 ( - n) * a + n * b;
}
//重复刷新, 更新canvas画图
requestAni() {
var _this = this;
//计算
上一篇:Linux usb子系统(三):通过usbfs操作设备的用户空间驱动


下一篇:mysql的小总结