码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2019-05-23 23:23:09      阅读:273      评论:0      收藏:0      [点我收藏+]

标签:数学   支持   mat   var   基础知识   +=   highlight   center   估计   

想在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吧。

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

标签:数学   支持   mat   var   基础知识   +=   highlight   center   估计   

原文地址:https://www.cnblogs.com/fengziwu/p/10914972.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!