当前位置:站长之家学习教程图象图形Flash学习教程 → 文章内容

Flash MX 2004新特性实例学习五(3)

减小字体 增大字体 作者:佚名  来源:不详  发布时间:2006-1-25 17:04:02

18、在Actions层的第2帧的Action面板上增加下面的语句:

  

  function handleHideControlPanel (evt) {

  controlPanel._visible = !evt.target.selected;

  }

  hideCP.addEventListener("click", handleHideControlPanel); //注释1

  function handleMaskeeSelect (evt) {

  for (var i in maskees) { //注释2

  if (maskees[i] == eval(evt.target.selectedRadio.data)) { //注释3

  currentMaskee.setMask(); //注释4

  maskees[i].setMask(currentMask); //注释5

  eval(maskees[i])._visible = true; //注释6

  currentMaskee = maskees[i]; //注释7

  } else {

  eval(maskees[i])._visible = false;

  }

  }

  }

  controlPanel.content.maskeeGroup.addEventListener("click", handleMaskeeSelect); //注释8

  function handleMaskSelect (evt) {

  for (var i in masks) {

  if (masks[i] == eval(evt.target.selectedRadio.data)) { //注释9

  currentMaskee.setMask(masks[i]); //注释10

  eval(masks[i])._visible = true;

  currentMask = masks[i];

  } else {

  eval(masks[i])._visible = false;

  }

  }

  }

  controlPanel.content.maskGroup.addEventListener("click", handleMaskSelect); //注释11

  

  function handleDragging (evt) {

  if (evt.target.selected) {

  this.onEnterFrame = function () { //注释12

  with (currentMask) {

  _rotation += 5;

  _x += (_root._xmouse - _x) * .3;

  _y += (_root._ymouse - _y) * .3;

  }

  }

  } else {

  delete this.onEnterFrame;

  currentMask._x = 275;

  currentMask._y = 200;

  }

  }

  controlPanel.content.cbDrag.addEventListener("click", handleDragging);

  var currentMaskee:MovieClip; //注释13

  var currentMask:MovieClip;

  controlPanel.content.rCity.selected = true;

  city._visible = true;

  controlPanel.content.rStripes.selected = true;

  stripes._visible = true;

  currentMaskee = city;

  currentMask = stripes;

  currentMaskee.setMask(currentMask);

  stop();

  注释1:这里是检查是否显示Window组件。

    注释2:对maskees数组中的每一个元素都去检查一次,也就是所谓的遍历了。

    注释3:检查选中的Button的值是否与数组中的元素相匹配。

    注释4:setMask()的参数为空的话,就是清除之前的遮照效果。

    注释5:设置新的遮照背景。

    注释6:显示新的遮照背景。

    注释7:将当前的遮照背景保存到currentMaskee,以便操作。

    注释8:这里是侦听Window中前面三个Radio的鼠标点击情况。

    注释9:检查选中的Button的值是否与数组中的元素相匹配。

    注释10:设置新的遮照效果。

    注释11:这里是侦听Window中后面三个Radio的鼠标点击情况。

    注释12:这些代码是设置遮照效果跟随鼠标而运动。

    注释13:初始化,设置最初的遮照效果为City效果。

  三、实际用途

  本实例中的setMask()方法在制作遮照效果的时候很有用。其用法为my_mc.setMask(mask_mc),其中my_mc是遮照的背景,mask_mc是遮照的效果(为空的话则是清除遮照效果)。