JavaScript实现Flash炫光波动特效


Posted in Javascript onMay 14, 2015

看到flash的实现这类的动画非常的便捷,于是试图胡搞一下。全部是用dom模拟的像素点,锯齿是难免的……

这个要避免锯齿恐怕要再加一次滤镜了吧,或者用图片。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>炫光波动效果</title>
<script>
var lightWave = function(T,left,thick,sharp,speed,vibration,amplitude,opacity){
this.cont = T;//炫光容器
this.left = left;//炫光向右偏移量
this.thick = thick;//粗细
this.sharp = sharp;//尖锐度
this.speed = speed;//波动速度
this.vibration = vibration;//单位时间内的振动频率
this.amplitude = amplitude;//振幅
this.opacity = opacity;//透明度
this.cont.style.position = 'relative';
this.move();
}
lightWave.prototype = {
point:function(n,l,t,c,color){
var p = document.createElement('p');
p.innerHTML = ' ';
p.style.top = t + 'px';
p.style.left = l + 'px';
p.style.width = 1 + 'px';
p.style.height = n + 'px';
p.style.filter = 'alpha(opacity='+this.opacity+')';
p.style.lineHeight = 0;
p.style.position = 'absolute';
p.style.background = color;
c.appendChild(p);
return this;
},
color:function(){
var c = ['0','3','6','9','c','f'];
var t = [c[Math.floor(Math.random()*100)%6],'0','f'];
t.sort(function(){return Math.random()>0.5?-1:1;});
return '#'+t.join('');
},
wave:function(){
var l = this.left,t = this.wavelength,color = this.color();
var c = document.createElement('div');
c.style.top = this.amplitude+20+'px';
c.style.position = 'absolute';
c.style.opacity = this.opacity/100;
for(var i=1;i<this.thick;i++){
for(var j=0;j<this.thick*this.sharp-i*i;j++,l++){
this.point(i,l,-9999,c,color);
}
}
for(var i=this.thick;i>0;i--){
for(var j=this.thick*this.sharp-i*i;j>0;j--,l++){
this.point(i,l,-9999,c,color);
}
}
this.cont.appendChild(c);
return c;
},
move:function(){
var wl = this.amplitude;
var vibration = this.vibration;
var w = this.wave().getElementsByTagName('p');
for(var i=0;i<w.length;i++){
w[i].i = i;
}
var m = function(){
for(var i=0,len=w.length;i<len;i++){
if(w[i].ori == true){
w[i].i-=vibration;
var top = w[i].i%180==90?0:wl*Math.cos(w[i].i*Math.PI/180);
w[i].style.top = top+'px';
if(parseFloat(w[i].style.top)<=-wl){
w[i].ori = false;
}
}else{
w[i].i+=vibration;
var top = w[i].i%180==90?0:wl*Math.cos(w[i].i*Math.PI/180);
w[i].style.top = top+'px';
if(parseFloat(w[i].style.top)>=wl){
w[i].ori = true;
}
}
}
}
setInterval(m,this.speed);
}
}
window.onload = function(){
var targetDom = document.body;
new lightWave(targetDom,0,3,36,120,6,20,40);
new lightWave(targetDom,50,2,70,120,10,30,30);
}
</script>
</head>
<body style="background:#000;margin-top:100px">
</body>
</html>

参数:

var lightWave = function (T,left,thick,sharp,speed,vibration,amplitude,opacity){
    this .cont = T; //需要添加炫光的容器
    this .left = left; //炫光出生时的向右偏移量
    this .thick = thick; //粗细程度
    this .sharp = sharp; //尖锐程度
    this .speed = speed; //波动速度
    this.vibration = vibration; //单位时间内的振动频率
    this .amplitude = amplitude; //振幅
    this .opacity = opacity; //透明度
    this .cont.style.position = 'relative';
    this .move();
}

大家感兴趣可以来讨论一下。

另外,还遇到个问题,上面代码中ie下面的透明度滤镜不起作用,经研究得知,改变父容器的定位会影响子节点的透明滤镜的继承。

以上所述就是本文的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
初学prototype,发个JS接受URL参数的代码
Sep 25 Javascript
extjs两个tbar问题探讨
Aug 08 Javascript
使用JavaScript 编写简单计算器
Nov 24 Javascript
基于JavaScript实现仿京东图片轮播效果
Nov 06 Javascript
使用Node.js给图片加水印的方法
Nov 15 Javascript
js中变量的连续赋值(实例讲解)
Jul 08 Javascript
bootstrap基本配置_动力节点Java学院整理
Jul 14 Javascript
微信小程序数据存储与取值详解
Jan 30 Javascript
vue+element导航栏高亮显示的解决方式
Nov 12 Javascript
JS 创建对象的模式实例小结
Apr 28 Javascript
JavaScript Event Loop相关原理解析
Jun 10 Javascript
vue插件--仿微信小程序showModel实现模态提示窗功能
Aug 19 Javascript
javascript基于DOM实现省市级联下拉框的方法
May 14 #Javascript
javascript搜索框效果实现方法
May 14 #Javascript
javascript操作ul中li的方法
May 14 #Javascript
javascript中createElement的两种创建方式
May 14 #Javascript
javascript常用方法总结
May 14 #Javascript
javascript实现动态改变层大小的方法
May 14 #Javascript
JavaScript中停止执行setInterval和setTimeout事件的方法
May 14 #Javascript
You might like
PHP模板引擎SMARTY
2006/10/09 PHP
php删除文件夹及其文件夹下所有文件的函数代码
2013/01/23 PHP
PHP的Yii框架中过滤器相关的使用总结
2016/03/29 PHP
Yii2简单实现给表单添加验证码的方法
2016/07/18 PHP
[原创]php token使用与验证示例【测试可用】
2017/08/30 PHP
js 新浪的一个图片播放图片轮换效果代码
2008/07/15 Javascript
js 三级关联菜单效果实例
2013/08/13 Javascript
jquery按回车提交数据的代码示例
2013/11/05 Javascript
JS批量修改PS中图层名称的方法
2014/01/26 Javascript
JavaScript中停止执行setInterval和setTimeout事件的方法
2015/05/14 Javascript
举例详解JavaScript中Promise的使用
2015/06/24 Javascript
基于jquery实现复选框全选,反选,全不选等功能
2015/10/16 Javascript
JavaScript中的数组遍历forEach()与map()方法以及兼容写法介绍
2016/05/19 Javascript
Jquery Easyui菜单组件Menu使用详解(15)
2016/12/18 Javascript
微信小程序实现tab左右切换效果
2020/11/15 Javascript
微信小程序如何获取用户收货地址
2018/11/27 Javascript
微信小程序 flexbox layout快速实现基本布局的解决方案
2020/03/24 Javascript
原生js实现简单轮播图
2020/10/26 Javascript
[39:46]完美世界DOTA2联赛PWL S2 LBZS vs Rebirth 第二场 11.25
2020/11/25 DOTA
Python类的基础入门知识
2008/11/24 Python
python进阶教程之循环对象
2014/08/30 Python
python3+selenium自动化测试框架详解
2019/03/17 Python
pyqt5 键盘监听按下enter 就登陆的实例
2019/06/25 Python
python 爬取疫情数据的源码
2020/02/09 Python
基于python实现简单网页服务器代码实例
2020/09/14 Python
Python实现钉钉/企业微信自动打卡的示例代码
2021/02/02 Python
AmazeUI在模态框中嵌入表单形成模态输入框
2020/08/20 HTML / CSS
印度和世界各地的精美产品:Ikka Dukka
2018/02/12 全球购物
什么是Linux虚拟文件系统VFS
2012/01/31 面试题
《守株待兔》教学反思
2014/03/01 职场文书
生态养殖创业计划书
2014/05/06 职场文书
赞美老师的演讲稿
2014/05/22 职场文书
作风建设年活动实施方案
2014/10/24 职场文书
教师学期末个人总结
2015/02/13 职场文书
详解TypeScript的基础类型
2022/02/18 Javascript
浅谈Redis跟MySQL的双写问题解决方案
2022/02/24 Redis