一行代码让圆周运动不依赖于三角函数

Posted fengziwu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一行代码让圆周运动不依赖于三角函数相关的知识,希望对你有一定的参考价值。

想在AS3里实现圆周运动,我们一般都这么写:

var centerX:Number = 300;
var centerY:Number = 200;
var radius:Number = 20;
var degree:Number = 0;
addEventListener(Event.ENTER_FRAME, enterFrameHandler);
function enterFrameHandler(event:Event):void{
  display.x = centerX + radius * Math.cos(degree * Math.PI / 180);
  display.y = centerY + radius * Math.sin(degree * Math.PI / 180);
  degree += 5;
}

  其中centerX和centerY分别是圆心的x坐标和y坐标,radius为圆周的半径,degree是当前角度。

代码中出现了cos和sin两个三角函数,可别觉得这些中学的基础知识大家都懂,没准就在高中毕业当天,就有不少人把这些函数都还给老师了。就像iloveas,除了“欲穷干里日”一句外,小学课本里教过的古诗词都早给我忘的一干二净了。

那么,有没办法不通过这些蛋疼的三角函数来实现同样的效果呢?说到这里,大神们估计很容易想到向量、矩阵等高端货,不过今天iloveas给大家分享一个更简单的做法,只要一行代码,什么弦什么切的都可以一边凉快去了:

var pt:Point = Point.polar(radius, degree * Math.PI / 180);
display.x = centerX + pt.x;
display.y = centerY + pt.y;

  如果你喜欢装逼,那以下写法会更适合你:

var pt:Point = Point.polar(radius, degree * Math.PI / 180).add(new Point(centerX, centerY));
display.x = pt.x;
display.y = pt.y;

  不可否认的是,iloveas今天介绍的方法在运行效率方面比自己写三角函数要差的多,但它很适合像iloveas这样的数学白痴们入门编程这一行。在这点上,AS3确实做的比其他语言好,所以不管AS3的明天何去何从,大家都来多多支持AS3吧。

以上是关于一行代码让圆周运动不依赖于三角函数的主要内容,如果未能解决你的问题,请参考以下文章

Python的学习之-流程控制

转五种常见的 PHP 设计模式

AEJoy —— 随机运动表达式之球面上的随机运动

Android 片段和依赖注入

Android片段和依赖注入

常用Javascript代码片段集锦