512x512x512 Voxel

by Albert
♥1 | Line 296 | Modified 2011-01-21 01:05:49 | MIT License
play

ActionScript3 source code

/**
 * Copyright Albert ( http://wonderfl.net/user/Albert )
 * MIT License ( http://www.opensource.org/licenses/mit-license.php )
 * Downloaded from: http://wonderfl.net/c/cUXH
 */

package
{
    
    import flash.display.Bitmap;
    import flash.display.BitmapData;
    import flash.display.Sprite;
    import flash.display.StageAlign;
    import flash.display.StageQuality;
    import flash.display.StageScaleMode;
    import flash.events.Event;
    import flash.net.URLRequest;
    import flash.net.URLStream;
    import flash.text.TextField;
    import flash.text.TextFormat;
    import flash.utils.ByteArray;
    
    public class voxel extends Sprite
    {
        private var outputBitmapData : BitmapData;
        private var outputBitmap : Bitmap;
        private var urlStream : URLStream = new URLStream();
        private var fileData : ByteArray = new ByteArray();
        private var psin : Array = [];
        private var pcos : Array = [];    
        private var x10 : Array = [];
        private var y10 : Array = [];
        private var z10 : Array = [];
        private var kz : Array = [];
        private var ad : Array = [];
        private var color : Array = [];
        private var tp : Array = [];
        
        private var x101 : Array = [];
        private var y101 : Array = [];
        private var color1 : Array = [];
        private var x102 : Array = [];
        private var y102 : Array = [];
        private var color2 : Array = [];
        private var x103 : Array = [];
        private var y103 : Array = [];
        private var color3 : Array = [];
        private var x104 : Array = [];
        private var y104 : Array = [];
        private var color4 : Array = [];
        
        private var voxels : int = 512;
        private var ang : int = 0;
        private var ang2 : int = 0;
        
        private var textfield : TextField;
        private var timer:int = 0;
        private var completed:Boolean = false;
        
        public function voxel()
        {
            stage.align = StageAlign.TOP_LEFT;
            stage.quality = StageQuality.LOW;
            stage.scaleMode = StageScaleMode.NO_SCALE;
            
            outputBitmapData = new BitmapData(512, 492, false);            
            outputBitmap = new Bitmap(outputBitmapData);
            addChild(outputBitmap);
            
            textfield = new TextField();
            textfield.defaultTextFormat = new TextFormat("_sans");
            textfield.text = "Initializing";
            textfield.autoSize = "left";
            textfield.x = (stage.stageWidth >> 1) - (textfield.width >> 1);
            addChild(textfield);
            
            onStageResize(null);
            //addEventListener(Event.ADDED_TO_STAGE, loaded);
            addEventListener(Event.ENTER_FRAME, update);
         
        }
        
        public function loaded(e:Event):void
        {
            var n:int, n2:int, x:int, x2:int, y:int, z:int;
            var num:Array = [];
            var i:int = 0;
            var nx:int, ny:int;    
            var cont1:int=0, cont2:int=0, cont3:int=0, cont4:int=0, s:int=0;

            for (n=0; n<=16383; n++)
            {            
                psin[n]=Math.sin((n)*((3.141592)/(4096)))*65536;
                pcos[n]=Math.cos((n)*((3.141592)/(4096)))*65536;
            }
            var u:int,v:int,w:int;
            var ix:int,iy:int,iz:int;
            for (n = 0; n < 512; n++) kz[n] = 0;
            for (n=0; n<voxels; n++)
            {
                if (n%2==0) u++;
                if (n%20==0) v++;
                //if (n<512*128) w++; else w--;
                x10[n] = ((256-u/2)+ix)%512;
                y10[n] = ((256-v/2)+iy)%512
                z10[n] = iz%512;
                ix++;
                if (ix>u)
               {
                   iy++;
                   ix=0;
               }
               if (iy>v)
              {
                  iz++;
                  iy=0; 
              }
            }
            for (n=0; n<voxels; n++)
            {
                color[n]=n/512*0x010101;
            }
            for (n=0; n<512; n++)
            {
                ad[n] = 1;
            }
            for (n=0; n<voxels; n++)
            {
                n2 = z10[n];
                kz[n2]=n;            
            }
            
            
            for (i=100; i<512; i++)
            {    
                if (kz[i])
                {
                    var tmp:int;
                    
                    for (n = 0; n < 512; n++) num[n]=0;                
                    for (n=s; n<=kz[i]; n++)
                    {
                        y = y10[n];                    
                        tp[(y<<9)+num[y]] = n;
                        num[y]++;                    
                    }                
                    for (n=0; n<512; n++)
                    {                    
                        for (x = 0; x < num[n]; x++)
                        {
                            for (x2 = x + 1; x2 < num[n]; x2++)
                            {
                                if ((x10[tp[(n << 9) + x]]) > (x10[tp[(n << 9) + x2]]))
                                {
                                    tmp = tp[(n << 9) + x];
                                    tp[(n << 9) + x] = tp[(n << 9) + x2];
                                    tp[(n << 9) + x2] = tmp;
                                }
                            }
                        }
                        for (x = 0; x < num[n]; x++)
                        {
                            n2 = tp[(n<<9)+x];
                            x101[cont1]=x10[n2]-256;
                            y101[cont1]=y10[n2]-256;
                            color1[cont1]=color[n2];                        
                            cont1++;
                        }
                    }
                    for (n = 0; n < 512; n++) num[n]=0;                
                    for (n=s; n<=kz[i]; n++)
                    {
                        x = x10[n];                    
                        tp[(x<<9)+num[x]] = n;
                        num[x]++;                    
                    }                
                    for (n=511; n>=0; n--)
                    {                    
                        for (x = 0; x < num[n]; x++)
                        {
                            for (x2 = x + 1; x2 < num[n]; x2++)
                            {
                                if ((y10[tp[(n << 9) + x]]) > (y10[tp[(n << 9) + x2]]))
                                {                                
                                    tmp = tp[(n << 9) + x];
                                    tp[(n << 9) + x] = tp[(n << 9) + x2];
                                    tp[(n << 9) + x2] = tmp;
                                }
                            }
                        }
                        for (x = 0; x < num[n]; x++)
                        {
                            n2 = tp[(n<<9)+x];
                            x102[cont2]=x10[n2]-256;
                            y102[cont2]=y10[n2]-256;
                            color2[cont2]=color[n2];                        
                            cont2++;
                        }
                    }
                    for (n=s; n<=kz[i]; n++)
                    {
                        x103[n]=x101[s+kz[i]-n];
                        y103[n]=y101[s+kz[i]-n];
                        color3[n]=color1[s+kz[i]-n];
                        x104[n]=x102[s+kz[i]-n];
                        y104[n]=y102[s+kz[i]-n];
                        color4[n]=color2[s+kz[i]-n];
                    }
                    s=kz[i]+1;    
                }
            }
   
            addEventListener(Event.ENTER_FRAME, animIn);
            //addEventListener(Event.ENTER_FRAME, update);
            stage.addEventListener(Event.RESIZE, onStageResize);           
            outputBitmap.y = stage.stageHeight;
            completed = true;
        }
        
        public function update(e:Event):void
        {
            var x:int;
            var y:int;
            var i:int;
            var n:int;
            var s:int;
            var xr:int;
            var a:int, b:int, n2:int;
            var t:int;        
            var k:int;
            timer++;
            if (!completed)
           {
               if (timer % 40 == 0) textfield.text = "Initializing"+timer/40;
               loaded(null);
           }
  
            ang2 += (mouseX - (stage.stageWidth >> 1)) >> 1;
            ang = (ang2 + 81920000) % 8192;
            a = psin[ang];
            b = pcos[ang];
            
            outputBitmapData.lock();
            outputBitmapData.fillRect( outputBitmapData.rect, 0xffffff );
            s = ad[100];        
            
            if ((ang>=1024+2048+4096)||(ang<1024))
            {
                for (i=100; i<512; i++)
                {
                    t = kz[i];                
                    for (n=s; n<=t; n++)
                    {
                        xr = 256 + ((x101[n] * b + y101[n] * a) >> 16);                    
                        n2 = color1[n];
                        outputBitmapData.setPixel(xr++, i, n2);
                        outputBitmapData.setPixel(xr, i, n2);                    
                    }
                    s = t + ad[i];
                }
            }
            else if ((ang >= 1024) && (ang < 1024 + 2048))
            {
                for (i=100; i<512; i++)
                {
                    t = kz[i];
                    for (n=s; n<=t; n++)
                    {                            
                        xr = 256 + ((x102[n] * b + y102[n] * a) >> 16);                    
                        n2 = color2[n];
                        outputBitmapData.setPixel(xr++, i, n2);                    
                        outputBitmapData.setPixel(xr, i, n2);                    
                    }
                    s = t + ad[i];
                }
            }
            else if ((ang>=1024+2048)&&(ang<1024+4096))
            {
                for (i=100; i<512; i++)
                {
                    t = kz[i];
                    for (n=s; n<=t; n++)
                    {                            
                        xr = 256 + ((x103[n] * b + y103[n] * a) >> 16);                    
                        n2 = color3[n];
                        outputBitmapData.setPixel(xr++, i, n2);                    
                        outputBitmapData.setPixel(xr, i, n2);                    
                    }
                    s=t + ad[i];
                }
            }
            else 
            {
                for (i=100; i<512; i++)
                {
                    t = kz[i];
                    for (n=s; n<=t; n++)
                    {                            
                        xr = 256 + ((x104[n] * b + y104[n] * a) >> 16);                    
                        n2 = color4[n];
                        outputBitmapData.setPixel(xr++, i, n2);                    
                        outputBitmapData.setPixel(xr, i, n2);                    
                    }
                    s=t + ad[i];
                }
            }
            outputBitmapData.unlock();
        }
        
        private function animIn(e:Event):void
        {
            if (outputBitmap.y == (stage.stageHeight - outputBitmap.height))
            {
                textfield.visible = false;
                removeEventListener(Event.ENTER_FRAME, animIn);
            }
                
            textfield.y += (-20 -textfield.y) * .1;
            outputBitmap.y += ((stage.stageHeight - outputBitmap.height) - outputBitmap.y) * .05;
            
        }
        
        private function onStageResize(e:Event):void
        {
            outputBitmap.x = (stage.stageWidth >> 1) - (outputBitmap.width >> 1);     
            outputBitmap.y = stage.stageHeight - outputBitmap.height;
        }
    }
}

Forked