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 相关文章推荐
JS 控制CSS样式表
Aug 20 Javascript
extjs之去除s.gif的影响
Dec 25 Javascript
js无刷新操作table的行和列
Mar 27 Javascript
jQuery.position()方法获取不到值的安全替换方法
Mar 13 Javascript
简单谈谈node.js 版本控制 nvm和 n
Oct 15 Javascript
Js与Jq获取浏览器和对象值的方法
Mar 18 Javascript
解决OneThink中无法异步提交kindeditor文本框中修改后的内容方法
May 05 Javascript
Node做中转服务器转发接口
Oct 18 Javascript
node简单实现一个更改头像功能的示例
Dec 29 Javascript
vue-cli3.0+element-ui上传组件el-upload的使用
Dec 03 Javascript
Javascript实现一朵从含苞到绽放的玫瑰
Mar 30 Javascript
vue单页应用的内存泄露定位和修复问题小结
Aug 02 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
基于qmail的完整WEBMAIL解决方案安装详解
2006/10/09 PHP
Android ProgressBar进度条和ProgressDialog进度框的展示DEMO
2013/06/19 PHP
PHP exif扩展方法开启详解
2014/07/28 PHP
PHP实现读取文件夹及批量重命名文件操作示例
2019/04/15 PHP
Gambit vs ForZe BO3 第二场 2.13
2021/03/10 DOTA
比较简单的异步加载JS文件的代码
2009/07/18 Javascript
JavaScript Event学习第八章 事件的顺序
2010/02/07 Javascript
基于jQuery的message插件实现右下角弹出消息框
2011/01/11 Javascript
div失去焦点事件实现思路
2014/04/22 Javascript
avascript中的自执行匿名函数应用示例
2014/09/15 Javascript
jQuery+HTML5实现手机摇一摇换衣特效
2015/06/05 Javascript
跟我学习javascript的var预解析与函数声明提升
2015/11/16 Javascript
打造自己的jQuery插件入门教程
2016/09/23 Javascript
Jq通过td获取同行其它列td的方法
2016/10/05 Javascript
js中DOM三级列表(代码分享)
2017/03/20 Javascript
jQuery开源组件BootstrapValidator使用详解
2017/06/29 jQuery
JavaScript实现的原生态兼容IE6可调可控滚动文字功能详解
2017/09/19 Javascript
vuex + axios 做登录验证 并且保存登录状态的实例
2018/09/16 Javascript
js根据需要计算数组中重复出现某个元素的个数
2019/01/18 Javascript
解决vuecli3中img src 的引入问题
2020/08/04 Javascript
easy_install python包安装管理工具介绍
2013/02/10 Python
python遍历 truple list dictionary的几种方法总结
2016/09/11 Python
解决python3 requests headers参数不能有中文的问题
2019/08/21 Python
Python面向对象程序设计之继承、多态原理与用法详解
2020/03/23 Python
海淘零差价,宝贝全球购: 宝贝格子
2016/08/24 全球购物
俄罗斯的精英皮具:Wittchen
2018/01/29 全球购物
Ben Sherman官方网站:英国男装品牌
2019/10/22 全球购物
欧姆龙医疗欧洲有限公司:Omron Healthcare Europe B.V
2020/06/13 全球购物
机械电子工程专业推荐信范文
2013/11/20 职场文书
讲文明树新风公益广告宣传方案
2014/02/25 职场文书
关于读书的演讲稿500字
2014/08/27 职场文书
我为党旗添光彩演讲稿
2014/09/13 职场文书
2015年大学元旦晚会活动策划书
2014/12/09 职场文书
高校教师个人总结
2015/02/10 职场文书
图文详解Nginx版本平滑升级方案
2021/09/15 Servers
前端实现滑动按钮AJAX与后端交互的示例代码
2022/02/24 Javascript