纳金网

标题: away3d4.0 新手入门系列教程 第一讲 3D WORLD [打印本页]

作者: D调的华丽    时间: 2012-8-21 13:03
标题: away3d4.0 新手入门系列教程 第一讲 3D WORLD
         网页的多媒体应用FLASH功不可没,在线视频,网页动画,网页游戏等等..FLASH MX FLASH8的出现在flash应用越来越广的时候,纵多闪客横空出世的时候,AS程序员可以用FLASH这个低门槛的软件做游戏的时候,大家心里或许都有遗憾。就是FLASH对于3D的无力。在AS2时代,那语言还不强大成熟的时候这简直是个高不可攀的梦想,仅有PV3D这样的先驱者做着尝试,后来Adobe收购了MM公司 FLASH也划于其旗下,AS3的横空出世,完善的OOP编程模式,特别是FP10里Z轴的出现 让FLASH3D看到曙光了,一大批基于AS3的较为成熟的3D引擎也纷纷出现: A3D AWAY3D 等。后来在AODBE MAX大会上 AODOBE宣布了FlashPlayer基于GPU渲染的MOLEHILL(也就是后来的STAGE3D) ,当演示的时候 flashplayer里面绚丽的3D效果 我相信看到的人都和我一样热血沸腾。在现在这个时代已经到来。FP11已经具备了GPU硬件加速功能。flashplayer实时渲染上十万个多边形模型已经不再话下。我相信大家都想看到在网页上玩CS。而更多的ASer应该更想动起手来制作属于自己的3D世界。在此我就将个人研究学习心得贡献出来,抛砖引玉,和大家共同学习,以下是我将用到的引擎和环境。
        1引擎:我将会用Away3d这款3D引擎来讲。因为其清楚的API和免费开源。
        2环境:个人比较懒。而且网上的配置教程也比较多,如果你是低版本的FLASH PRO 或者FLASH BUILD 那自行去找配置教程,我推荐就直接使用FLASH BUILD4.6,或者FLASH CS6  这样不用去配置环境。而AWAY3D的类文件我会放在附件里。


=================================华丽的分割线====================================

现在我们打开FLASH 或者 FLASH BUILD 开始动手开始创建我们的第一个3D世界
   创建away3d的3D世界 首先我们得了解away3d的几个基本类 也是每次我们做的时候必须初始化的  View3D ,Scene3D ,Camera3D。这三个类我做下简单的解释
1   View3D 我们可以理解为一个窗子。就像我们站在屋外可以通过窗子看到屋内的家具。同理 如果同时有多扇窗子,我们就可以看到多个屋内环境。在AWAY3D里面 我也可以通过创建多个View3D来看到这个3D世界。
2 Scene3D  我还是拿屋子做比较。Scene3D就类似这个屋内这个空间。因为这个空间的存在。我们才能向里面放置家具。
3 Camera3D 这个就类似我们的眼睛。因为它我们才看到这个世界。我们改变Camera3D 的坐标 遍可以从不同角度来观看这个3D世界

以上就是3个基础类。他们的创建方式如下
var _view:View3D=new View3D();
addChild(_view);

var _scene:Scene3D=new Scene3D();
_view.scene=_scene;

var _camera:Camera3D=new Camera3D();
_view.camera=_camera;

好了基本元素创建完毕 最后 我们需要用一个ENTER_FRAME来实时渲染这个View3D
_view.render();

下面我们来说说AWAY3D的基本模型
Away3d里面有我们常见的几何体。如球SphereGeometry
,盒子CubeGeometry
,平面Plane,圆柱体CylinderGeometry等等 他们都在primitives类里面 大家可以自行查阅。在这我就不一一列举了 他们创建的方式也几乎一样。我现在教大家创建一个基本3D模型:球。
在away3d里 创建模型需要3个条件 Mesh(网格) Mode(模型)  Material(贴图)
Mesh是一个显示对象 我们的Mode 和Material就将放置其中 然后显示出来
我们现在创建一个纯白色,半径为200,横向细分(细分就是模型的拓扑结构,细分越大 每个多边形就越小 模型也越光滑。相应的对电脑的压力也越大)为32 纵向细分为24的球,代码如下
var _material:ColorMaterial=new ColorMaterial(0xffffff);
var _sphere:SphereGeometry=new SphereGeometry(100,32,32);
var _sphereMesh:Mesh=new Mesh(_sphere,_material);
然后我们将Mesh addChild 到View3D里

_view.scene.addChild(_sphereMesh);

然后我们输出 就可以看到一个白色的圆。如图

是不是很不立体啊 呵呵因为没打灯光 没有明暗关系

我们可以打一个灯光

var _dlirectionalLight=new DirectionalLight();
   var _dl2irectionalLight=new DirectionalLight(.5,1,-1);
   _dl2.ambient=.1
   var _light:StaticLightPicker=new StaticLightPicker([_dl,_dl2]);
   
   _sphereMesh.material.lightPicker=_light;
   
   _view.scene.addChild(_dl);


然后我们输出就可以看到如下图


现在就有3D感觉了吧 好吧 今天教程到此为止。
全部的代码如下
package  {

import flash.display.MovieClip;
import away3d.containers.View3D;
import away3d.containers.Scene3D;
import away3d.cameras.Camera3D;
import flash.events.Event;
import flash.display.Sprite;
import away3d.materials.ColorMaterial;
import away3d.primitives.SphereGeometry;
import away3d.entities.Mesh;
import away3d.lights.DirectionalLight;
import away3d.materials.lightpickers.StaticLightPicker;

public class Main extends  Sprite {
  
  private var _view:View3D;
  
  private var _scene:Scene3D;
  
  private var _camera:Camera3D;
  
  private var _material:ColorMaterial;
  
  private var _sphere:SphereGeometry;
  
  private var _sphereMesh:Mesh;
  
  private var _dlirectionalLight;
  private var _dl2irectionalLight;
  
  private var _light:StaticLightPicker;
   
  public function Main()
  {
   _view=new View3D();
   addChild(_view);
   
   _scene=new Scene3D();
   _view.scene=_scene;   
   _camera=new Camera3D();
   _view.camera=_camera;
      _material=new ColorMaterial(0xffffff);
   _sphere=new SphereGeometry(100,32,32);
   _sphereMesh=new Mesh(_sphere,_material);
   _view.scene.addChild(_sphereMesh);
   
   _dl=new DirectionalLight();
   _dl2=new DirectionalLight(.5,1,-1);
   _dl2.ambient=.1
   _light=new StaticLightPicker([_dl,_dl2]);
   
   _sphereMesh.material.lightPicker=_light;
   
   _view.scene.addChild(_dl);
   this.addEventListener(Event.ENTER_FRAME,enterFrameFunction)
  }
  
  private function enterFrameFunction(evt:Event):void
  {
   _view.render();
  }
}

}




在下一篇教程里 我会给大家介绍一下light (灯光)
  
作者: wsk    时间: 2012-9-7 11:54
支持!!!!!!!!!!!!
作者: 如同    时间: 2012-9-7 17:21
总算找到中文教程了,好东西,支持!

作者: Gary-code    时间: 2012-9-24 09:19
楼主加油,极度支持,呵呵    。
作者: ss33    时间: 2012-9-26 11:48
怎么到处away3d类都不一样啊。。。
作者: 小铁匠    时间: 2012-10-9 11:25
好教程 谢谢!
作者: seedcll    时间: 2012-10-20 15:05
支持 支持~~~~~~~~~~~~~~
作者: 凡客    时间: 2012-10-26 22:06
找地址
作者: 凡客    时间: 2012-10-29 19:47
给师傅顶顶人气
作者: 81537261    时间: 2012-12-4 17:00
看看~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
作者: 开拓者    时间: 2012-12-29 11:03
初学  顶起!觉得楼主应该多发点帖子
作者: king    时间: 2013-1-10 11:23
吼吼~~~~~~~~~~

作者: 误码率    时间: 2013-1-15 10:35
哈哈 学习一下啊! 希望能多多支持类似的帖子

作者: xiongz    时间: 2013-1-15 11:11
支持一下·顶顶。。。      

作者: love你我    时间: 2013-1-23 17:28
为什么我运行部起立法撒旦法师法撒撒反对爱死
作者: FeralSpiri    时间: 2013-2-26 14:40
好帖子,学习中.谢谢搂住
作者: blackCat    时间: 2013-2-26 23:02
求学习,求下组件。喵
作者: haoyi    时间: 2013-2-27 17:38
挺好的教程支持楼主继续发布新的教程

作者: 来学习    时间: 2013-2-28 20:18
必须顶~顶顶顶~顶顶顶~顶顶顶~顶顶顶~顶顶顶~顶顶顶~

作者: long    时间: 2013-3-1 13:39
学习中 马克!!!!!!!!1
作者: kz2007    时间: 2014-10-22 13:31
给LZ顶顶人气
作者: zcylwzsj    时间: 2015-6-30 16:18
只少俩var已经很良心了,其他教程少一大堆东西,根本没法用
var _dl=new DirectionalLight();
   var _dl2=new DirectionalLight(.5,1,-1);




欢迎光临 纳金网 (http://rs.narkii.com/club/) Powered by Discuz! X2.5