js之:漂浮线
(function initJParticle( $ ){ "use strict"; var createParticlesSandbox, Utils; Utils = {}; /*
* Create jParticle animation.
* @param {Object} options Few jParticle options.
* @return {Object} jQuery object for chaining.
*/
$.fn.jParticle = function jParticle( options ){ this.each(function( _, el ){ if ( typeof el.sandbox === 'object' ) { $( el ).removeJParticle();
} el.sandbox = createParticlesSandbox( el, options );
}); return this;
}; /*
* Remove jParticle canvas.
* @return {Object} jQuery object for chaining.
*/
$.fn.removeJParticle = function removeJParticle(){ this.each(function( _, el ){ if ( el.sandbox ) { el.sandbox.remove();
delete el.sandbox;
}
}); return this;
}; /*
* Freeze jParticle animation.
* @return {Object} jQuery object for chaining.
*/
$.fn.freezeJParticle = function freezeJParticle(){ this.each(function( _, el ){ if ( el.sandbox ) { el.sandbox.freeze();
}
}); return this;
}; /*
* Unfreeze jParticle animation.
* @return {Object} jQuery object for chaining.
*/
$.fn.unfreezeJParticle = function unfreezeJParticle(){ this.each(function( _, el ){ if ( el.sandbox ) { el.sandbox.unfreeze();
}
}); return this;
}; /*
* Create a particles sandbox instance.
* @param {Object} element Element for the sandbox.
* @param {Object} params Few sandbox's params.
* @return {Object} Particles sandbox object.
*/
createParticlesSandbox = function createParticlesSandbox( element, params ){ var ParticlesSandbox, createParticle; ParticlesSandbox = {}; ParticlesSandbox.canvas = {};
ParticlesSandbox.mouse = {};
ParticlesSandbox.particles = []; ParticlesSandbox.isAnimated = false; /*
* Initialize the sandbox
* @param {Object} element Element for the sandbox.
* @param {Object} params Few sandbox's params.
*/
ParticlesSandbox.initialize = function initialize( element, params ){ ParticlesSandbox.initParams( params );
ParticlesSandbox.initHTML( element );
ParticlesSandbox.initParticles();
ParticlesSandbox.initEvents();
ParticlesSandbox.initAnimation();
}; /*
* Initialize sandbox's params.
* @param {Object} params Few sandbox's params.
*/
ParticlesSandbox.initParams = function initParams( params ){ if ( params && params.color && (!params.particle || ( params.particle && !params.particle.color ) ) ) { if ( !params.particle ) { params.particle = {};
} params.particle.color = params.color;
} ParticlesSandbox.params = $.extend({
particlesNumber: 100,
linkDist: 50,
createLinkDist: 150,
disableLinks: false,
disableMouse: false,
background: 'black',
color: 'white',
width: null,
height: null,
linksWidth: 1
}, params );
}; /*
* Initialize the sandbox's html.
* @param {Object} element Element for the sandbox.
*/
ParticlesSandbox.initHTML = function initHTML( element ){ var canvas; canvas = ParticlesSandbox.canvas; canvas.container = $( element );
canvas.element = $('<canvas/>'); canvas.context = canvas.element.get(0).getContext('2d'); canvas.container.append( canvas.element ); canvas.element.css( 'display', 'block' ); canvas.element.get(0).width = ( ParticlesSandbox.params.width ) ? ParticlesSandbox.params.width : canvas.container.width();
canvas.element.get(0).height = ( ParticlesSandbox.params.height ) ? ParticlesSandbox.params.height : canvas.container.height(); canvas.element.css( 'background', ParticlesSandbox.params.background );
}; /*
* Resize canvas.
*/
ParticlesSandbox.resize = function resize( width, height ){ if ( width ) { canvas.element.get(0).width = width;
} if ( height ) { canvas.element.get(0).height = height;
}
}; /*
* Create all particles in the sandbox.
*/
ParticlesSandbox.initParticles = function initParticles(){ var i, count; i = 0;
count = ParticlesSandbox.params.particlesNumber; for ( ; i < count; i += 1 ) { ParticlesSandbox.particles.push( createParticle(
ParticlesSandbox.canvas.element.get(0),
ParticlesSandbox.params.particle
) );
}
}; /*
* Initialize the sandbox's events.
*/
ParticlesSandbox.initEvents = function initEvents(){ ParticlesSandbox.canvas.element.mouseenter(function mouseEnterCallback(){ ParticlesSandbox.mouse.hoverCanvas = true; if ( !ParticlesSandbox.isAnimated ) { ParticlesSandbox.draw();
}
}); ParticlesSandbox.canvas.element.mouseleave(function mouseLeaveCallback(){ ParticlesSandbox.mouse.hoverCanvas = false;
}); ParticlesSandbox.canvas.element.mousemove(function mouseMoveCallback(e){ ParticlesSandbox.mouse = $.extend( ParticlesSandbox.mouse, Utils.getMousePosition( e, ParticlesSandbox.canvas.element[0] ) );
});
}; /*
* Initialize the sandbox's animation.
*/
ParticlesSandbox.initAnimation = function initAnimation(){ window.requestAnimFrame =
window.requestAnimationFrame ||
window.webkitRequestAnimationFrame ||
window.mozRequestAnimationFrame ||
window.ORequestAnimationFrame ||
window.msRequestAnimationFrame || function requestAnimFrame( callback ){ setTimeOut( callback, 1000/60 );
}; ParticlesSandbox.isAnimated = true; ParticlesSandbox.draw();
}; /*
* Draw the sandbox canvas.
*/
ParticlesSandbox.draw = function draw(){ var i, j, count, canvas, particle, particle2; i = 0;
count = ParticlesSandbox.particles.length;
canvas = ParticlesSandbox.canvas; canvas.context.clearRect( 0, 0, canvas.element.get(0).width, canvas.element.get(0).height ); for ( ; i < count; i += 1 ) { particle = ParticlesSandbox.particles[i]; if ( ParticlesSandbox.isAnimated ) { particle.update();
} particle.draw(); if ( !ParticlesSandbox.params.disableMouse && ParticlesSandbox.mouse.hoverCanvas ) {
ParticlesSandbox.drawLink(
particle.getPosition('x'),
particle.getPosition('y'),
ParticlesSandbox.mouse.x,
ParticlesSandbox.mouse.y
);
} if ( !ParticlesSandbox.params.disableLinks ) { for ( j = i+1; j < count; j += 1 ) { particle2 = ParticlesSandbox.particles[j]; ParticlesSandbox.drawLink(
particle.getPosition('x'),
particle.getPosition('y'),
particle2.getPosition('x'),
particle2.getPosition('y')
);
}
}
} ParticlesSandbox.requestID = window.requestAnimFrame( ParticlesSandbox.draw );
}; /*
* Draw a link between two particles.
* @param {int} x First object abscissa coords.
* @param {int} y First object ordered coords.
* @param {int} x2 Second object abscissa coords.
* @param {int} y2 Second object ordered coords.
*/
ParticlesSandbox.drawLink = function drawLink( x, y, x2, y2 ){ var context; if ( Utils.getDistance( x, y, x2, y2 ) <= ParticlesSandbox.params.createLinkDist ) { context = ParticlesSandbox.canvas.context; context.save(); context.beginPath();
context.lineWidth = ParticlesSandbox.params.linksWidth;
context.moveTo( x, y );
context.lineTo( x2, y2 );
context.globalAlpha = ParticlesSandbox.getOpacityLink( x, y, x2, y2 );
context.strokeStyle = ParticlesSandbox.params.color;
context.lineCap = 'round';
context.stroke();
context.closePath(); context.restore();
}
}; /*
* Get opacity for link two particles.
* @param {int} x First object abscissa coords.
* @param {int} y First object ordered coords.
* @param {int} x2 Second object abscissa coords.
* @param {int} y2 Second object ordered coords.
* @return {int} 0 <= opacity <= 1
*/
ParticlesSandbox.getOpacityLink = function getOpacityLink( x, y, x2, y2 ){ var dist, opacity, linkDist, createLinkDist; dist = Utils.getDistance( x, y, x2, y2 );
linkDist = ParticlesSandbox.params.linkDist;
createLinkDist = ParticlesSandbox.params.createLinkDist; if ( dist <= linkDist ) { opacity = 1;
} else if ( dist > createLinkDist ) { opacity = 0;
} else { opacity = 1 - ( ( ( dist - linkDist ) * 100 ) / ( createLinkDist - linkDist ) ) / 100;
} return opacity;
}; /*
* Freeze the animation.
*/
ParticlesSandbox.freeze = function freeze(){ if ( ParticlesSandbox.isAnimated ) { ParticlesSandbox.isAnimated = false;
}
}; /*
* Unfreeze the animation.
*/
ParticlesSandbox.unfreeze = function unfreeze(){ if ( !ParticlesSandbox.isAnimated ) { ParticlesSandbox.isAnimated = true;
}
}; /*
* Remove the animation's canvas.
*/
ParticlesSandbox.remove = function remove(){ ParticlesSandbox.canvas.element.remove();
}; /*
* Create a particle instance.
* @param {Object} canvas DOM element.
* @param {Object} params Few particle's params.
* @return {Object} Particle object.
*/
createParticle = function createParticle( canvas, params ){ var Particle; Particle = {}; Particle.canvas = {};
Particle.vector = {}; /*
* Initialize the particle.
* @param {Object} canvas DOM element.
* @param {Object} params Few particle's params.
*/
Particle.initialize = function initialize( canvas, params ){ Particle.params = $.extend({
color: 'white',
minSize: 2,
maxSize: 4,
speed: 60
}, params ); Particle.setCanvasContext( canvas ); Particle.initSize();
Particle.initPosition();
Particle.initVectors();
}; /*
* Initialize particle's position.
*/
Particle.initPosition = function initPosition(){ Particle.x = Utils.getRandNumber( 0 + Particle.radius, Particle.canvas.element.width - Particle.radius );
Particle.y = Utils.getRandNumber( 0 + Particle.radius, Particle.canvas.element.height - Particle.radius );
}; /*
* Initialize particle's size.
*/
Particle.initSize = function initSize(){ Particle.size = Utils.getRandNumber( Particle.params.minSize, Particle.params.maxSize );
Particle.radius = Particle.size / 2;
}; /*
* Initialize particle's vectors for speed.
*/
Particle.initVectors = function initVectors(){ do {
Particle.vector.x = Utils.getRandNumber( -Particle.params.speed / 60, Particle.params.speed / 60, false );
Particle.vector.y = Utils.getRandNumber( -Particle.params.speed / 60, Particle.params.speed / 60, false ); } while ( Particle.vector.x == 0 || Particle.vector.y == 0 )
}; /*
* Set the context to draw particles.
* @param {Object} canvas Canvas.
*/
Particle.setCanvasContext = function setCanvasContext( canvas ){ var context; Particle.canvas.element = canvas;
context = canvas.getContext('2d'); if ( typeof context === 'object' && typeof context.canvas === 'object' ) { Particle.canvas.context = context;
} else { throw "Error: Can't set canvas context to Particle because context isn't a CanvasRenderingContext2D object.";
}
}; /*
* Draw particle.
*/
Particle.draw = function draw(){ var context = Particle.canvas.context; context.beginPath();
context.arc( Particle.x, Particle.y, Particle.size /2, 0, Math.PI*2 );
context.fillStyle = Particle.params.color;
context.fill();
context.closePath();
}; /*
* Update the particle's position.
*/
Particle.update = function update(){ Particle.x += Particle.vector.x;
Particle.y += Particle.vector.y; if ( 0 > ( Particle.x - Particle.radius ) || ( Particle.x + Particle.radius ) > Particle.canvas.element.width ) { Particle.vector.x = -Particle.vector.x;
} if ( 0 > ( Particle.y - Particle.radius ) || ( Particle.y + Particle.radius ) > Particle.canvas.element.height ) { Particle.vector.y = -Particle.vector.y;
}
}; /*
* Return position of particle.
* @param {string} axis Optionnal axis.
* @return {int|Object} Return object if axis is not defined, else return int.
*/
Particle.getPosition = function getPosition( axis ){ if ( typeof axis === 'string' && ( axis != 'x' && axis != 'y' ) ) { axis = null;
} return ( typeof( axis ) === 'string' ) ? Particle[ axis ] : { x: Particle.x, y: Particle.y };
}; Particle.initialize( canvas, params ); return {
getPosition: Particle.getPosition,
update: Particle.update,
draw: Particle.draw
};
}; ParticlesSandbox.initialize( element, params ); return {
remove: ParticlesSandbox.remove,
freeze: ParticlesSandbox.freeze,
unfreeze: ParticlesSandbox.unfreeze,
resize: ParticlesSandbox.resize
};
}; /*
* Get rand number between x and y.
* @param {int} x Minimal number.
* @param {int} y Maximal number.
* @param {Boolean} round True is value shouldn't be round.
* @return {int} Rand number.
*/
Utils.getRandNumber = function getRandNumber( x, y, round ){ var value; if( x == null ) { x = 0;
} if( y == null ) { y = 10;
} if( round == null ) { round = true;
} value = Math.random() * ( y - x ) + x; return ( round ) ? Math.round( value ) : value;
}; /*
* Get distance between to cartesian points.
* @param {int} x First object abscissa coords.
* @param {int} y First object ordered coords.
* @param {int} x2 Second object abscissa coords.
* @param {int} y2 Second object ordered coords.
* @return {int} Distance.
*/
Utils.getDistance = function getDistance( x, y, x2, y2 ){ return Math.sqrt( Math.pow( x2 - x, 2 ) + Math.pow( y2 - y, 2 ) );
}; /*
* Get mouse position.
* @param {Object} event The HTML DOM events.
* @param {Object} element The DOM element.
* @return {Object} x/y position.
*/
Utils.getMousePosition = function getMousePosition( event, element ){ var rect; if ( typeof element === 'undefined' ) { element = $('body')[0];
} rect = element.getBoundingClientRect(); return {
x: event.clientX - rect.left,
y: event.clientY - rect.top
};
}; })( jQuery )
调用方法:
html:
<div class="layui-canvs"></div>
js:
$(".layui-canvs").jParticle({
background: "#141414",
color: "#E6E6E6"
});
注意:需要先设置 canvas的宽高
js之:漂浮线的更多相关文章
- Js弹性漂浮广告代码
<html><head><meta http-equiv="Content-Type" content="text/html; charse ...
- three.js 创建点 线 面
<html> <head> <title>My first three.js app</title> <style> body { marg ...
- d3.js制作连线动画图和编辑器
此文章为原创文章,原文地址:https://www.cnblogs.com/eagle1098/p/11431679.html 连线动画图 编辑器 效果如上图所示.本项目使用主要d3.jsv4制作,分 ...
- js 开源k线图开发库
https://github.com/andredumas/techan.js/wiki http://techanjs.org/ A visual, stock charting (Candlest ...
- vue.js打包部署线上
你完成了工程开发,需要部署到外网环境,要进行下面的步骤: 一.首先你要购买一个服务器或者有自己的服务器.我介绍给大家的一个免费的服务器:http://free.3v.do/index.html可以免费 ...
- JavaScript浮动广告代码,容纯DIV/CSS对联漂浮广告代码,兼容性非常好的js右下角与漂浮广告代码
基于JavaScript代码实现随机漂浮图片广告,javascript图片广告 在网上有很多这样的代码,不过未必符合W3C标准,因为在头部加上<!DOCTYPE html>类似标签之后,漂 ...
- 一些js 插件的作用
前言: 从一些开源网站上下载下来的 后台管理系统模板一般会有很多的js ,其js 的功能是什么呢?这里随手查询了一下,记录下来 正文: 1.zDialog.js 各种弹窗插件详细案例:http://w ...
- 怎么评价Facebook的Relay框架?Meteor.js 是什么?
http://www.zhihu.com/question/34531232?rf=34500201 Meteor.js 是什么? 作者:陈天链接:http://www.zhihu.com/quest ...
- JS常用正则表达式备忘录
摘要: 玩转正则表达式. 原文:JS常用正则表达式备忘录 作者:前端小智 Fundebug经授权转载,版权归原作者所有. 正则表达式或"regex"用于匹配字符串的各个部分 下面是 ...
随机推荐
- promise迷你书-读书笔记
Promise三种类型 Constructor 使用Promise构造器来实例化一个promise对象 var promise = new Promise(function(resolve,rejec ...
- 最全Redis基础知识
NoSQL概述 什么是NoSQL NoSQL不仅仅是SQL,它是Not Only SQL 的缩写,也是众多非关系型数据库的统称NoSQL和关系型数据库一样,也是用来存储数据的仓库. 为什么需要NoSQ ...
- Iterm2 快捷操作
窗口操作 新建窗口:Command + N 关闭所有窗口:Shift + Command + W 窗口之间切换 前一个窗口: Command + [ 后一个窗口:Command + ] 进入窗口1,2 ...
- docker的安装,自己写了一个安装docker的脚本,辅助做docker安装的实验(ubuntu)
#!/bin/bash #获取用户名 [ pwd == '/root' ] && hn="root@$(hostname):~#" || hn="root ...
- html5 拖放购物车
1.本例中模仿了购物车添加的功能 主要运用了ondragstart / ondragover/ ondrag 功能 功能比较简单 遗留问题:火狐下图片拖进会被打开 <!doctype html& ...
- [置顶] Django-rest framework框架
出师表 先帝创业未半而中道崩殂,今天下三分,益州疲弊此诚危急存亡之秋也.然侍卫之臣不懈于内忠志之士忘身于外者盖追先帝之殊遇,欲报之于陛下也.诚宜开张圣听,以光先帝遗德,恢弘志士之气,不宜妄自菲薄,引喻 ...
- [CSP初赛] 组合数学的三个技巧以及从另一方面思考组合类问题
也不知道老师讲不讲 话说好久没有水博客了,看了一点\(python\)然后就去搞文化课了 正好网课讲到组合数学,然后觉得还蛮难的(其实是我变菜了),就想到了以前的\(csp\)的组合数学基础 果然被我 ...
- mybatis返回自增主键踩坑记
背景 MyBatis 是支持定制化 SQL.存储过程以及高级映射的优秀的持久层框架.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis 可以对配置和原生Map ...
- Open live Writer 直接发布wps文章,优点是可以带上图片
官方网站: http://openlivewriter.org/ 博客园的设置里面的 MetaWeblog访问地址
- iviewadmin url 加入 Router base #viewDesignAdmin
router/index.js const router = new Router({ routes, base: '/viewDesignAdmin/', mode: 'history' ...