当前位置: 首页 > 图文教程 > Flash动画 > Flash动画制作 > AS3.0实用代码:绘制各种各样三角形

Flash动画制作
Flash制作超酷的旋转图像像册视觉效果
Flash轻松制作2008北京奥运邮票
Flash入门:制作圆形路径运动动画的技巧
在Flash中制作紧紧跟随鼠标的按钮说明文字
Flash制作动画的经典问题问答
Flash入门实例:制作有趣的拍照效果动画
高级游戏制作:Flash制作物体弹跳电脑游戏
Flash形状补间打造霓虹灯效果
用Flash AS简单制作可以任意拖动的四边形
Flash游戏制作基础:跟随鼠标的曲线
用Flash制作课件中的倒计时动画效果
Flash形状补间动画:看我七十二变教程
用Flash制作折扇动画
Flash简单制作文字遮罩效果
Flash打造美丽星空特效
Flash简单制作打字效果
Flash在课件中加个画水平线工具
Flash绘制卡通女孩头像
Flash鼠标跟随教程:制作蜻蜒点水
Flash教程:浇筑效果的制作

Flash动画制作 中的 AS3.0实用代码:绘制各种各样三角形


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-01-04   浏览: 93 ::
收藏到网摘: n/a

以下介绍的是如何用程序 as3 (action script 3.0)画出各种各样的三角形:

一、根据三个顶点画出三角形

这是最简单的画法

package com.king{
/*
author: ShangBin Feng
QQ: 334973991
*/
import flash.display.Sprite;
import flash.geom.Point

public class testTriangle extends Sprite{
  public function testTriangle(){
   //已知条件
   var pointA:Point=new Point(0,0);
   var pointB:Point=new Point(50,55);
   var pointC:Point=new Point(0,70);

   //画三角形

   graphics.lineStyle(1, 0xff0000, 1);
   graphics.moveTo(pointA.x,pointA.y);
   graphics.lineTo(pointB.x,pointB.y);
   graphics.lineTo(pointC.x,pointC.y);
   graphics.lineTo(pointA.x,pointA.y);
  }
}
}

 

二、画等腰三角形

1、等腰三角形可以看做其两腰交叉的那个点在一个圆的圆心,那么其他两个顶点则在这个圆上,假设圆心坐标为(0,0),圆的半径为r,两腰夹角为Q,可得另个顶点坐标为(r,0),最后个顶点坐标为(r*cosQ,r*sinQ);

程序为

package com.king{
/*
author: ShangBin Feng
QQ: 334973991
*/
import flash.display.Sprite;
import flash.geom.Point
public class testTriangle extends Sprite{
  public function testTriangle(){
   //已知条件
   var r:Number=100;
   var Q:Number=30*(2*Math.PI/360);//这里得到是弧度,即30度对应的弧度数
   //画三角形
   graphics.lineStyle(1, 0xff0000, 1);
   graphics.moveTo(0,0);
   graphics.lineTo(r,0);
   graphics.lineTo(r*Math.cos(Q),r*Math.sin(Q));
   graphics.lineTo(0,0);
  }
}
}

2、等边三角形可看做两腰夹角为60度的等腰三角形,只需知道边长,即可按照上面的方法画出

3、如果已知条件为 两腰夹角Q,底边长度d,那么两腰的长度即圆的半径r 为d*Math.PI/(2*Q),再按照上面的方法也可画出

4、如果知道等腰三角形的腰长r 和底边长d 也可求出
假设两腰夹角为x ,沿顶点画出等腰三角形的垂直平分线,可看出sin(x/2)=(d/2)/r,可求出夹角Q=(Math.asin((d/2)/r))/2,再按照上面的方法也可画出

三、画普通的三角形

1、已知两角一边

package com.king{
/*
author: ShangBin Feng
QQ: 334973991
*/
import flash.display.Sprite;
import flash.geom.Point;
public class testTriangle extends Sprite{
  public function testTriangle(){
   //已知条件
   var a:Number=100;
   var A:Number=90*2*Math.PI/360;
   var B:Number=30*2*Math.PI/360;
   //画三角形
   var b:Number=a*Math.sin(A)/Math.tan(B)+a*Math.cos(A);
   graphics.lineStyle(1, 0xff0000, 1);
   graphics.moveTo(0,0);
   graphics.lineTo(a,0);
   graphics.lineTo(b*Math.cos(A),b*Math.sin(A));
   graphics.lineTo(0,0);
  }
}
}

2、已知两边和此两边的夹角

package com.king{
/*
author: ShangBin Feng
QQ: 334973991
*/
import flash.display.Sprite;
import flash.geom.Point;
public class testTriangle extends Sprite{
  public function testTriangle(){
   //已知条件
   var a:Number=100;
   var b:Number=200;
   var A:Number=90*2*Math.PI/360;
   //画三角形
   graphics.lineStyle(1, 0xff0000, 1);
   graphics.moveTo(0,0);
   graphics.lineTo(a,0);
   graphics.lineTo(b*Math.cos(A),b*Math.sin(A));
   graphics.lineTo(0,0);
  }
}
}

3、已知三条边长,最大边和最小边之差不能大于第三边

package com.king{
/*
author: ShangBin Feng
QQ: 334973991
*/
import flash.display.Sprite;
import flash.geom.Point;
public class testTriangle extends Sprite{
  public function testTriangle(){
   //已知条件
   var a:Number=100;
   var b:Number=200;
   var c:Number=250;
   //画三角形
   var x=(a*a+b*b-c*c)/(2*a);
   var y=Math.sqrt(b*b-x*x);
   graphics.lineStyle(1, 0xff0000, 1);
   graphics.moveTo(0,0);
   graphics.lineTo(a,0);
   graphics.lineTo(x,y);
   graphics.lineTo(0,0);
  }
}
}