Flash AS 实例进阶 图片闪白切换效果实现代码
“闪白”换场是电视拍摄用语,是画面切换过程中场景出现空白,有人将这一手法应用到网页图片的切换上来,也是一种不错的组图显示效果,这里我们用动作脚本来制作一个这样的实例。
基本思路
① 构建一个数组放置库中的多个类型为 MC 的图片。
②将数组中的元素依次加载到主场景。
③利用帧循环来依次改变各 MC 的状态。
新知识点
my_array = new Array(); // 使用构造函数来创建一个数组。
_root.attachMovie () // 加载 MC 到主场景,本实例是按索引从数组中取得 MC 。
补充模糊滤镜
import flash.filters.BlurFilter;//载入滤镜类-模糊
var myBlurfilter:BlurFilter = new BlurFilter(blurX:Number, blurY:Number, quality:Number);// 创建一个模糊滤镜对象
var filterArray:Array = new Array();//创建一个临时数组
filterArray.push(myBlurfilter);//将新元素添加到数组的结尾
myMovieClip.filters = filterArray;//MC增加滤镜
实例说明
① 8 个同样大小的位图都转换为 MC ,并在链接属性里作好相关设置。
②第 1 帧加载 MC 和变量初始化 , 第 2 帧到第 7 帧设置循环, MC 被依次改变属性为可见,并用透明度的变化来实现白和非白之间的画面转换。
编写动作脚本
①在第 1 帧上输入:
tu = new Array("a", "b", "c", "d", "e", "f", "g", "h");// 创建一个数组,其中的元素是库中的 MC
for (i=1; i<=8; i++) {
_root.attachMovie(tu[i-1], "h"+i, i);// 将数组中 MC 加载到主场景的对象上
with (_root["h"+i]) {// 设置对象属性
_x = 250;
_y = 90;
_visible = false;
}
}
i = 1;
n = 0;
② 在第 2 帧上输入:
_root["h"+i]._visible = true;
_root["h"+i]._alpha = n*5;// 帧循环中透明度由 0 到 100 递加
n++;
③ 在第 3 帧上输入:
if (n<21) {
gotoAndPlay(2);
}
④ 在第 5 帧上输入:
_root["h"+i]._alpha = n*5; // 帧循环中透明度由 100 到 0 递减
n--;
⑤ 在第 6 帧上输入:
if (n>0) {
gotoAndPlay(5);
} else {
gotoAndPlay(2);
i++;
if (i>8) {
i = 1;
}
}
要点分析
①数组中的元素就是库中含有位图的 MC 元件,共 8 个,数组元素的索引也是就是序列号是从 0 开始,这里就是 0-7 ,将各 MC 再分别加载到一个新对象 MC 上,再由脚本控制这些新对象的状态。
②实例中是一个大循环里面嵌套两个小循环,大循环是 8 个 MC 循环显示,而在显示一个 MC 的循环里,有前段的透明度由 0 到 100 的以 5 递增的 20 次小循环,和后段的反向循环,显示的效果就是图片由白逐渐变清晰再由清晰变白,然后下一张图片以同样过程显示。
小结
本讲学习的内容是了解和应用了一维数组,这是数组使用的初步方法,在今后的学习中会掌握更加复杂的数组应用,数组的应用是广泛的,而且有简洁清晰调用方便的特点 。帧循环也是应用普遍的方法,这个实例有助于我们了解和掌握循环过程。
课后练习
修改源文件,使两个图片间的切换是前面的淡出,后面的淡入,中间不出现空白。
提示:在帧循环过程中不是一个 MC 而是两 MC 同时改变状态,在最后一张图和第一张图片之间不出现空白更要专门编写帧循环语句。范例效果:
补充模糊效果实例
在第 2 帧上输入:
_root["h"+i]._visible = 1;
import flash.filters.*;//载入滤镜类
mohu = new BlurFilter(n, n, 1);// 创建一个模糊滤镜对象
shuzu = new Array();//创建一个临时数组
shuzu.push(mohu);//将新元素添加到数组的结尾
_root["h"+i].filters = shuzu;//将滤镜加到MC上
//_root["h"+i].filters = [mohu];//简略写法,可去掉4-6行
_root["h"+(i+1)]._visible = 1;
_root["h"+(i+1)]._alpha = n*5;
n++;