mirror of
				https://github.com/MapMakersAndProgrammers/TankiOnline2.0DemoClient.git
				synced 2025-10-26 01:49:11 -07:00 
			
		
		
		
	PNG skybox
This commit is contained in:
		| @@ -40,6 +40,8 @@ package alternativa.tanks.game.entities.map | |||||||
|    import flash.ui.Keyboard; |    import flash.ui.Keyboard; | ||||||
|    import flash.utils.ByteArray; |    import flash.utils.ByteArray; | ||||||
|    import flash.utils.setTimeout; |    import flash.utils.setTimeout; | ||||||
|  |    import alternativa.tanks.game.utils.TaskSequence; | ||||||
|  |    import flash.display.Bitmap; | ||||||
|     |     | ||||||
|    use namespace alternativa3d; |    use namespace alternativa3d; | ||||||
|     |     | ||||||
| @@ -63,6 +65,8 @@ package alternativa.tanks.game.entities.map | |||||||
|        |        | ||||||
|       private var name_RZ:Boolean = true; |       private var name_RZ:Boolean = true; | ||||||
|  |  | ||||||
|  |       private var bitmapCollector:Object; | ||||||
|  |        | ||||||
|       public function A3DMapComponent(files:ByteArrayMap, skyboxFiles:ByteArrayMap, skyboxSize:Number, listener:IA3DMapComponentListener) |       public function A3DMapComponent(files:ByteArrayMap, skyboxFiles:ByteArrayMap, skyboxSize:Number, listener:IA3DMapComponentListener) | ||||||
|       { |       { | ||||||
|          super(); |          super(); | ||||||
| @@ -79,7 +83,18 @@ package alternativa.tanks.game.entities.map | |||||||
|       override public function addToGame(gameKernel:GameKernel) : void |       override public function addToGame(gameKernel:GameKernel) : void | ||||||
|       { |       { | ||||||
|          this.gameKernel = gameKernel; |          this.gameKernel = gameKernel; | ||||||
|          this.createSkybox(); |  | ||||||
|  |  | ||||||
|  |          this.bitmapCollector = new Object(); | ||||||
|  |          var skyTextures:Array = [SkyBox.BACK,SkyBox.BOTTOM,SkyBox.FRONT,SkyBox.LEFT,SkyBox.RIGHT,SkyBox.TOP];; | ||||||
|  |          var bitmapLoader:TaskSequence = new TaskSequence(); | ||||||
|  |          for each (var textureName:String in skyTextures) | ||||||
|  |          { | ||||||
|  |             bitmapLoader.addTask(new BitmapLoadTask(this.skyboxFiles.getValue(textureName), textureName, this.bitmapCollector)) | ||||||
|  |          } | ||||||
|  |          bitmapLoader.addEventListener(Event.COMPLETE, this.createSkybox); | ||||||
|  |          bitmapLoader.run(); | ||||||
|  |           | ||||||
|          gameKernel.getInputSystem().addKeyboardListener(KeyboardEventType.KEY_DOWN,this.onKeyDown); |          gameKernel.getInputSystem().addKeyboardListener(KeyboardEventType.KEY_DOWN,this.onKeyDown); | ||||||
|          if(gameKernel.options[MapOptions.FAKE_MAP] != null) |          if(gameKernel.options[MapOptions.FAKE_MAP] != null) | ||||||
|          { |          { | ||||||
| @@ -91,23 +106,23 @@ package alternativa.tanks.game.entities.map | |||||||
|          } |          } | ||||||
|       } |       } | ||||||
|        |        | ||||||
|       private function createSkybox() : void |       private function createSkybox(event:Event) : void | ||||||
|       { |       { | ||||||
|          var skyBox:SkyBox = null; |          var skyBox:SkyBox = null; | ||||||
|          var surfaceIds:Array = null; |          var surfaceIds:Array = null; | ||||||
|          var surfaceId:String = null; |          var surfaceId:String = null; | ||||||
|          var renderSystem:RenderSystem = null; |          var renderSystem:RenderSystem = null; | ||||||
|          var container:Object3D = null; |          var container:Object3D = null; | ||||||
|          var texture:ByteArray = null; |          var texture:Bitmap = null; | ||||||
|          var textureResource:ATFTextureResource = null; |          var textureResource:BitmapTextureResource = null; | ||||||
|          if(this.skyboxFiles != null) |          if(this.skyboxFiles != null) | ||||||
|          { |          { | ||||||
|             skyBox = new SkyBox(this.skyboxSize); |             skyBox = new SkyBox(this.skyboxSize); | ||||||
|             surfaceIds = [SkyBox.BACK,SkyBox.BOTTOM,SkyBox.FRONT,SkyBox.LEFT,SkyBox.RIGHT,SkyBox.TOP]; |             surfaceIds = [SkyBox.BACK,SkyBox.BOTTOM,SkyBox.FRONT,SkyBox.LEFT,SkyBox.RIGHT,SkyBox.TOP]; | ||||||
|             for each(surfaceId in surfaceIds) |             for each(surfaceId in surfaceIds) | ||||||
|             { |             { | ||||||
|                texture = this.skyboxFiles.getValue(surfaceId); |                texture = this.bitmapCollector[surfaceId]; | ||||||
|                textureResource = new ATFTextureResource(texture); |                textureResource = new BitmapTextureResource(texture.bitmapData); | ||||||
|                skyBox.getSide(surfaceId).material = new SkyMaterial(textureResource); |                skyBox.getSide(surfaceId).material = new SkyMaterial(textureResource); | ||||||
|             } |             } | ||||||
|             renderSystem = this.gameKernel.getRenderSystem(); |             renderSystem = this.gameKernel.getRenderSystem(); | ||||||
| @@ -419,3 +434,46 @@ package alternativa.tanks.game.entities.map | |||||||
|    } |    } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | import alternativa.tanks.game.utils.Task; | ||||||
|  | import flash.utils.ByteArray; | ||||||
|  | import flash.display.Loader; | ||||||
|  | import flash.events.Event; | ||||||
|  | import flash.events.IOErrorEvent; | ||||||
|  | import flash.display.Bitmap; | ||||||
|  |  | ||||||
|  | class BitmapLoadTask extends Task | ||||||
|  | { | ||||||
|  |    private var data:ByteArray; | ||||||
|  |    private var name:String; | ||||||
|  |    private var collector:Object; | ||||||
|  |     | ||||||
|  |    public function BitmapLoadTask(data:ByteArray, name:String, collector:Object) | ||||||
|  |    { | ||||||
|  |       super(); | ||||||
|  |  | ||||||
|  |       this.data = data; | ||||||
|  |       this.name = name; | ||||||
|  |       this.collector = collector; | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |    override public function run() : void | ||||||
|  |    { | ||||||
|  |       var loader:Loader = new Loader(); | ||||||
|  |       loader.contentLoaderInfo.addEventListener(Event.COMPLETE, onBitmapLoad); | ||||||
|  |       loader.contentLoaderInfo.addEventListener(IOErrorEvent.IO_ERROR, onBitmapError); | ||||||
|  |       loader.loadBytes(this.data); | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |    private function onBitmapLoad(event:Event):void | ||||||
|  |    { | ||||||
|  |       trace("Loaded texture: " + this.name); | ||||||
|  |       var bitmap:Bitmap = event.target.content as Bitmap; | ||||||
|  |       this.collector[this.name] = bitmap; | ||||||
|  |       completeTask(); | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |    private function onBitmapError(event:Event):void | ||||||
|  |    { | ||||||
|  |       trace("Error loading texture: " + this.name); | ||||||
|  |    } | ||||||
|  | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Pyogenics
					Pyogenics