首 页免费资源建站技术源码下载软件下载精品淘吧客户留言
用户登陆 | 用户注册
您当前的位置:笃志小屋建站技术网页设计Flash → 文章内容
Flash MX 编程深层次应用-高级特效(5)
作者:佚名  来源:不详  发布时间:2007-9-11 0:18:59

3.3 虚幻特效(1)

    

Flash MX特效中,虚幻的影像、复杂的粒子系统、激情的火焰、跳动的波浪都属于一种虚幻的内容。一般来说,在矢量动画中是很难制作出这种效果的,但是Flash MX编程在绘图方面的加强,使这些效果的实现成为可能,下面将介绍两个这方面的例子。在Flash MX中仍然没有增加对3D的支持,所以对3D物体的操作只能靠程序来完成,在第三个实例中讲述了一个3D物体旋转的应用,它对广大程序员来说是一个极好的范例。

3.3.1  虚幻实境

现在介绍一个程序技巧要求不高,但却要求编程人员有非凡想像力的特效——虚拟实境。这个特效原理非常简单,首先产生出一批用来控制的点,然后用这些点画出一个封闭的区域,然后以随机色、透明度为3的方式进行填充。在产生一批这样的区域后,将这些区域随机放置、叠加,就创造出一个真实而又虚幻的特效。请看下面的代码:

//在低分辨率下运算会快些,才能产生出朦胧美

_quality = "LOW";

//产生8个用来控制的点

for (i=1; i<=8; i++) {

    _root.createEmptyMovieClip("point"+i, i+10);

    _root["point"+i]._x = Stage.width/2;

    _root["point"+i]._y = Stage.height/2;

    //控制点的位置在正负5个点之内变化

    _root["point"+i].xVel = Math.floor(Math.random()*10)-5;

    _root["point"+i].yVel = Math.floor(Math.random()*10)-5;

    _root["point"+i].onEnterFrame = function() {

             this._x += this.xVel;

             this._y += this.yVel;

      //这两句保证控制点在超出视野时就要回头反向移动

             this._x<0 || this._x>Stage.width ? this.xVel *= -1 : this.xVel;

             this._y<0 || this._y>Stage.height ? this.yVel *= -1 : this.yVel;

    };

}

//定义随机颜色

values = new Array("0", "2", "4", "6", "8", "A", "C", "D");

_root.hexColor="0x"+values[Math.floor(Math.random()*values.length)]+values[Math.floor(Math.random()*values.length)]+values[Math.floor(Math.random()*values.length)]+values[Math.floor(Math.random()*values.length)]+values[Math.floor(Math.random()*values.length)]+values[Math.floor(Math.random()*values.length)];

//产生变形

i = 1;

_root.onEnterFrame = function() {

    name = "dongua_shape_"+i;

    _root.createEmptyMovieClip(name, i+20);

    _root[name].beginFill(_root.hexColor, 3);

    _root[name].moveTo(_root.point1._x, _root.point1._y);

    _root[name].curveTo(_root.point2._x,_root.point2._y, _root.point3._x, _root.point3._y);

    _root[name].curveTo(_root.point4._x,_root.point4._y, _root.point5._x, _root.point5._y);

    _root[name].curveTo(_root.point6._x,_root.point6._y, _root.point7._x, _root.point7._y);

    _root[name].curveTo(_root.point8._x,_root.point8._y, _root.point1._x, _root.point1._y);

    _root[name].endFill();

   //移去以前的区域,仅保留最新的50个区域

    removeMovieClip(_root["dongua_shape_"+(i-50)]);

    i++;

};

这个特效最核心的地方就是每个独立区域的透明度不高,但是当两个透明度为3的地方叠加时,在叠加位置的透明度就变成了6n个透明叠加之后其相应位置透明效果就为3×n。由于区域是随机的,因此叠加的地方也是随机的。不但出来的效果随机了,而且画面还会有一种渐变的层次感,从而产生了超酷的效果!说句实在话,自己都不相信这么短的一段代码可以产生出这么酷的效果。效果如图3-12与图3-13所示。

      

3-12                                      3-13

在制作这个效果初期,先是将这些区域放在一个MC中,然后做了一个定时器,当时间一到就让这个MC的透明度降低直至为0,然后再重新开始新的效果。但是实际演示时,发现这种透明度渐变效果根本不连续,甚至连颜色看上去都有点变化,无法达到理想的效果。解决此问题时可以采用前面特效用到的把不同的区域放到不同的MC的办法,然后不断产生出新的区域,又同时消除以前的区域,保证在画面上只有固定个数的填充区域,一运行,效果非常理想。通过这个例子可以说明一个道理,就是编程在很多地方是相通的,在这个地方用到的思路也可以在另一个地方用到,由于核心思想不同,出来的效果也就不相同了。


2007-9-11 0:18:59免费资源duzhi.net

[ ] [返回上一页] [打 印]

【笃志小屋duzhi.net】

  技术文章导航
  技术文章排行
  精彩推荐
Copyright www.duzhi.net All Right Reserved.
设计制作:翼迅设计室 Equick Desgin Home 在线QQ:303471038
网络备案号:冀ICP备06008201号 站长信箱:webmaster#duzhi.net(将#换为@)
本站部分文章和图片来源于网络和内容提供伙伴,如果侵犯了您的权利,请留言告知,本站定会及时删除相关文件!