Flash Alternativa 3D引擎-基础理论

Flash Alternativa 3D引擎-基础理论

自由行走的花

网站设计,flash网站设计与动画制作,web,as3

2010-12-31 14:29

【转】Flash Alternativa 3D引擎-基础理论

《本文转载自:http://www.zcool.com.cn/article/ZMTEwMzY=.html》敬请阅读,不懂的地方可以在此交流!

 

一. Alternativa 三维坐标系

        在任何一个三维引擎中,都有自己的系统坐标系,对于Alternativa 3D也不例外。Alternativa 3D采用的是右手坐标系,绕轴旋转准侧也是采用 右手定则。(以后将Alternativa 3D 简写为A3D)

        坐标系:

A3D——>Flash Alternativa 3D引擎-基础理论          Flash 3D——>Flash Alternativa 3D引擎-基础理论

 

        与Flash中的坐标系的对比:

                两者X轴的方向一致,为水平向右;

                Y轴与Z轴截然不同;

                两者都采用右手坐标系。

        对于绕轴的旋转正方向:   Flash Alternativa 3D引擎-基础理论

分开来讲:

绕X轴旋转–>Flash Alternativa 3D引擎-基础理论,绕Y轴旋转–>Flash Alternativa 3D引擎-基础理论,绕Z轴旋转–>Flash Alternativa 3D引擎-基础理论

也就是说:用右手大拇指指向轴的方向,四指握拳的方向就只该轴旋转正方向。这也就是右手定则。

二. A3D 三维结构基础(重点)

Flash Alternativa 3D引擎-基础理论

        A3D 的三维结构如上图。在A3D中几个基础的要素为 Scene3D,View,Camera3D,Object3D与Material。

Scene3D:即 三维场景。在A3D中,Scene3D是一个基础的3D要素,也是一个三维模型存储的空间,用来储存三维模型,完成BSP树的建立,渲染机制等工作。但要 注意的是,Scene3D并不是一个Object3D显示对象,也就是说它并不继承自Object3D,只是Scene3D最重要的一个公共属性root 才是用来存放其他显示元素的Object3D对象。换句话说,Scene3D.root 才是通常意义上的三维场景。Scene3D不但拥有这个三维场景显示对象,同时还完成一些BSP树搭建,渲染,计算等工作。若想要你的三维模型 (Object3D对象)显示在场景中,就必需首先将这个模型放在场景中,即调用方 法:Scene3D.root.addChild(Object3D);另外还要讲Camera3D对象也放在同一个场景 中:Scene3D.root.addChild(Camera3D)。这里只给大家一个基本的原理与印象,后面我们将会实际的操作。

想要了解Scene3D的渲染机制与BSP树的建立,估计又要花很长时间,但是之一部分对于工程师而言,没有很大的了解意义。如果感兴趣的朋友可以去Alternativa3D的官方网站查找相关解释性的说明。

Camera3D:三 维摄像机。对于利用Camera来完成三维动画的想法,我一直觉得很是高明。想象一下,我们的眼睛就是摄像机。如果我们想观察一个物体的各个侧面,我么会 拿起手转动这个物体,然后观察。我们为何不换一种思路,把物体放在那,而眼镜(自己的头)绕着物体转呢?这也就是Camera3D的作用。不但我们可以控 制场景中物体的任意动画,我们也可以控制摄像机的不同位置与角度。想想CS,不就像是自己拿着摄像机在看一个三维世界吗?这样的设计更合理,也更具与人性 的特点。那如何来控制摄像机呢?在A3D中也为我们设计了一下特定的类,后面的教程中将会给大家介绍。同时,在3D中,摄像机必须与View(视窗),相 结合使用。那什么又是视窗呢?

View:视窗。我们来想想一下,你面前有个扇门,门上有一个正方形小 孔,你想通过小孔看看门后房子里是什么东西,而你和们之间有一段距离,就如上面的那张图。为了看得更全,你可以移动自己的眼镜(Camera3D),但 是,你能看见的范围却只有那个控那么大。这就是视窗View与摄像机Camera3D之间的关系。视窗是用来观察场景(Scene3D.root)空间的 一个窗口,所以视窗不用放在场景之中。

Object3D:三维对象。A3D中显示对象不再是Flash 中的DisplayObject,而是Object3D。不过Object3D与DisplayObject的属性差不多。可想而知,A3D中的所有显示 对象都继承自Object3D这个类。A3D同时也很周到的为我们建立了一些基础的三维模型,我们可以直接用,例如立方体Box,球体Sphere,圆柱 体Cone,平面Plan等。这些类都是继承自Object3D的。

Material:材质。用 Object3D建立的显示对象往往是看不见的,应为我们还要给每个三维对象贴一层皮,这层皮就是Materal,即材质。在A3D中为大家建立了一些基 本的材质类,例如纯色,线框等,另外还有一些高级的材质,如电影剪辑,外载贴图等,用户也可以建立自己的材质。在A3D中同时支持带有UV机制的外载贴 图。这使得我们对三维模型的建立变得更加简单,那为什么更加简单呢?这就必须要了解什么是UV。

*UV坐标

详细解释,请参见维基百科(英文):http://en.wikipedia.org/wiki/UV_mapping

Flash Alternativa 3D引擎-基础理论

        简单地说,UV展开就是讲一个三维模型的表面(三维坐标)展开成一个二维坐标(U坐标与V坐标)下的平面图。例如上面的例子,我们可以从三维;模型得到他 的UV图,并把它放在一个矩形中贴图(Texture贴图)。反过来,我们如果知道一个三维模型,还知道他的带有UV属性的贴图(Texture),我们 就可以重建这个三维模型。

三. 小结

        在这里写小结,说明这一章相当的关键。这是理解A3D与应用A3D的基础,对于没有接触过三维引擎的同学而言,这也是一个从整体上认识三维引擎结构的基 础。希望大家认真的理解,特别是我那个小孔观物的例子。现在只要记住这个例子中观察事物的原理与方法就可以了,后面我们将会以实例来说明,那是大家会更深 的理解的。

转载于:https://www.cnblogs.com/tanbq/p/3208866.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/110072.html原文链接:https://javaforall.net

(0)
上一篇 2021年8月25日 上午6:00
下一篇 2021年8月25日 上午6:00


相关推荐

  • 网页鼠标点击特效案例收集

    网页鼠标点击特效案例收集1 鼠标点击出随机颜色的爱心 DOCTYPE tml htmllang en head metacharset UTF 8 metaname viewport content width device width initial scale 1 0 title Document title metaname viewport content width device width initial scale 1 0 metacharset UTF 8 head htmllang en

    2026年3月17日
    2
  • java栈内存初始化,阿里面试官:小伙子,你给我说一下JVM对象创建与内存分配机制吧…

    java栈内存初始化,阿里面试官:小伙子,你给我说一下JVM对象创建与内存分配机制吧…内存分配机制逐步分析类加载检查:虚拟机遇到一条new指令(new关键字、对象的克隆、对象的序列化等)时,会先去检查这个指令的参数在常量池中定位到一个类的符号引用,并且这个符号引用代表的类是否应被加载过,如果没有那么就去加载该类分配内存类加载完毕后会给对象分配内存空间。对象的所需的内存大小在类加载完毕后就便可完全确认,为对象分配内存大小的空间等同于把一块确定大小的内存从java堆中划分出来。如何划分…

    2022年5月14日
    39
  • Spatial Transformer Network_transgression

    Spatial Transformer Network_transgression导读上一篇通俗易懂的SpatialTransformerNetworks(STN)(一)中,我们详细介绍了STN中会使用到的几个模块,并且用pytorch和numpy来实现了他们,这篇文章我们将会利用pytorch来实现一个MNIST的手写数字识别并且将STN模块插入到CNN中STN关键点解读STN有一个最大的特点就是STN模块能够很容易的嵌入到CNN中,只需要进行非常小的修改即可。上一篇文章我们也说了STN拥有平移、旋转、剪切、缩放等不变性,而这一特点主要是依赖θ\thetaθ参数来实现的。刚开

    2022年8月31日
    4
  • 避免在移动端页面中使用100vh

    避免在移动端页面中使用100vh100vh带来的问题在CSS中,视口单位(Viewportunits)听起来不错。如果要设置一个元素的样式使它占据整个屏幕的高度,那么你可以设置height:100vh,这样你就拥有一个完美的全屏元素,该元素会随着视口的变化而调整大小!可惜的是,事实并非如此。100vh在移动浏览器中以一种微妙但基本的方式被破坏,使其几乎无用。最好避免使用100vh,而应该通过javascript设置高度的方…

    2022年5月1日
    47
  • 送几本超级棒的 Java 新书

    送几本超级棒的 Java 新书6 月底了 又到了给大家送福利的时间了 这次我联系了 6 个好友一起给各位送书 每个号送 5 本一共 35 本 还包邮哦 01 书怎么送很简单 在下面的公众号后台回复 抽奖 弹

    2026年3月16日
    2
  • Base64实现android端图片上传到server端

    Base64实现android端图片上传到server端

    2022年1月19日
    48

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号