每天学一点Flash(49) 三角函数在Flash中的应用

 假设半径为R, A 和B 都是已知的点,坐标分别为A(x1,y2),B(x2,y2) 求C 和D 点坐标?

 

一个数学坐标系分为四个象限,右上为第一象限 左上第二象限,左下第三象限,右下第四象限 。为了

求出鼠标坐标点A(x1,y1)和中心点B(x2,y2)连线的垂直中线和圆的两个交点C和D,这里需要借助

几个重要的三角函数。

Math.atan2,如果知道两点的坐标就可以求出反余切的角度。

作AB 的连线的垂直分线CD,和半径为R的交于两点C和D,继续作A的垂直线交于坐标系X轴的D点,利用

Flash 的Math.atan2利用已知的条件角DBC的角度就是

90度减去反余切的角度。借助这个角度,通过余弦和正弦的函数求出C点坐标,同理D的坐标也是一样的

求法。

AB和CD垂直,知道90度的角

Flash as 2.0 代码.

var R:Number=100;//定义半径为5
var x1:Number=Stage.width/2;
var y1:Number=Stage.height/2;
var rot:Number=0;
onEnterFrame=function(){
clear();
lineStyle(1, 0xFF00FF, R);
moveTo(x1, y1);//中心点坐标
lineTo(_root._xmouse,_root._ymouse);
rot=Math.PI/2-Math.atan2(_root._ymouse-y1, _root._xmouse-x1);

//case 1第一象限
if(_root._xmouse >=x1 && _root._ymouse <=y1)
{   
 lineTo(x1+R*Math.cos(rot),y1-R*Math.sin(rot)); 
 lineTo(x1-R*Math.cos(rot),y1+R*Math.sin(rot)); 
 lineTo(_root._xmouse,_root._ymouse);
 
}
//case2第二象限
if(_root._xmouse<=x1 && _root._ymouse<=y1)
{    
 lineTo(x1+R*Math.cos(rot),y1-R*Math.sin(rot));
 lineTo(x1-R*Math.cos(rot),y1+R*Math.sin(rot));
 lineTo(_root._xmouse,_root._ymouse);
 
}
//case 3 第三象限
if(_root._xmouse<=x1 && _root._ymouse>=y1)
{
 lineTo(x1+R*Math.cos(rot),y1-R*Math.sin(rot));
 lineTo(x1-R*Math.cos(rot),y1+R*Math.sin(rot));//
 lineTo(_root._xmouse,_root._ymouse);
 
}

//case4 第四象限
if(_root._xmouse>=x1 && _root._ymouse>=y1)
{  trace(Math.atan2(_root._ymouse-y1, _root._xmouse-x1));
 lineTo(x1+R*Math.cos(rot),y1-R*Math.sin(rot));
 lineTo(x1-R*Math.cos(rot),y1+R*Math.sin(rot));
 lineTo(_root._xmouse,_root._ymouse);
 
}


}


  

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值