查看: 4726|回复: 4
打印 上一主题 下一主题

[Away3D] Away3D4.0入门教程

[复制链接]

3

主题

0

听众

35

积分

设计初学者

Rank: 1

纳金币
6
精华
0
跳转到指定楼层
楼主
发表于 2013-11-14 09:37:47 |只看该作者 |倒序浏览
大多数Flash程序员想要接触3D项目的时候,应该最关心的是怎么造一座山,怎么在场景里显示流动的河水,或是怎么让模型动起来(奔跑,攻击,或是跳舞),又或是怎么才能给人物换装,怎么让人物装备武器.

在做这类教程之前,作为初学者的你必须得了解一下,或许它们粗浅的让你觉得根本不值一看,能了解一些基础知识,它们终将在未来的某一天帮到你。用最简单的语言词汇让大家清晰的了解起功能运用。

Origin(原心,或称之为起始点):
3D世界与物体的中心点,3D世界中的任何对象都会有一个Origin,不管是场景,3D模型,灯光,还是摄像机,它的所在位置是物体或场景的(0,0,0)坐标,你可能并不能在所有的3D引擎或3d软件(如3dmax)中看到它,但它却是真实存在并起着相应的作用的

Geometry(几何形状):
在Away3D中,Geometry类其实就是一个数据对象,它被用来保存3D物体的基础数据,如顶点(vertices),法线(normals),UV数据,我们从外部加载进来的模型文件会被解析成一个Geometry实例并被保存在内存中

当然,我们也可以通过实例化一些Geometry的子类来创建一些基础的几何形状数据
PlaneGeometry        //平面
CubeGeometry        //方块
SphereGeometry        //球形
CylinderGeometry    //圆柱
CapsuleGeometry        //胶囊

Material(材质):
我们也可以将它称之为贴图,基本的贴图分三种,颜色贴图,照片贴图和线框贴图(线框贴图仅针对于线框类型对象使用),我们还能为贴图设置透明度和灯光反射强度,以此来达到一些特殊效果

Mesh(网格):
Mesh是一个容器,如果我们为它设置形状数据和贴图后,我们就可以在场景中看到它,它可以是一个方块,一个圆球,也可以是一个如汽车或楼房这样的复杂模型,当然,它也可以仅仅只是一个点,一根线条,或是一个平面,一切取决于它所包含的Geometry数据内容

UV:
U,V是贴图坐标的简称(它和3D模型的X, Y, Z轴是类似的),水平方向是U,垂直方向是V,通过这个二维平面的UV坐标系定义了图片上每个点的位置的信息. 这些点与3D模型是相互联系的, 以决定表面贴图的位置. UV就是将图像上每一个点精确对应到模型物体的表面. 在点与点之间的间隙位置由软件进行图像光滑插值处理. 这就是所谓的UV贴图.

Normals(法线):
法线并不是一种实体线,它是一条垂直于曲线上节点和表面切线方向上的虚拟线,使用正负值来表示和区别多边形上面和点的法向参数,并且只有法线为正值的点和面在场景中才可见,一般来说,由内部指向外部表示当前位置的法线为正向,如果将表面翻转,也就改变了法线的方向,如果你的模型不是双面显示的话,那么负法向的那一面将会在视力窗口中不可见,并且不可被渲染


Light(灯光):
我们生存的这个世界必须有光,不然就是漆黑一片...
3D世界中也一样,但不同的是,我们需要在3D世界中使用有限的几种灯光类型来模拟真实现世界中的大多数可见光源(像红外线这种不可见光源不在我们的讨论之列)

目前Away3D 4.0中提供两种光源
PointLight(点光源):这是最常用到的,我们可以用它来模拟太阳,月亮,或是台灯的灯炮
DirectionalLight(投射光源):好吧,这货可以用来模拟探照灯,或是月光透过窗户的效果

View3D(视口):
这是整个3D世界的入口,犹如透过一个窗口看世界,Away3D中View3D类就是这个窗口,你可以在Flash中同时添加多个View3D实例,就好像在一面墙上砸出多个窗户一样,每个View3D实例可以指向同一个Scene3D,也可以指向不同的Scene3D,但请记住,即使所有的View3D都指向同一个Scene3D实例,也会造成性能的下降,所以通常情况下,我们只使用一个View3D实例

Scene3D(场景):
Scene3D就是窗户外的风景,它在Flash的作用类似于Stage,所有的3D对象都需通过它来addChild,才能被显示出来,你也同样可以同时实例化多个Scene3D实例,但每个View3D每次只能被分配一个Scene3D

Camera3D(镜头):
Camera3D就相当于你的眼睛,睛,如果移动Camera3D的坐标就相当于你的眼睛在移动,如果移动Scene3D里的物体坐标呢?.....那就说明那个物体在移动
  1. //范例:
  2. var view:View3D = new View3D();
  3. //View3D实例必须被添加到舞台上才能正确生效
  4. stage.addChild(view);

  5. //创建一个长宽高都为500的立方体数据
  6. var cubeGeometry:CubeGeometry = new CubeGeometry(500, 500, 500);
  7. //创建一个单色的贴图(材质)
  8. var cubeMaterial:ColorMaterial = new ColorMaterial(0xFF0000);
  9. //创建一个可视的Mesh对象,并设置形状数据和贴图
  10. var cubeMesh:Mesh = new Mesh(cubeGeometry, cubeMaterial);
  11. //将mesh添加到舞台上
  12. view.scene.addChild(cubeMesh);

  13. //移动风景中的物体
  14. cubemesh.z += 100;

  15. //移动镜头,或是说移动你的眼睛....
  16. view.camera.z = 100;
复制代码
objectContainer3D:
顺便提一下这个类,ObjectContainer3D类是Away3d中大多数3D可视对象的基类,
如果你想自己创建一个比较复杂的3D物体对象(如包含好几个Mesh的对象),可以通过继承它来实现自己的需要


分享到: QQ好友和群QQ好友和群 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
转播转播0 分享淘帖0 收藏收藏0 支持支持0 反对反对0
回复

使用道具 举报

0

主题

2

听众

3238

积分

中级设计师

Rank: 5Rank: 5

纳金币
0
精华
0

最佳新人 活跃会员 热心会员 灌水之王 突出贡献

沙发
发表于 2014-2-28 12:24:12 |只看该作者
感谢分享
回复

使用道具 举报

0

主题

1

听众

2458

积分

中级设计师

Rank: 5Rank: 5

纳金币
0
精华
0

最佳新人 活跃会员 热心会员 灌水之王 突出贡献

板凳
发表于 2014-3-26 20:47:14 |只看该作者
楼主就是给力
回复

使用道具 举报

0

主题

0

听众

18

积分

设计初学者

Rank: 1

纳金币
5
精华
0
地板
发表于 2014-10-16 11:14:55 |只看该作者
楼主给力,感谢分享
回复

使用道具 举报

icon    

0

主题

1

听众

110

积分

设计实习生

Rank: 2

纳金币
2
精华
0

最佳新人

5#
发表于 2015-1-23 10:42:09 |只看该作者

pstatus"> 本帖最后由 比巴卜 于 2013-10-28 08:57 编辑

lash AS3制作个性的旋转圆形网页导航,最终效果如下。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

手机版|纳金网 ( 闽ICP备2021016425号-2/3

GMT+8, 2025-1-26 02:39 , Processed in 0.068872 second(s), 35 queries .

Powered by Discuz!-创意设计 X2.5

© 2008-2019 Narkii Inc.

回顶部