看到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"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下面的透明度滤镜不起作用,经研究得知,改变父容器的定位会影响子节点的透明滤镜的继承。
以上所述就是本文的全部内容了,希望大家能够喜欢。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
桃源资源网 Design By www.nqtax.com
暂无“JavaScript实现Flash炫光波动特效”评论...