中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 图形图象 > 网页设计 > Flash
Flash MX 编程深层次应用-高级特效(5)
作者:未知 时间:2005-05-21 12:12 出处:ChinaZ.com 责编:chinaitpower
              摘要:Flash MX 编程深层次应用-高级特效(5)
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的办法,然后不断产生出新的区域,又同时消除以前的区域,保证在画面上只有固定个数的填充区域,一运行,效果非常理想。通过这个例子可以说明一个道理,就是编程在很多地方是相通的,在这个地方用到的思路也可以在另一个地方用到,由于核心思想不同,出来的效果也就不相同了。

关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有