adobeflashplayer:Flash AS3.0例子教程:AS3.0代码制作3D旋转动画效果

  效果演示:





  1、新建Flash文档创建5 个图形(或导入5张图片到库中)

  2、创建个影片剪辑1层为图片层2层为代码层在1层把5张图片分别放在5帧中在代码层输入stop; 如图:

Flash AS3.0例子教程:AS3.0代码制作3D旋转动画效果

  3、Ctrl + L 打开库右键单击影片剪辑例子做链接类名为:IconMenu 如图:

Flash AS3.0例子教程:AS3.0代码制作3D旋转动画效果

  4、返回场景1图层1为背景层图层2为代码层在图层1导入背景图片图层2输入代码:

1. "Math2.as"
2. //图片容器
3. var menu:Sprite= Sprite;
4. //使图标移动
5. menu.x = 300;
6. menu.y = 200;
7. //注册事件侦听器
8. menu.addEventListener(Event.ENTER_FRAME,moveMenu);
9. this.addChild(menu);
10. //椭圆在x 和y 轴上截距
11. var disx:Number = 200;
12. var disy:Number = 10;
13. //旋转速度
14. var speed:Number = 0;
15. initMenu(5);
16. function initMenu(n:) {
17. for (var i:; i<n; i) {
18. var mc:MovieClip = IconMenu;
19. //缩小图标
20. mc.scaleX = mc.scaleY = .5;
21. menu.addChild(mc);
22. }
23. }
24. //事件侦听器
25. function moveMenu(e:Event):void {
26. //获取图标数
27. var iconCount: = menu.numChildren;
28. //定义
29. var depthArray:Array = Array;
30. //把360度平分
31. var angle:Number = 360 / iconCount;
32. for (var z:; z<iconCount; z) {
33. //根据深度获取图标
34. var mc:MovieClip = menu.getChildAt(z);
35. //跳转到区别帧来显示区别图标
36. mc.gotoAndStop(z+1);
37. //设置图标位置
38. mc.x = cosD(speed + angle*z) * disx;
39. mc.y = sinD(speed + angle*z) * disy;
40. Prop(mc,"alpha");
41. Prop(mc,"scaleX",.2,.7);
42. Prop(mc,"scaleY",.2,.7);
43. //保存图标到
44. depthArray[z] = mc;
45. }
46. //重新设置图标深度
47. arrange(depthArray);
48. speed 2;
49. }
50. function arrange(depthArray:Array):void {
51. //按照y坐标排序
52. depthArray.sortOn("y", Array.NUMERIC);
53. var i: = depthArray.length;
54. while (i--) {
55. menu.ChildIndex(depthArray[i], i);
56. }
57. }
58. function Prop(mc:MovieClip,prop:String,n1:Number = .5, n2:Number = 1):void {
59. mc[prop] = ((mc.y + 2 * disy) / disy - 1) / 2 * (n2 - n1) + n1;
60. }


  5、新建.as文档保存名为:Math2.as (这个文档是进行 3角计算)

  输入代码: 

1. //角度转弧度
2. function angleToRadian(angle:Number):Number
3. {
4. angle*(Math.PI/180);
5. }
6. //弧度转角度
7. function radianToAngle(radian:Number):Number
8. {
9. radian*(180/Math.PI);
10. }
11. //计算正弦值
12. function sinD(angle:Number):Number
13. {
14. Math.sin(angleToRadian(angle));
15. }
16. //计算余弦值
17. function cosD(angle:Number):Number
18. {
19. Math.cos(angleToRadian(angle));
20. }
21. //计算反正切
22. function atan2D(y:Number, x:Number):Number
23. {
24. radianToAngle(Math.atan2(y, x));
25. }

复制代码


  把fla文档和Math2.as 文档保存在同目录下进行测试

Tags:  flash播放器 flash插件 flashplayer adobeflashplayer

延伸阅读

最新评论

发表评论