FLASH实现滚动条 网页书签效果

2008-04-02 10:34:43来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折


  在网页中司空见惯的滚动条及网页书签效果在FLASH中如何实现呢?首先让我们来看看效果图:

  

  


  上图中,右边的文字既可通过右边的滚动条实现上下自由滚动,又可通过点击左边的文字菜单滚动到指定位置。下面我们就来逐步介绍其实现方法。

  声明:

  1> 本文主要介绍AS脚本的实现,画图部分大家能够下载源文档后自己研究;

  2> as部分假如有不了解的命令、函数,大家能够查阅as相关书籍或actionscript字典,本文不对每一段代码进行解释;

  3> 由于本人的as水平有限,做出来的东西一定有很多有待改进的地方,欢迎大家到本文发表的相关论坛/博客批评指正:D

  第一步:场景中的元素

  因为这一步主要是在场景中加入文字和图片,大家能够下载源文档后用FLASH打开自己研究,这里就不周详介绍各元素的画法了。

  >>点击下载FLA源文档

  关于场景中的元素,这里要说清楚的是各个MovieClip(影片剪辑,以下简称mc)的命名,如下图所示(注:这里说的命名,是指把mc放到场景中后在Properties<属性>面板中的命名,而不是在Library<库>中的命名,见图中红色线条框出的部分):

  


  说 明:

  对应于Timeline(时间线)上的各层:

  mask层:只有一个mc,名为mask;

  scrolling层:

  


  名为scrolling;

  txt层:mc名为txt。txt内,八个mc,从上至下分别命名为title1~title8;

  menu层:从上至下分别命名为title1~title8;

  第二步:滚动条

  选中as层的第一帧,按F9打开Actions面板,输入如下代码:

  //滚动条初始化开始:

  scrolling.onPress = function() {

  this.gotoAndStop("dark");//滚动条变暗

  lock = "no";

  };

  scrolling.onRelease = function() {

  this.gotoAndStop("light");//滚动条变亮

  lock = "yes";

  };

  maskheight=177;//mask的高度

  //滚动条初始化结束

  txt.ymin = txt._y;//txt在y方向的初始值(最小值)

  txt.y1 = txt.ymin txt._height-maskheight;//txt在y方向最多能够到达的地方(最大值)

  说 明:

  设一变量lock,记录鼠标是否在滚动条(scrolling)上按下,按下时,lock值为"no",反之则为"yes";

  maskheight为文字蒙板(mask)的高度,开始觉得用mask._height就行了,但测试时发现mask._height值为210,而在Properties面板上看到的mask的值却是177,不知道是出了什么错-_-!

  这段代码只是对滚动条的初化连同一些参数的配置和获取。

  选中as层的第二帧,按F9打开Actions面板,输入如下代码:

  //滚动条实现

  if (lock == "no" and _xmouse>(scrolling._x-scrolling._width) and _xmouse<(scrolling._x 2*scrolling._width)) {

  //lock为no,并且鼠标在x方向的位置不至于太偏

  distance = _ymouse-scrolling._y;//鼠标在y方向的移动距离,即滚动条在y方向的移动距离

  if ((txt._y>=txt.ymin and txt._y<=txt.y1) or (txt._y>txt.y1 and distance>0) or (txt._y<txt.ymin and distance<0)) {

  /*假如txt在y方向的位置没超过指定范围(ymin to y1)或

  1.txt在y方向的位置小于ymin(过上),但鼠标是向下移动

  2.txt在y方向的位置大于y1(过下),但鼠标是向上移动

  则执行下面的程式*/

  scrolling._y = distance;

  txt._y -= distance*((txt._height-maskheight)/(maskheight-scrolling._height));

  }

  }

  说 明:

  这段代码是滚动条效果的核心部分。

  要理解这段代码,我们必须先清楚FLASH内的座标,如下图所示:

  

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇: Flash视觉特效的制作

下一篇: FlashPlayer8新特性