源文件下载
>点击查看动画效果<实例2-6时钟
基本思路
① 作 3 个指针 MC ,分别按不同的速度旋转,实现时钟效果。
②若 要拖拽效果,则要把 12 个数字分别作成 MC 。然后作鼠标跟随。
新知识点 ① Date 类的方法的应用:
实例说明
①此时钟实例是由数字和指针共 15 个 MC 组成,并又是嵌套在 MC “ biao” 中,各 MC 的注册点一定要确定准确,
② 分别将 MC “ biao” 放在主时间轴的 3 个帧上,为各帧上的 MC 编写不同的脚本。
③ 设一按钮用于各帧之间的跳转
编写动作脚本 ① 在第 1 帧到第 2 帧的 MC 上输入:
stop();
④ 在第 2 帧上输入:
biao.startDrag(true);
⑤在第 1 帧到第 2 帧的按钮上输入:
on (release) { nextFrame();}
⑤在第 3 帧的按钮上输入:
on (release) { gotoAndStop(1);}要点分析
① 时针: this.b13._rotation = ((Hours*30)+(s.getMinutes()/2))
首先看 ((Hours*30) ,因为走一周 12 小时是 360 度,那每小时就是走 30 度,用本地时间的小时数乘于 30 就是指针指向的度数。,如 3 点就是 3*30 ,指针在 90 度位置,但这样只能是按小时发生动作,要显示中间的指针变化还需加上 (s.getMinutes()/2) ,这个表达式是计算的当前分钟乘于每分钟在一个小时刻度内走的度数( 0.5 度),这两个表达式相加就是以小时和分钟计算出的时针旋转度数。
② 缓冲公式: this["b"+i].xl = (this["b"+(i-1)]._x-this["b"+i]._x)/2+this["b"+i].xl*0.3;
为便于观看首先把数值具体化: b2.xl=( b1._x-b2._x)/2+b2.xl*0.3; 其中的 ( b1._x-b2._x)/2 ,我们在导航条那课已经用过类似的方法,这里是取两个 MC 坐标值的差的二分之一,这个表达式的结果在不断的由大到小直至为 0 ,其中的 b2.xl*0.3 , 是有意增加的偏差值, 有叫抖动率的,也是由大到小变化最后到 0 ,这两个表达式计算的结果赋给变量 b2.xl ,有了这样的公式,鼠标跟随就会有延时和抖动效果。
小结本讲学习的目的是掌握时钟的运动原理,此外还学习 一种缓冲公式的运用,也是很有实用价值的内容,希望课下能用数字代入加深理解。
课后练习不要秒针跳跃式旋转,而要平缓连贯地旋转,范例效果:
>点击查看动画效果<练习2-6
>点击查看动画效果<练习2-6-2
查看全套"Flash AS 实例进阶教程"
IT时代网(关注微信公众号ITtime2000,定时推送,互动有福利惊喜)所有原创文章版权所有,未经授权,转载必究。
创客100创投基金成立于2015年,直通硅谷,专注于TMT领域早期项目投资。LP均来自政府、互联网IT、传媒知名企业和个人。创客100创投基金对IT、通信、互联网、IP等有着自己独特眼光和丰富的资源。决策快、投资快是创客100基金最显著的特点。
小何
小何
小何
小何