多个立方体 - Papervision3D

时间:2010-12-23 06:29:34

标签: papervision3d

我找到了adding texture to a cube

的示例

我想要的是连续3个立方体,并且能够将它们放在后面(x轴),但我真的不太了解papervision3d。我只是改变了纹理,就是这样。这是代码:

http://www.kelvinluck.com/assets/papervision3d/cube_tweaks/

package
{
 import flash.display.Bitmap;
 import flash.display.BitmapData;
 import flash.display.Sprite;
 import flash.events.Event;
 import flash.events.KeyboardEvent;
 import org.papervision3d.cameras.Camera3D;
 import org.papervision3d.materials.BitmapMaterial;
 import org.papervision3d.materials.BitmapFileMaterial;
 import org.papervision3d.materials.MaterialsList;
 import org.papervision3d.objects.DisplayObject3D;
 import org.papervision3d.scenes.Scene3D;
 import org.papervision3d.objects.Collada;
 import org.papervision3d.core.proto.DisplayObjectContainer3D;
 import org.papervision3d.objects.Cube;
 import org.papervision3d.materials.ColorMaterial;

 public class PapervisionCubeSides extends Sprite
 {

  private var container:Sprite;
  private var scene:Scene3D;
  private var camera:Camera3D;
  private var rootNode:DisplayObject3D;
  private var ml:MaterialsList = new MaterialsList();
  private var customcube:Cube;

  public function PapervisionCubeSides()
  {
   init3D();
   addEventListener(Event.ENTER_FRAME, Timeline);
  }

  private function init3D():void {
   container = new Sprite();
   addChild( container );   
   container.x = stage.stageWidth * .5;
   container.y = stage.stageHeight * .5;
   scene = new Scene3D( container );
   camera = new Camera3D();
   camera.zoom = 10;

   rootNode = scene.addChild( new DisplayObject3D("rootNode") );

   var ml:MaterialsList = new MaterialsList();
   ml.addMaterial(new BitmapFileMaterial("ski.jpg"), 'face1');
   ml.addMaterial(new BitmapFileMaterial("ski.jpg"), 'face2');
   ml.addMaterial(new BitmapFileMaterial("ski.jpg"), 'face3');
   ml.addMaterial(new BitmapFileMaterial("ski.jpg"), 'face4');
   ml.addMaterial(new BitmapFileMaterial("ski.jpg"), 'face5');
   ml.addMaterial(new BitmapFileMaterial("ski.jpg"), 'face6');

   customcube = new Cube( ml, 280, 280, 280, 1, 1, 1 );

   rootNode.addChild( customcube, "myCube01" );
  }

  private function Timeline( event:Event ):void {
   var screen:DisplayObject3D = this.scene.getChildByName("rootNode");
   var rotationY:Number = -(this.mouseX / this.stage.stageWidth * 275);
   var rotationX:Number = -(this.mouseY / this.stage.stageHeight * 275);
   screen.rotationY += (rotationY - screen.rotationY) / 12;
   screen.rotationX += (rotationX - screen.rotationX) / 12;

   this.scene.renderCamera(this.camera);
  }
 }
}

感谢您的帮助

1 个答案:

答案 0 :(得分:1)

你要添加3个立方体,就像添加1个立方体一样诚实。你可以做一个基本的for循环,并使用迭代器来增加位置:

package
{
 import flash.display.Bitmap;
 import flash.display.BitmapData;
 import flash.display.Sprite;
 import flash.events.Event;
 import flash.events.KeyboardEvent;
 import org.papervision3d.cameras.Camera3D;
 import org.papervision3d.materials.BitmapMaterial;
 import org.papervision3d.materials.BitmapFileMaterial;
 import org.papervision3d.materials.MaterialsList;
 import org.papervision3d.objects.DisplayObject3D;
 import org.papervision3d.scenes.Scene3D;
 import org.papervision3d.objects.Collada;
 import org.papervision3d.core.proto.DisplayObjectContainer3D;
 import org.papervision3d.objects.Cube;
 import org.papervision3d.materials.ColorMaterial;

 public class PapervisionCubeSides extends Sprite
 {

  private var container:Sprite;
  private var scene:Scene3D;
  private var camera:Camera3D;
  private var rootNode:DisplayObject3D;
  private var ml:MaterialsList = new MaterialsList();
  private var customcube:Cube;

  public function PapervisionCubeSides()
  {
   init3D();
   addEventListener(Event.ENTER_FRAME, Timeline);
  }

  private function init3D():void {
   container = new Sprite();
   addChild( container );   
   container.x = stage.stageWidth * .5;
   container.y = stage.stageHeight * .5;
   scene = new Scene3D( container );
   camera = new Camera3D();
   camera.zoom = 10;

   rootNode = scene.addChild( new DisplayObject3D("rootNode") );

   var ml:MaterialsList = new MaterialsList();
   ml.addMaterial(new BitmapFileMaterial("ski.jpg"), 'face1');
   ml.addMaterial(new BitmapFileMaterial("ski.jpg"), 'face2');
   ml.addMaterial(new BitmapFileMaterial("ski.jpg"), 'face3');
   ml.addMaterial(new BitmapFileMaterial("ski.jpg"), 'face4');
   ml.addMaterial(new BitmapFileMaterial("ski.jpg"), 'face5');
   ml.addMaterial(new BitmapFileMaterial("ski.jpg"), 'face6');

   for(var i:int = 0 ; i < 3 ; i++){
      customcube = new Cube( ml, 280, 280, 280, 1, 1, 1 );
      customcube.x = (280 + 10) * i
      rootNode.addChild( customcube, "myCube"+i );
   }
  }

  private function Timeline( event:Event ):void {
   var screen:DisplayObject3D = this.scene.getChildByName("rootNode");
   var rotationY:Number = -(this.mouseX / this.stage.stageWidth * 275);
   var rotationX:Number = -(this.mouseY / this.stage.stageHeight * 275);
   screen.rotationY += (rotationY - screen.rotationY) / 12;
   screen.rotationX += (rotationX - screen.rotationX) / 12;

   this.scene.renderCamera(this.camera);
  }
 }
}