分享
 
 
 

AS教程:用动态遮罩实现液化效果-Flash

王朝数码·作者佚名  2008-11-18
窄屏简体版  字體: |||超大  

先看效果:将鼠标在图片上移动看看效果。

制作方法:

1. 新建flash文档,将帧频调到31.导入一张图片。

2. 新建一影片剪辑,将图片拖入。然后回到主场景,将该MC放到舞台上,居中对齐。打开属性面板实例名称设为:pic_mc.

3. 新建一影片剪辑,用椭园工具画一个无笔触任一填充的园,这个园应该覆盖图片的大部分。

回到主场景,新建一层,将库中的园元件拖上舞台。打开属性面板,实例名称为:mask_mc.将这一层拖到图片层的下面。

4. 新建一层,取名为action,输入下列代码:

this.createEmptyMovieClip("theScene", this.getNextHighestDepth());

var maxImages:Number = 20;

dupeAndPlace = function (image:MovieClip):Object {

var arrHolder:Object = new Object();

arrHolder.pics_arr = new Array(0);

arrHolder.masks_arr = new Array(0);

for (var i = 1; i

var dnm = "image" + i;

var mnm = "mask" + i;

var imgObj = {_x:image._x, _y:image._y, _xscale:100+(i*1.7), _yscale:100+(i*1.7)};

var maskObj = {_xscale:Math.floor(100/i+3), _yscale:Math.floor(100/i+3), _x:this._xmouse, _y:this._ymouse};

var theDupedImage = image.duplicateMovieClip(dnm, theScene.getDepth()+ i, imgObj);

var theDupedMask = mask_mc.duplicateMovieClip(mnm, theScene.getDepth()+(i*50), maskObj);

theDupedImage.setMask(theDupedMask);

arrHolder.pics_arr.push(theDupedImage);

arrHolder.masks_arr.push(theDupedMask);

}

mask_mc._visible = false;

return arrHolder;

};

makeWaves = function (masks_arr:Array) {

for (var i = masks_arr.length; i0; i--) {

masks_arr[i]._x += (this._xmouse-masks_arr[i]._x)/maxImages*i;

masks_arr[i]._y += (this._ymouse-masks_arr[i]._y)/maxImages*i;

}

};

this.liquefyImage = function(theImage:MovieClip){

var arrHolder:Object = dupeAndPlace(theImage);

onEnterFrame = function(){

makeWaves(arrHolder.masks_arr);

}

}

pic_mc.onRollOver = function(){

liquefyImage(pic_mc);

}

OK,大功告成!

测试影片。代码分析:

看到这个效果我们很可能想到虑镜,其实不然,这就是用遮罩实现的效果。原理并不复杂。若干个随鼠标运动的园型遮罩,下面也是若干个被遮罩的图片,遮罩和被遮罩大小都不断变化,从而实现了这个效果。

首先创建了一个空的MC,然后预设了一个数量,上面我们说到若干个,这里设为20。

this.createEmptyMovieClip("theScene", this.getNextHighestDepth());

var maxImages:Number = 20;

接下创建一个函数用来创建这些若干个遮照和图片。

dupeAndPlace = function (image:MovieClip):Object {

创建一个对象用来存放这些遮罩和图片。

var arrHolder:Object = new Object();

接下来创建两个数组一个用来存放图片,一个用来存放遮罩:

arrHolder.pics_arr = new Array(0);

arrHolder.masks_arr = new Array(0);

接下来用一个for循环来创建这些图片和遮罩:

for (var i = 1; i

用两个变量来代表图片和遮罩,这样一个循环下来,就产生了20个图片和遮罩,当然这时还没创建,只是产生了20个名称而已:

var dnm = "image" + i;

var mnm = "mask" + i;

接下来再创建两个对象,用来存放将要产生的遮罩和图片的属性:

var imgObj = {_x:image._x, _y:image._y, _xscale:100+(i*1.7), _yscale:100+(i*1.7)};

var maskObj = {_xscale:Math.floor(100/i+3), _yscale:Math.floor(100/i+3), _x:this._xmouse, _y:this._ymouse};

下面创建两个对象分别复制图片和遮罩,并将上面两个对象中存的属性赋给它们。

var theDupedImage = image.duplicateMovieClip(dnm, theScene.getDepth()+ i, imgObj);

var theDupedMask = mask_mc.duplicateMovieClip(mnm, theScene.getDepth()+(i*50), maskObj);

然后将遮罩应用于图片上:

theDupedImage.setMask(theDupedMask);

然后将遮罩和图片存到上面创建的数组中。

arrHolder.pics_arr.push(theDupedImage);

arrHolder.masks_arr.push(theDupedMask);

将舞台上的mask_mc元件隐藏。

mask_mc._visible = false;

返回存放这些遮罩和图片的对象:

return arrHolder;

上面这些动作都是在for循环中,因此,到现在就已创建了20对大小不一遮罩和图片,并且都被设置了遮罩和被遮罩的关系。

下面创建一个函数使这些遮罩向鼠标靠近:

makeWaves = function (masks_arr:Array) {

for (var i = masks_arr.length; i0; i--) {

masks_arr._x += (this._xmouse-masks_arr._x)/maxImages*i;

masks_arr._y += (this._ymouse-masks_arr._y)/maxImages*i;

}

};

创建一个函数用来执行上面创建的创建这些遮罩和图片的函数,并在每隔一帧时调用一次让遮罩靠近鼠标的函数:

this.liquefyImage = function(theImage:MovieClip){

var arrHolder:Object = dupeAndPlace(theImage);

onEnterFrame = function(){

makeWaves(arrHolder.masks_arr);

}

}

下面是当鼠标移过图片时调用上面这个函数:

pic_mc.onRollOver = function(){

liquefyImage(pic_mc);

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有