下载插件和效果图

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

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

  效果图:

  在线预览页面

<!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;
//计算

chrome浏览器美化插件:让你的浏览器页面冒水泡, 游小鱼儿的更多相关文章

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

    下载插件和效果图 这是一个让你的浏览器冒泡泡的插件, 浏览网页的时候仿佛置身于海底世界: 插件下载地址:http://files.cnblogs.com/files/diligenceday/chro ...

  2. chrome浏览器postman 插件安装

    postman 软件功能 模拟各种HTTPrequests 从常用的GET.POST到RESTful的PUT.DELETE…等等.甚至还可以发送文件.送出额外的header. Collection功能 ...

  3. 怎样开发Chrome浏览器的插件

    http://jingyan.baidu.com/article/b907e627fb90fd46e7891c3c.html Chrome 浏览器作为基于Webkit的新一代浏览器.Chrome自从正 ...

  4. chrome浏览器视频插件

    以前安装chrome浏览器flash插件是将libflashplayer.so拷贝到chrome浏览器的plugins目录下.但最近好像不行了. 于是换了另一插件:pepperflashplugin- ...

  5. Python+selenium 自动化-启用带插件的chrome浏览器,调用浏览器带插件,浏览器加载配置信息。

    Python+selenium 自动化-启用带插件的chrome浏览器,调用浏览器带插件,浏览器加载配置信息.   本文链接:https://blog.csdn.net/qq_38161040/art ...

  6. 无插件的大模型浏览器Autodesk Viewer开发培训-武汉-2014年8月28日 9:00 – 12:00

    武汉附近的同学们有福了,这是全球第一次关于Autodesk viewer的教室培训. :) 你可能已经在各种场合听过或看过Autodesk最新推出的大模型浏览器,这是无需插件的浏览器模型,支持几十种数 ...

  7. jquery判断浏览器版本插件,jquery-browser.js

    jquery判断浏览器版本插件,jquery-browser.js,jquery 判断是否为ie浏览器插件 >>>>>>>>>>>&g ...

  8. 《浏览器工作原理与实践》<01>Chrome架构:仅仅打开了1个页面,为什么有4个进程?

    无论你是想要设计高性能 Web 应用,还是要优化现有的 Web 应用,你都需要了解浏览器中的网络流程.页面渲染过程,JavaScript 执行流程,以及 Web 安全理论,而这些功能是分散在浏览器的各 ...

  9. Chrome浏览器扩展开发系列之七:override页面

    Chrome浏览器通常提供了一些默认页面,如标签管理器页面chrome://bookmarks.浏览历史记录页面chrome://history或新建Tab页面chrome://newtab等. Ch ...

随机推荐

  1. dubbo框架揭秘之服务发布

    通常情况下是通过Spring配置的方式去实现服务的发布,为了方便调试,我就不采用Spring配置的方式. DemoService demo = new DemoServiceImpl(); Appli ...

  2. UVa 10718 - Bit Mask

    题目大意:给一数N,在区间[L, U]上找到一个数M使得M| N的值最大,如果有M有多个可能值,取最小的那个值. 从最高位开始逐位判断,如果N的该位为0,为使M | N的值最大,M的该位应考虑置为1, ...

  3. UIscrollView 代理

    // // UIDemoViewController.m // 06-1UIScrollDemo // // Created by k on 14-9-4. // Copyright (c) 2014 ...

  4. Android性能优化(一)之启动加速35%

    一.前言 随着项目版本的迭代,App的性能问题会逐渐暴露出来,而好的用户体验与性能表现紧密相关,从本篇文章开始,我将开启一个Android应用性能优化的专题,从理论到实战,从入门到深挖,手把手将性能优 ...

  5. BZOJ 2038: [2009国家集训队]小Z的袜子(hose)&&莫对算法

    这里跟曼哈顿最小生成树没有太大的关系. 时间复杂度证明: [BZOJ2038 小Z的袜子 AC代码] 排序方式: 第一关键字:l所在的块: 第二关键字:r从小到大. #include<cstdi ...

  6. SecureCRT 使用

    1. 连接linux 服务器 http://www.cnblogs.com/SimonGao/p/4959274.html

  7. 如何在asp.net页面使用css和js

    一.如何在asp.net页面中使用css1.可以直接写在需要样式控制的控件里 例如:<div style="border:#ff6100 1px solid">< ...

  8. easyUI draggable组件使用

    easyUI draggable组件使用: <!DOCTYPE html> <html lang="en"> <head> <meta c ...

  9. MyBatis浅尝笔记

    MyBatis应属于一种轻量级的java持久层技术,它通过简单的SQL xml或注解,将数据库数据映射到接口与POJO.最近项目要用到mybatis,所以学习之后在这里做个总结,文中的示例以xml配置 ...

  10. ssh配置文件及问题解决

    一 ssh的配置文鉴模板 Host AAA User gitolite3 HostName IP地址 IdentityFile ~/.ssh/key 二 下载代码的方法 1 ssh git2 git ...