예제 #1
0
파일: Swizzle.cs 프로젝트: num0005/Mutation
        public static byte[] Swizzle(byte[] raw, int pixOffset, int Width, int Height, int depth, int bitCount, bool deswizzle)
        {
            bitCount /= 8;
            int a = 0;
            int b = 0;

            byte[] dataArray = new byte[raw.Length]; //Bitmap.Width * Height * bitCount;

            MaskSet masks = new MaskSet(Width, Height, depth);

            pixOffset = 0;
            for (int y = 0; y < Height * depth; y++)
            {
                for (int x = 0; x < Width; x++)
                {
                    if (deswizzle)
                    {
                        a = ((y * Width) + x) * bitCount;
                        b = (Swizzle(x, y, depth, masks)) * bitCount;
                    }
                    else
                    {
                        b = ((y * Width) + x) * bitCount;
                        a = (Swizzle(x, y, depth, masks)) * bitCount;
                    }

                    if (a < dataArray.Length && b < raw.Length)
                    {
                        for (int i = pixOffset; i < bitCount + pixOffset; i++)
                        {
                            dataArray[a + i] = raw[b + i];
                        }
                    }
                    else
                    {
                        return(null);
                    }
                }
            }

            //for (int u = 0; u < pixOffset; u++)
            //    raw[u] = raw[u];
            //for (int v = pixOffset + (Height * Width * depth * bitCount); v < raw.Length; v++)
            //    raw[v] = raw[v];

            return(dataArray);
        }
예제 #2
0
파일: Swizzle.cs 프로젝트: num0005/Mutation
 public static int Swizzle(int x, int y, int z, MaskSet masks)
 {
     return(SwizzleAxis(x, masks.x) | SwizzleAxis(y, masks.y) | (z == -1 ? 0 : SwizzleAxis(z, masks.z)));
 }