分析:

正二十面体共有12个顶点、30条棱,其20个面都是正三角形。每条棱所对应的弧度值为1.1071487177940904弧度,这个弧度值可通过求Math.sqrt(5)/5的反余弦值求得。正二十面体的12个点按相对应的位置可以分为6对,把其中一对顶点置于Y轴上,此两点到坐标原点距离相等,则另外五对顶点皆呈倾斜状态,它们穿过坐标原点并环绕Y轴以72度递增旋转。根据这一点,可以先算好第一对倾斜顶点的坐标,然后让它绕Y轴以72度递增旋转4次得到另外四对顶点坐标,至此正二十面体的12个顶点坐标都已清楚,便可以创建模型了。

 package
{
import flash.display.MovieClip;
import flash.display.Sprite;
import flash.events.Event;
import flash.geom.Vector3D;
import flash.net.LocalConnection; /**
* @author Frost.Yen
* @E-mail 871979853@qq.com
* @create 2015-9-7 下午12:58:27
*
*/
[SWF(width="800",height="600")]
public class LineIcosahedron extends Sprite
{
private var _r:Number = 100;
private var _faceArr:Array = [];
private var _focus:Number = 400;
private var _container:Sprite;
private var _lineContainer:Sprite;
public function LineIcosahedron()
{
initViews();
initEventlisteners();
}
private function initViews():void
{
_container = new Sprite();
_lineContainer = new Sprite();
_container.x = _lineContainer.x = 400;
_container.y = _lineContainer.y = 300;
this.addChild(_container);
this.addChild(_lineContainer);
createFace();
}
private function initEventlisteners():void
{
this.addEventListener(Event.ENTER_FRAME,onEnterFrame);
}
private function onEnterFrame(e:Event):void
{
_lineContainer.graphics.clear(); _lineContainer.graphics.lineStyle(3,0x00ffff);
for(var i:int = 0;i<_faceArr.length;i++){
(_faceArr[i] as MovieClip).transform.matrix3D.appendRotation(-(mouseX-_container.x)/50,Vector3D.Y_AXIS);
(_faceArr[i] as MovieClip).transform.matrix3D.appendRotation((mouseY-_container.y)/50,Vector3D.X_AXIS);
//利用焦距实现透视
_faceArr[i].Z = (_faceArr[i] as MovieClip).transform.getRelativeMatrix3D(_container).position.z;
_faceArr[i].X = (_faceArr[i] as MovieClip).transform.getRelativeMatrix3D(_container).position.x*(_focus/(_focus+_faceArr[i].Z));
_faceArr[i].Y = (_faceArr[i] as MovieClip).transform.getRelativeMatrix3D(_container).position.y*(_focus/(_focus+_faceArr[i].Z));
} drawLine();
}
private function createFace():void
{
var angle:Number = 0.5*Math.PI - Math.acos(Math.sqrt(5)/5);
for(var i:int = 0;i<12;i++){
var mc:MovieClip = new MovieClip();
_container.addChild(mc);
_faceArr.push(mc);
if(i==0){
mc.x = 0;
mc.y = -_r;
mc.z = 0;
}else if(i==11){
mc.x = 0;
mc.y = _r;
mc.z = 0;
}else if(i<=5){
mc.x = _r*Math.cos(angle);
mc.y = -_r*Math.sin(angle);
mc.z = 0;
}else{
mc.x = -_r*Math.cos(angle);
mc.y = _r*Math.sin(angle);
mc.z = 0;
}
}
for(i = 1;i<11;i++){
(_faceArr[i] as MovieClip).transform.matrix3D.appendRotation(i*72,Vector3D.Y_AXIS);
}
}
private function drawLine():void
{
for(var i:int = 1;i<6;i++ ){
_lineContainer.graphics.moveTo(_faceArr[0].X,_faceArr[0].Y);
_lineContainer.graphics.lineTo(_faceArr[i].X,_faceArr[i].Y);
}
for(i=1;i<6;i++){
_lineContainer.graphics.lineTo(_faceArr[i].X,_faceArr[i].Y);
}
for(i = 6;i<11;i++){
_lineContainer.graphics.moveTo(_faceArr[11].X,_faceArr[11].Y);
_lineContainer.graphics.lineTo(_faceArr[i].X,_faceArr[i].Y);
}
for(i=6;i<11;i++){
_lineContainer.graphics.lineTo(_faceArr[i].X,_faceArr[i].Y);
} _lineContainer.graphics.moveTo(_faceArr[1].X,_faceArr[1].Y);
var id:int = 9;
for(i=0;i<9;i++){
_lineContainer.graphics.lineTo(_faceArr[id].X,_faceArr[id].Y);
if(i<3){
id = i+11-id;
}else{
id = i+6-id;
}
}
_lineContainer.graphics.lineTo(_faceArr[1].X,_faceArr[1].Y);
}
}
}

下面是源代码中drawLine()函数的原型

 private function drawLine2():void
{
_lineContainer.graphics.moveTo(_faceArr[0].X,_faceArr[0].Y);
_lineContainer.graphics.lineTo(_faceArr[1].X,_faceArr[1].Y); _lineContainer.graphics.moveTo(_faceArr[0].X,_faceArr[0].Y);
_lineContainer.graphics.lineTo(_faceArr[2].X,_faceArr[2].Y); _lineContainer.graphics.moveTo(_faceArr[0].X,_faceArr[0].Y);
_lineContainer.graphics.lineTo(_faceArr[3].X,_faceArr[3].Y); _lineContainer.graphics.moveTo(_faceArr[0].X,_faceArr[0].Y);
_lineContainer.graphics.lineTo(_faceArr[4].X,_faceArr[4].Y); _lineContainer.graphics.moveTo(_faceArr[0].X,_faceArr[0].Y);
_lineContainer.graphics.lineTo(_faceArr[5].X,_faceArr[5].Y); _lineContainer.graphics.lineTo(_faceArr[1].X,_faceArr[1].Y);
_lineContainer.graphics.lineTo(_faceArr[2].X,_faceArr[2].Y);
_lineContainer.graphics.lineTo(_faceArr[3].X,_faceArr[3].Y);
_lineContainer.graphics.lineTo(_faceArr[4].X,_faceArr[4].Y);
_lineContainer.graphics.lineTo(_faceArr[5].X,_faceArr[5].Y); _lineContainer.graphics.moveTo(_faceArr[11].X,_faceArr[11].Y);
_lineContainer.graphics.lineTo(_faceArr[6].X,_faceArr[6].Y); _lineContainer.graphics.moveTo(_faceArr[11].X,_faceArr[11].Y);
_lineContainer.graphics.lineTo(_faceArr[7].X,_faceArr[7].Y); _lineContainer.graphics.moveTo(_faceArr[11].X,_faceArr[11].Y);
_lineContainer.graphics.lineTo(_faceArr[8].X,_faceArr[8].Y); _lineContainer.graphics.moveTo(_faceArr[11].X,_faceArr[11].Y);
_lineContainer.graphics.lineTo(_faceArr[9].X,_faceArr[9].Y); _lineContainer.graphics.moveTo(_faceArr[11].X,_faceArr[11].Y);
_lineContainer.graphics.lineTo(_faceArr[10].X,_faceArr[10].Y); _lineContainer.graphics.lineTo(_faceArr[6].X,_faceArr[6].Y);
_lineContainer.graphics.lineTo(_faceArr[7].X,_faceArr[7].Y);
_lineContainer.graphics.lineTo(_faceArr[8].X,_faceArr[8].Y);
_lineContainer.graphics.lineTo(_faceArr[9].X,_faceArr[9].Y);
_lineContainer.graphics.lineTo(_faceArr[10].X,_faceArr[10].Y); _lineContainer.graphics.moveTo(_faceArr[1].X,_faceArr[1].Y);
_lineContainer.graphics.lineTo(_faceArr[9].X,_faceArr[9].Y);
_lineContainer.graphics.lineTo(_faceArr[2].X,_faceArr[2].Y);
_lineContainer.graphics.lineTo(_faceArr[10].X,_faceArr[10].Y);
_lineContainer.graphics.lineTo(_faceArr[3].X,_faceArr[3].Y);
_lineContainer.graphics.lineTo(_faceArr[6].X,_faceArr[6].Y);
_lineContainer.graphics.lineTo(_faceArr[4].X,_faceArr[4].Y);
_lineContainer.graphics.lineTo(_faceArr[7].X,_faceArr[7].Y);
_lineContainer.graphics.lineTo(_faceArr[5].X,_faceArr[5].Y);
_lineContainer.graphics.lineTo(_faceArr[8].X,_faceArr[8].Y);
_lineContainer.graphics.lineTo(_faceArr[1].X,_faceArr[1].Y);
}

[ActionScript 3.0] AS3 绘制正二十面体(线条)的更多相关文章

  1. [ActionScript 3.0] AS3 绘制正四面体(线条)

    package { import flash.display.MovieClip; import flash.display.Sprite; import flash.events.Event; im ...

  2. [ActionScript 3.0] AS3 绘制正八面体(线条)

    分析: 将八面体置于3D坐标系中,其中心的坐标位于原点(0,0,0),让八面体的六个顶点恰好位于3D坐标系的x轴.y轴和z轴上,则从八面体的中心到这六个顶点的距离是相等的.我们可以假设这个距离为r,则 ...

  3. [ActionScript 3.0] AS3 绘制星形

    package { import flash.display.Sprite; import flash.events.Event; /** * @author Frost.Yen * @E-mail ...

  4. [ActionScript 3.0] AS3 绘制12面体

    package { import flash.display.Sprite; import flash.events.Event; import flash.events.MouseEvent; im ...

  5. [ActionScript 3.0] AS3 绘制立方体

    package { import flash.display.Sprite; import flash.events.Event; import flash.geom.Vector3D; import ...

  6. [ActionScript 3.0] AS3 绘制任意三角形任意顶点到对边的高

    注:顶点坐标可以点击 package { import flash.display.Shape; import flash.display.Sprite; import flash.events.Mo ...

  7. [ActionScript 3.0] as3处理xml的功能和遍历节点

    as3比as2处理xml的功能增强了N倍,获取或遍历节点非常之方便,类似于json对像的处理方式. XML 的一个强大功能是它能够通过文本字符的线性字符串提供复杂的嵌套数据.将数据加载到 XML 对象 ...

  8. [ActionScript 3.0] AS3.0 动态加载显示内容

    可以将下列任何外部显示资源加载到 ActionScript 3.0 应用程序中: 在 ActionScript 3.0 中创作的 SWF 文件 — 此文件可以是 Sprite.MovieClip 或扩 ...

  9. [ActionScript 3.0] AS3虚线绘制方法

    import flash.geom.Point; import flash.display.MovieClip; import flash.display.Graphics; var mc:Movie ...

随机推荐

  1. EDIUS如何实现抠图

    有时候我们把素材图片导入到EDIUS中会发现图片的背景有点不合适,这时候就会想替换掉这个背景.那么EDIUS也可以像PS一样替换掉背景吗?答案当然是肯定的,现在小编就带领你们一起来学习EDIUS抠图吧 ...

  2. 使用Myeclipse 2015 进行 Hdp 4 windows 开发

    在本地环境下进行开发,使用cygwin安装 Hdp那就是一个呵呵岂能概括. 所以啊,还是用Hdp windows进行开发测试吧.这样感觉省心点.具体 Hdp windows的安装参看前面的文章或自行G ...

  3. 华东师大OJ:IP Address【IP地址转换】

    /*===================================== IP Address Time Limit:1000MS Memory Limit:30000KB Total Subm ...

  4. html之内联标签img

    img创建的是被链接图像的占位空间,它不会真正地在网页插入图像. 两个必须属性: src:图像的超链接 alt:图像的替代文本 可选属性: height:高度 width:宽度 ismap:将图像定义 ...

  5. python数据类型之int用法

    1.查看整型的用法 CODE:print(dir(int))['__abs__', '__add__', '__and__', '__bool__', '__ceil__', '__class__', ...

  6. SQL Server锁、闩等资源的阻塞诊断---osql/sqlcmd,sp_blocker_pss80

          osql/sqlcmd 工具是一个 SqlServer的命令提示符工具,我们可以使用它运行 Transact-SQL 语句和脚本文件.该工具所在目录:C:\Program Files\Mi ...

  7. Linux启动过程详解 (转)

    启动第一步--加载BIOS当你打开计算机电源,计算机会首先加载BIOS信息,BIOS信息是如此的重要,以至于计算机必须在最开始就找到它.这是因为BIOS中包含了CPU的相关信息.设备启动顺序信息.硬盘 ...

  8. mysql edit

    表外键5个相关性: cascade,restrict,set null,no action,default   show character set ;   show collation like ' ...

  9. [mysql] mysql explain 使用

    explain显示了mysql如何使用索引来处理select语句以及连接表.可以帮助选择更好的索引和写出更优化的查询语句. 先解析一条sql语句,看出现什么内容 EXPLAINSELECTs.uid, ...

  10. mybatis获得刚刚插入的自增的值

    转自这里 在http://blog.csdn.net/zhangwenan2010/article/details/7579191   介绍了MyBatis 3 的配置过程, 其中,Product 类 ...