Exemple #1
0
    private void  readFile()
    {
        int        tick = ConvertDateTimeInt(DateTime.Now);
        FileStream sr2  = new FileStream("map.vox", FileMode.OpenOrCreate, FileAccess.Read);

        System.IO.BinaryReader br2 = new System.IO.BinaryReader(sr2);
        vs2 = VoxelFormater.ReadFromMagicaVoxel(br2);
        sr2.Close();
        System.Diagnostics.StackTrace st = new System.Diagnostics.StackTrace();


        logIt("readFile", ConvertDateTimeInt(DateTime.Now) - tick);
    }
    public void SplitVoxelTest()
    {
        VectorInt3 a = new VectorInt3(3, 4, 5);
        VectorInt3 b = new VectorInt3(1, 2, 3);

        Assert.AreEqual(a - b, new VectorInt3(2, 2, 2));

        FileStream sr2 = new FileStream(".//Assets//Voxel//grass.bytes", FileMode.OpenOrCreate, FileAccess.Read);

        System.IO.BinaryReader br2 = new System.IO.BinaryReader(sr2);

        VoxelStruct vs = VoxelFormater.ReadFromMagicaVoxel(br2);


        SplitVoxel split = new SplitVoxel(vs);

        split.addBox(new VectorInt3(0, 0, 0), new VectorInt3(16, 16, 3));
        split.addBox(new VectorInt3(0, 17, 0), new VectorInt3(16, 16, 3));
        split.addBox(new VectorInt3(0, 34, 0), new VectorInt3(16, 16, 3));
        split.addBox(new VectorInt3(0, 54, 0), new VectorInt3(16, 16, 3));


        split.addBox(new VectorInt3(20, 0, 0), new VectorInt3(16, 16, 3));
        split.addBox(new VectorInt3(20, 17, 0), new VectorInt3(16, 16, 3));
        split.addBox(new VectorInt3(20, 34, 0), new VectorInt3(16, 16, 3));
        split.addBox(new VectorInt3(20, 54, 0), new VectorInt3(16, 16, 3));


        split.addBox(new VectorInt3(37, 0, 0), new VectorInt3(16, 16, 3));
        split.addBox(new VectorInt3(37, 17, 0), new VectorInt3(16, 16, 3));
        split.addBox(new VectorInt3(37, 34, 0), new VectorInt3(16, 16, 3));
        split.addBox(new VectorInt3(37, 54, 0), new VectorInt3(16, 16, 3));


        split.addBox(new VectorInt3(54, 0, 0), new VectorInt3(16, 16, 3));
        split.addBox(new VectorInt3(54, 17, 0), new VectorInt3(16, 16, 3));
        split.addBox(new VectorInt3(54, 34, 0), new VectorInt3(16, 16, 3));
        split.addBox(new VectorInt3(54, 54, 0), new VectorInt3(16, 16, 3));
        /**/

        VoxelStruct[] voxels = split.doIt();
        for (int i = 0; i < voxels.Length; ++i)
        {
            FileStream sw = new FileStream("cool" + i + ".vox", FileMode.Create, FileAccess.Write);

            System.IO.BinaryWriter bw = new System.IO.BinaryWriter(sw);
            //voxels [i].normal ;
            VoxelFormater.WriteToMagicaVoxel(voxels[i], bw);
            sw.Close();
        }
        //VoxelStruct vs2 = splice.spliceAll ();
    }

    [Test]
    public void JoinVoxelTest()
    {
        return;

        /*
         * FileStream sr2 = new FileStream ("fly2.vox", FileMode.OpenOrCreate, FileAccess.Read);
         *
         *
         * System.IO.BinaryReader br2 = new System.IO.BinaryReader (sr2);
         *
         * VoxelStruct vs = VoxelFormater.ReadFromMagicaVoxel (br2);
         *
         * sr2.Close ();
         * JoinVoxel join = new JoinVoxel ();
         * join.addVoxel(vs, new VectorInt3(0, 0, 0));
         * join.addVoxel(vs, new VectorInt3(10, 10, 10));
         * VoxelStruct vs2 = join.doIt ();
         *
         * FileStream sw = new FileStream ("fly3.vox", FileMode.Create, FileAccess.Write);
         *
         * System.IO.BinaryWriter bw = new System.IO.BinaryWriter (sw);
         * VoxelFormater.WriteToMagicaVoxel (vs2, bw);
         * sw.Close ();
         * /*
         *
         * Assert.AreEqual(vs.main.name, vs2.main.name);
         * Assert.AreEqual(vs.main.size, vs2.main.size);
         * Assert.AreEqual(vs.main.chunks, vs2.main.chunks);
         *
         *
         * Assert.AreEqual(vs.size.box, vs2.size.box);
         * Assert.AreEqual(vs.size.name, vs2.size.name);
         * Assert.AreEqual(vs.size.size, vs2.size.size);
         * Assert.AreEqual(vs.size.chunks, vs2.size.chunks);
         */

        //Assert.AreEqual(vs.rgba.palette.Length, vs2.rgba.palette.Length);

        /*for (int i = 0; i < vs.rgba.palette.Length; ++i) {
         *      Assert.AreEqual(vs.rgba.palette[i], vs2.rgba.palette[i]);
         * }*/
        /*//		Debug.Log (vs2.rgba.palette.Length);
         * Assert.AreEqual(vs.rgba.name, vs2.rgba.name);
         * Assert.AreEqual(vs.rgba.size, vs2.rgba.size);
         * Assert.AreEqual(vs.rgba.chunks, vs2.rgba.chunks);
         */
    }
    public void VoxelFormaterTest()
    {
        //Arrange
        // var gameObject = new GameObject();

        //Act
        //Try to rename the GameObject
        // var newGameObjectName = "My game object";
        //gameObject.name = newGameObjectName;

        //VoxelWriter writer = gameObject.GetComponent<VoxelWriter> ();
        //VoxelFormater formater = gameObject.GetComponent<VoxelFormater> ();

        FileStream sr = new FileStream(".//Assets//Voxel//chr_cop2.bytes", FileMode.OpenOrCreate, FileAccess.Read);


        System.IO.BinaryReader br = new System.IO.BinaryReader(sr);


        VoxelStruct vs = VoxelFormater.ReadFromMagicaVoxel(br);


        FileStream sw = new FileStream("fly2.vox", FileMode.Create, FileAccess.Write);

        System.IO.BinaryWriter bw = new System.IO.BinaryWriter(sw);
        VoxelFormater.WriteToMagicaVoxel(vs, bw);


        sw.Close();
        sr.Close();

        FileStream sr2 = new FileStream("fly2.vox", FileMode.OpenOrCreate, FileAccess.Read);


        System.IO.BinaryReader br2 = new System.IO.BinaryReader(sr2);

        VoxelStruct vs2 = VoxelFormater.ReadFromMagicaVoxel(br2);

        Assert.AreEqual(vs.main.name, vs2.main.name);
        Assert.AreEqual(vs.main.size, vs2.main.size);
        Assert.AreEqual(vs.main.chunks, vs2.main.chunks);


        Assert.AreEqual(vs.size.box, vs2.size.box);
        Assert.AreEqual(vs.size.name, vs2.size.name);
        Assert.AreEqual(vs.size.size, vs2.size.size);
        Assert.AreEqual(vs.size.chunks, vs2.size.chunks);


        Assert.AreEqual(vs.rgba.palette.Length, vs2.rgba.palette.Length);
        for (int i = 0; i < vs.rgba.palette.Length; ++i)
        {
            Assert.AreEqual(vs.rgba.palette[i], vs2.rgba.palette[i]);
        }

//		Debug.Log (vs2.rgba.palette.Length);
        Assert.AreEqual(vs.rgba.name, vs2.rgba.name);
        Assert.AreEqual(vs.rgba.size, vs2.rgba.size);
        Assert.AreEqual(vs.rgba.chunks, vs2.rgba.chunks);

        sr2.Close();

        for (int i = 0; i < VoxelFormater.palette_.Length; ++i)
        {
            ushort s  = VoxelFormater.palette_ [i];
            Color  c  = VoxelFormater.Short2Color(s);
            ushort s2 = VoxelFormater.Color2Short(c);
            Color  c2 = VoxelFormater.Short2Color(s2);
            Assert.AreEqual(s, s2);
            Assert.AreEqual(c, c2);
        }


        //Debug.Log ();
        Assert.AreEqual(vs.datas.Count, vs2.datas.Count);

//		Debug.Log (vs2.datas.Length);
        for (int i = 0; i < vs.datas.Count; ++i)
        {
            Assert.AreEqual(vs.datas[i].color, vs2.datas[i].color);
            Assert.AreEqual(vs.datas[i].pos.x, vs2.datas[i].pos.x);
            Assert.AreEqual(vs.datas[i].pos.y, vs2.datas[i].pos.y);
            Assert.AreEqual(vs.datas[i].pos.z, vs2.datas[i].pos.z);
        }


        Assert.AreEqual(vs.datas.Count, vs.datas.Count);
    }