當前位置: 首頁>>代碼示例>>C#>>正文


C# Color.Clone方法代碼示例

本文整理匯總了C#中Color.Clone方法的典型用法代碼示例。如果您正苦於以下問題:C# Color.Clone方法的具體用法?C# Color.Clone怎麽用?C# Color.Clone使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Color的用法示例。


在下文中一共展示了Color.Clone方法的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: SetKeysAround

        private static void SetKeysAround(uint rowStart, uint colStart)
        {
            var colors = new Color[6][];
            var colorsColumns = new Color[22];
            for (var i = 0; i < colorsColumns.Length; i++)
            {
                colorsColumns[i] = Color.Black;
            }
            for (var i = 0; i < colors.Length; i++)
            {
                colors[i] = (Color[]) colorsColumns.Clone();
            }

            var indexList = new List<Tuple<int, int>>
            {
                Tuple.Create(-1, -1),
                Tuple.Create(-1, 0),
                Tuple.Create(-1, +1),
                Tuple.Create(0, -1),
                Tuple.Create(0, 0),
                Tuple.Create(0, +1),
                Tuple.Create(+1, -1),
                Tuple.Create(+1, 0),
                Tuple.Create(+1, +1)
            };

            foreach (var tuple in indexList)
            {
                if (((2 + tuple.Item1) > 0 && (2 + tuple.Item1) < maxRows)
                    && ((keyIndex + tuple.Item2) > 0 && (keyIndex + tuple.Item2) < maxCols))
                {
                    float brightnessModifier = (tuple.Item1 == 0 && tuple.Item2 == 0) ? 0f : 0.85f;
                    colors[2 + tuple.Item1][keyIndex + tuple.Item2] = new Color((1f - brightnessModifier), 0f, 0f);
                }
            }

            Keyboard.Instance.Set(new CustomGrid(colors));
            if (keyIndex >= maxCols)
            {
                keyIndex = 0;
            }
            else
            {
                keyIndex++;
            }
        }
開發者ID:danm-de,項目名稱:DrunkenOctoNinja,代碼行數:46,代碼來源:Program.cs

示例2: OnGUI


//.........這裏部分代碼省略.........
        EditorGUI.EndProperty();
        addRow(ref position, rowHeight);
        addRow(ref position, rowHeight);
        EditorGUI.LabelField(position, "Sprite Shattering Properties", EditorStyles.boldLabel);
        addRow(ref position, rowHeight);
        property.Next(false);
        EditorGUI.BeginProperty(position, label, property);
        property.vector2Value = EditorGUI.Vector2Field(position, new GUIContent("Explode From", "The position from which to apply the explosion force when " +
                "exploding the shattered pieces of the sprite. The X co-ordinate should be 0 for the left edge of the sprite and 1 for the right edge, and " +
                "the Y co-ordinate should be 0 for bottom of the sprite and 1 for the top, although the values can be outside this range. For example to " +
                "make the sprite explode up from the bottom, co-ordinates of (0.5, 0) could be used."), property.vector2Value);
        EditorGUI.EndProperty();
        addRow(ref position, rowHeight);
        property.Next(false);
        EditorGUI.BeginProperty(position, label, property);
        property.vector2Value = EditorGUI.Vector2Field(position, new GUIContent("Explosion Force", "The force to apply in the X and Y direction when " +
                "exploding the shattered pieces of the sprite. A force of zero will make the sprite just collapse in its current position"),
                property.vector2Value);
        EditorGUI.EndProperty();
        addRow(ref position, rowHeight);

        //Display a preview texture with the cuts made. First display a "Preview" header.
        addRow(ref position, rowHeight);
        EditorGUI.LabelField(position, "Preview", EditorStyles.boldLabel);
        addRow(ref position, rowHeight);
        if (!textureImporter.isReadable) {
            position.height *= 2;
            EditorGUI.HelpBox(position, "Texture \"Read/Write\" flag not set!", MessageType.Error);
        }
        else {
            int textureWidth = (int) spriteRenderer.sprite.rect.width;
            int textureHeight = (int) spriteRenderer.sprite.rect.height;

            //Calculate the texture width and height from the window width.
            int previewTextureWidth = (int) (position.width * 0.75f);
            int previewTextureHeight = (int) (((float) textureHeight / (float) textureWidth) * position.width * 0.75f);
            Color[] sourcePixels = spriteRenderer.sprite.texture.GetPixels((int) spriteRenderer.sprite.rect.xMin, (int) spriteRenderer.sprite.rect.yMin,
                    (int) spriteRenderer.sprite.rect.width, (int) spriteRenderer.sprite.rect.height);

            //If the preview texture is at least two pixels wide...
            if (previewTextureWidth > 1) {

                //Call the method that makes the cuts as these will be drawn onto the texture.
                int[,] horizontalCutTop, verticalCutLeft;
                ((SpriteShatter.Shatter) property.serializedObject.targetObject).makeCuts(spriteRenderer.sprite, horizontalCuts, verticalCuts, randomSeed,
                        randomness, zigzagFrequency, zigzagAmplitude, out horizontalCutTop, out verticalCutLeft);

                //Create the preview texture and set its pixels from the main texture.
                Texture2D previewTexture = new Texture2D(previewTextureWidth, previewTextureHeight, TextureFormat.RGBA32, false);
                previewTexture.hideFlags = HideFlags.HideAndDontSave;
                Color[] previewTexturePixels = new Color[previewTextureWidth * previewTextureHeight];
                for (int i = 0; i < previewTextureWidth; i++)
                    for (int j = 0; j < previewTextureHeight; j++)
                        previewTexturePixels[(j * previewTextureWidth) + i] = sourcePixels[(((j * textureHeight) / previewTextureHeight) * textureWidth) +
                                ((i * textureWidth) / previewTextureWidth)];

                //Loop over the cuts and draw them on the texture (white with a black outline to cover all texture colours).
                Color[] originalPreviewTexturePixels = (Color[]) previewTexturePixels.Clone();
                for (int l = 0; l < 2; l++) {
                    for (int i = 0; i < horizontalCuts; i++)
                        for (int j = 0; j < textureWidth; j++) {
                            int previewTextureX = (j * previewTextureWidth) / textureWidth;
                            int previewTextureY = (horizontalCutTop[i, j] * previewTextureHeight) / textureHeight;
                            if (originalPreviewTexturePixels[(previewTextureY * previewTextureWidth) + previewTextureX].a > 0.001f) {
                                for (int m = l == 0 ? -1 : 0; m <= (l == 0 ? 1 : 0); m++)
                                    for (int k = l == 0 ? -1 : 0; k <= (l == 0 ? 1 : 0); k++) {
                                        if (previewTextureX + m >= 0 && previewTextureX + m < previewTextureWidth && previewTextureY + k >= 0 &&
                                                previewTextureY + k < previewTextureHeight)
                                            previewTexturePixels[((previewTextureY + k) * previewTextureWidth) + previewTextureX + m] = l == 0 ? Color.black :
                                                    Color.white;
                                    }
                            }
                        }
                    for (int i = 0; i < verticalCuts; i++)
                        for (int j = 0; j < textureHeight; j++) {
                            int previewTextureX = (verticalCutLeft[i, j] * previewTextureWidth) / textureWidth;
                            int previewTextureY = (j * previewTextureHeight) / textureHeight;
                            if (originalPreviewTexturePixels[(previewTextureY * previewTextureWidth) + previewTextureX].a > 0.001f) {
                                for (int m = l == 0 ? -1 : 0; m <= (l == 0 ? 1 : 0); m++)
                                    for (int k = l == 0 ? -1 : 0; k <= (l == 0 ? 1 : 0); k++)
                                        if (previewTextureX + m >= 0 && previewTextureX + m < previewTextureWidth && previewTextureY + k >= 0 &&
                                                previewTextureY + k < previewTextureHeight)
                                            previewTexturePixels[((previewTextureY + k) * previewTextureWidth) + previewTextureX + m] = l == 0 ? Color.black :
                                                    Color.white;
                            }
                        }
                }
                previewTexture.SetPixels(previewTexturePixels);
                previewTexture.Apply();

                //Draw the texture in the editor window.
                position.xMin += position.width * 0.125f;
                position.xMax -= position.width * 0.125f;
                position.height = previewTextureHeight;
                GUIStyle style = new GUIStyle();
                style.normal.background = previewTexture;
                EditorGUI.LabelField(position, GUIContent.none, style);
            }
        }
    }
開發者ID:stonecompass,項目名稱:mobilegame,代碼行數:101,代碼來源:ShatterPropertyDrawer.cs

示例3: SetObject

        public void SetObject( Vector3[] vertices, Color[] colors, int[,] ribs )
        {
            if ( vertices.Length != colors.Length )
            {
                throw new ArgumentException( "Number of colors must be equal to number of vertices." );
            }

            if ( ribs.GetLength( 1 ) != 2 )
            {
                throw new ArgumentException( "Ribs array must have 2 coordinates per rib." );
            }

            this.objectPoints = (Vector3[]) vertices.Clone( );
            this.colors = (Color[]) colors.Clone( );
            this.lines = (int[,]) ribs.Clone( );

            Recalculate( );
        }
開發者ID:CanerPatir,項目名稱:framework,代碼行數:18,代碼來源:WorldRendererControl.cs

示例4: PaletteTable

 public PaletteTable(Color[] palette)
 {
     this.palette = (Color[])palette.Clone();
 }
開發者ID:metadeta96,項目名稱:openpdn,代碼行數:4,代碼來源:PaletteTable.cs

示例5: Stroke

 public void Stroke(GraphicsPath path, Graphics g, int time, float opacity)
 {
     int num1 = 0;
     int num2 = 0;
     AnimFunc.CreateAnimateValues(this, time, out num1, out num2);
     path.FillMode = FillMode.Alternate;
     g.SmoothingMode = base.OwnerDocument.SmoothingMode;
     SpreadMethods methods1 = this.SpreadMethod;
     bool flag1 = this.Units == Units.UserSpaceOnUse;
     float single1 = this.CX;
     float single2 = this.CY;
     float single3 = this.R;
     float single4 = this.FX;
     float single5 = this.FY;
     PointF[] tfArray2 = new PointF[7] { new PointF(single1, single2), new PointF(single1 + single3, single2), new PointF(single1 + (single3 * ((float) Math.Sin(1.8325957145940459))), single2 + (single3 * ((float) Math.Cos(1.8325957145940459)))), new PointF(single1 + (single3 * ((float) Math.Sin(1.3089969389957472))), single2 + (single3 * ((float) Math.Cos(1.3089969389957472)))), new PointF(single1, single2 + single3), PointF.Empty, PointF.Empty } ;
     this.boundsPoints = tfArray2;
     GraphicsPath path1 = this.gradientpath;
     path1.Reset();
     path1.AddEllipse((float) (single1 - single3), (float) (single2 - single3), (float) (2f * single3), (float) (2f * single3));
     RectangleF ef1 = RectangleF.Empty;
     RectangleF ef2 = PathFunc.GetBounds(path);
     RectangleF ef3 = RectangleF.Empty;
     this.coord.Reset();
     if (flag1)
     {
         ef3 = ((SVG) base.OwnerDocument.DocumentElement).ViewPort;
     }
     else
     {
         ef2 = new RectangleF(0f, 0f, 1f, 1f);
         ef3 = ef2;
         ef1 = PathFunc.GetBounds(path);
         this.coord.Translate(ef1.X, ef1.Y);
         this.coord.Scale(ef1.Width, ef1.Height);
     }
     ColorBlend blend1 = new ColorBlend(this.Stops.Count);
     Color[] colorArray1 = new Color[this.Stops.Count];
     float[] singleArray1 = new float[this.Stops.Count];
     SvgElementCollection collection1 = this.Stops;
     for (int num3 = 0; num3 < collection1.Count; num3++)
     {
         GradientStop stop1 = (GradientStop) collection1[num3];
         AnimFunc.CreateAnimateValues(stop1, time, out num1, out num2);
         int num4 = 0xff;
         if ((stop1.Opacity >= 0f) && (stop1.Opacity <= 255f))
         {
             if (stop1.Opacity <= 1f)
             {
                 num4 = (int) (stop1.Opacity * 255f);
             }
             else
             {
                 num4 = (int) stop1.Opacity;
             }
         }
         num4 = (int) Math.Min((float) (opacity * 255f), (float) num4);
         Color color1 = stop1.Color;
         float single6 = Math.Min((float) 1f, Math.Max((float) 0f, stop1.ColorOffset));
         colorArray1[num3] = Color.FromArgb(num4, color1.R, color1.G, color1.B);
         singleArray1[num3] = single6;
     }
     float[] singleArray2 = (float[]) singleArray1.Clone();
     Color[] colorArray2 = (Color[]) colorArray1.Clone();
     Array.Sort(singleArray2, colorArray2);
     Color color2 = colorArray2[0];
     Color color3 = colorArray2[colorArray2.Length - 1];
     if (singleArray2[0] != 0f)
     {
         float[] singleArray3 = (float[]) singleArray2.Clone();
         Color[] colorArray3 = (Color[]) colorArray2.Clone();
         singleArray2 = new float[singleArray2.Length + 1];
         colorArray2 = new Color[colorArray2.Length + 1];
         colorArray3.CopyTo(colorArray2, 1);
         singleArray3.CopyTo(singleArray2, 1);
         singleArray2[0] = 0f;
         colorArray2[0] = color2;
     }
     if (singleArray2[singleArray2.Length - 1] != 1f)
     {
         float[] singleArray4 = (float[]) singleArray2.Clone();
         Color[] colorArray4 = (Color[]) colorArray2.Clone();
         singleArray2 = new float[singleArray2.Length + 1];
         singleArray4.CopyTo(singleArray2, 0);
         singleArray2[singleArray2.Length - 1] = 1f;
         colorArray2 = new Color[colorArray2.Length + 1];
         colorArray4.CopyTo(colorArray2, 0);
         colorArray2[colorArray2.Length - 1] = color3;
     }
     if (methods1 == SpreadMethods.Pad)
     {
         float single7 = Math.Min((float) (single1 - single3), ef2.X);
         float single8 = Math.Min((float) (single2 - single3), ef2.Y);
         float single9 = Math.Max(single3, (float) (ef2.Width / 2f));
         float single10 = this.cx - single3;
         float single11 = this.r;
         for (int num5 = 0; num5 < singleArray2.Length; num5++)
         {
             singleArray2[num5] = ((single10 + (single11 * singleArray2[num5])) - single7) / single9;
         }
         if (singleArray2[0] != 0f)
//.........這裏部分代碼省略.........
開發者ID:EdgarEDT,項目名稱:myitoppsp,代碼行數:101,代碼來源:RadialGradients.cs

示例6: FillObject

        public Color[,] FillObject(Color[,] input)
        {
            if (perimeterPixels == null)
                return input;

            Color[,] output = (Color[,])input.Clone();

            for (int i = 0; i < perimeterListPixels.Count; i++)
            {
                int x1 = perimeterListPixels[i].X, y1 = perimeterListPixels[i].Y;

                for (int j = 0; j < perimeterListPixels.Count; j++)
                {
                    if (i == j)
                        continue;

                    int x2 = perimeterListPixels[j].X, y2 = perimeterListPixels[j].Y;

                    double distance = Math.Sqrt(Math.Pow(x2 - x1, 2) + Math.Pow(y2 - y1, 2));
                    double stepXDistance = ((double)(x2 - x1)) / distance;
                    double stepYDistance = ((double)(y2 - y1)) / distance;

                    for (int k = 0; k < distance; k++)
                    {
                        int uv1X = OffsetX + x1 + ((int)Math.Round(stepXDistance * k));
                        int uv1Y = OffsetY + y1 + ((int)Math.Round(stepYDistance * k));

                        if (uv1X < 0) // For safety
                            uv1X = 0;
                        if (uv1X > output.GetLength(0) - 1)
                            uv1X = output.GetLength(0) - 1;

                        if (uv1Y < 0)
                            uv1Y = 0;
                        if (uv1Y > output.GetLength(1) - 1)
                            uv1Y = output.GetLength(1) - 1;

                        output[uv1X, uv1Y] = Color.Black;
                    }
                }
            }

            return output;
        }
開發者ID:aelex13,項目名稱:RugbyIBV,代碼行數:44,代碼來源:ImageObject.cs

示例7: ColorizeVectors

        public Color[,] ColorizeVectors(Color[,] input)
        {
            if (LongestChord.firstPixel == null || LongestChord.secondPixel == null
                || LongestPerpendicularChord.firstPixel == null || LongestPerpendicularChord.secondPixel == null)
                return input;

            Color[,] output = (Color[,])input.Clone();

            double angle = LongestChord.orientation;
            double uv1CosAngle = Math.Cos(angle);
            double uv1SinAngle = Math.Sin(angle);

            double pAngle = Math.PI / 2;
            double[] rotationArray = new double[] { Math.Cos(pAngle), -1.0 * Math.Sin(pAngle), Math.Sin(pAngle), Math.Cos(pAngle) };
            Matrix<double> rotationMatrix = new DenseMatrix(2, 2, rotationArray);

            Vector<double> unitVector1 = new DenseVector(new double[] { uv1CosAngle, uv1SinAngle });
            Vector<double> unitVector2 = new DenseVector(new double[2]);
            rotationMatrix.LeftMultiply(unitVector1, unitVector2);

            double uv2CosAngle = unitVector2[0];
            double uv2SinAngle = unitVector2[1];

            int lcX = 0;
            if (uv1CosAngle > 0)
                if (LongestChord.firstPixel.X < LongestChord.secondPixel.X)
                    lcX = LongestChord.firstPixel.X;
                else
                    lcX = LongestChord.secondPixel.X;
            else
                if (LongestChord.firstPixel.X < LongestChord.secondPixel.X)
                    lcX = LongestChord.secondPixel.X;
                else
                    lcX = LongestChord.firstPixel.X;

            int lcY = 0;
            if (uv1SinAngle > 0)
                if (LongestChord.firstPixel.Y < LongestChord.secondPixel.Y)
                    lcY = LongestChord.firstPixel.Y;
                else
                    lcY = LongestChord.secondPixel.Y;
            else
                if (LongestChord.firstPixel.Y < LongestChord.secondPixel.Y)
                    lcY = LongestChord.secondPixel.Y;
                else
                    lcY = LongestChord.firstPixel.Y;

            for (int i = 0; i < LongestChord.distance; i++)
            {
                int uv1X = OffsetX + lcX + ((int)Math.Round(uv1CosAngle * i));
                int uv1Y = OffsetY + lcY + ((int)Math.Round(uv1SinAngle * i));
                output[uv1X, uv1Y] = Color.Red;
            }

            int lpcX = 0;
            if (uv2CosAngle > 0)
                if (LongestPerpendicularChord.firstPixel.X < LongestPerpendicularChord.secondPixel.X)
                    lpcX = LongestPerpendicularChord.firstPixel.X;
                else
                    lpcX = LongestPerpendicularChord.secondPixel.X;
            else
                if (LongestPerpendicularChord.firstPixel.X < LongestPerpendicularChord.secondPixel.X)
                    lpcX = LongestPerpendicularChord.secondPixel.X;
                else
                    lpcX = LongestPerpendicularChord.firstPixel.X;

            int lpcY = 0;
            if (uv2SinAngle > 0)
                if (LongestPerpendicularChord.firstPixel.Y < LongestPerpendicularChord.secondPixel.Y)
                    lpcY = LongestPerpendicularChord.firstPixel.Y;
                else
                    lpcY = LongestPerpendicularChord.secondPixel.Y;
            else
                if (LongestPerpendicularChord.firstPixel.Y < LongestPerpendicularChord.secondPixel.Y)
                    lpcY = LongestPerpendicularChord.secondPixel.Y;
                else
                    lpcY = LongestPerpendicularChord.firstPixel.Y;

            for (int i = 0; i < LongestPerpendicularChord.distance; i++)
            {
                int uv2X = OffsetX + lpcX + ((int)Math.Round(uv2CosAngle * i));
                int uv2Y = OffsetY + lpcY + ((int)Math.Round(uv2SinAngle * i));
                output[uv2X, uv2Y] = Color.Blue;
            }

            return output;
        }
開發者ID:aelex13,項目名稱:RugbyIBV,代碼行數:87,代碼來源:ImageObject.cs

示例8: Colorize

        public Color[,] Colorize(Color[,] input)
        {
            Color[,] output = (Color[,])input.Clone();

            for (int i = -4; i < 5; i++)
            {
                for (int j = -4; j < 5; j++)
                {
                    output[OffsetX + LongestChord.firstPixel.X + i, OffsetY + LongestChord.firstPixel.Y + j] = Color.Red;
                    output[OffsetX + LongestChord.secondPixel.X + i, OffsetY + LongestChord.secondPixel.Y + j] = Color.Orange;
                    output[OffsetX + LongestPerpendicularChord.firstPixel.X + i, OffsetY + LongestPerpendicularChord.firstPixel.Y + j] = Color.Blue;
                    output[OffsetX + LongestPerpendicularChord.secondPixel.X + i, OffsetY + LongestPerpendicularChord.secondPixel.Y + j] = Color.Cyan;
                }
            }

            return output;
        }
開發者ID:aelex13,項目名稱:RugbyIBV,代碼行數:17,代碼來源:ImageObject.cs

示例9: Stroke

 public void Stroke(GraphicsPath path, Graphics g, int time, float opacity)
 {
     int num1 = 0;
     int num2 = 0;
     GraphicsContainer container1 = g.BeginContainer();
     AnimFunc.CreateAnimateValues(this, time, out num1, out num2);
     g.SmoothingMode = base.OwnerDocument.SmoothingMode;
     SpreadMethods methods1 = this.SpreadMethod;
     bool flag1 = this.Units == Units.UserSpaceOnUse;
     float single1 = this.X1;
     float single2 = this.Y1;
     float single3 = this.X2;
     float single4 = this.Y2;
     if ((single1 == single3) && (single2 == single4))
     {
         single1 -= 1E-05f;
         single3 += 1E-05f;
     }
     float single5 = single1;
     float single6 = single2;
     float single7 = single3;
     float single8 = single4;
     RectangleF ef1 = RectangleF.Empty;
     RectangleF ef2 = RectangleF.Empty;
     Matrix matrix1 = this.Transform.Matrix.Clone();
     PointF[] tfArray4 = new PointF[2] { new PointF(single1, single2), new PointF(single3, single4) } ;
     PointF[] tfArray1 = tfArray4;
     matrix1.TransformPoints(tfArray1);
     single1 = tfArray1[0].X;
     single3 = tfArray1[1].X;
     single2 = tfArray1[0].Y;
     single4 = tfArray1[1].Y;
     bool flag2 = single2 == single4;
     bool flag3 = single1 == single3;
     float single9 = 1f;
     this.coord = new Matrix();
     this.ratiomatrix = new Matrix();
     RectangleF ef3 = PathFunc.GetBounds(path);
     if (flag1)
     {
         ef1 = ((SVG) base.OwnerDocument.DocumentElement).ViewPort;
     }
     else
     {
         ef3 = new RectangleF(0f, 0f, 1f, 1f);
         ef1 = ef3;
         ef2 = PathFunc.GetBounds(path);
         this.coord.Translate(ef2.X, ef2.Y);
         this.coord.Scale(ef2.Width, ef2.Width);
         this.ratiomatrix.Scale(1f, ef2.Height / ef2.Width);
     }
     PointF tf1 = new PointF(single1, single2);
     PointF tf2 = new PointF(single3, single4);
     PointF tf3 = tf1;
     PointF tf4 = tf2;
     ColorBlend blend1 = new ColorBlend(this.Stops.Count);
     Color[] colorArray1 = new Color[this.Stops.Count];
     float[] singleArray1 = new float[this.Stops.Count];
     SvgElementCollection collection1 = this.Stops;
     for (int num3 = 0; num3 < collection1.Count; num3++)
     {
         GradientStop stop1 = (GradientStop) collection1[num3];
         AnimFunc.CreateAnimateValues(stop1, time, out num1, out num2);
         int num4 = 0xff;
         if ((stop1.Opacity >= 0f) && (stop1.Opacity <= 255f))
         {
             if (stop1.Opacity <= 1f)
             {
                 num4 = (int) (stop1.Opacity * 255f);
             }
             else
             {
                 num4 = (int) stop1.Opacity;
             }
         }
         num4 = (int) Math.Min((float) (opacity * 255f), (float) num4);
         Color color1 = stop1.Color;
         float single10 = Math.Min((float) 1f, Math.Max((float) 0f, stop1.ColorOffset));
         colorArray1[num3] = Color.FromArgb(num4, color1.R, color1.G, color1.B);
         singleArray1[num3] = single10;
     }
     float[] singleArray2 = (float[]) singleArray1.Clone();
     Color[] colorArray2 = (Color[]) colorArray1.Clone();
     Array.Sort(singleArray2, colorArray2);
     Color color2 = colorArray2[0];
     Color color3 = colorArray2[colorArray2.Length - 1];
     float single11 = singleArray2[0];
     float single12 = singleArray2[singleArray2.Length - 1];
     if (singleArray2[0] != 0f)
     {
         float[] singleArray3 = (float[]) singleArray2.Clone();
         Color[] colorArray3 = (Color[]) colorArray2.Clone();
         singleArray2 = new float[singleArray2.Length + 1];
         colorArray2 = new Color[colorArray2.Length + 1];
         colorArray3.CopyTo(colorArray2, 1);
         singleArray3.CopyTo(singleArray2, 1);
         singleArray2[0] = 0f;
         colorArray2[0] = color2;
     }
     if (singleArray2[singleArray2.Length - 1] != 1f)
//.........這裏部分代碼省略.........
開發者ID:EdgarEDT,項目名稱:myitoppsp,代碼行數:101,代碼來源:LinearGradient.cs

示例10: Board

 public Board(Color[,] colors)
 {
     Colors = (Color[,])colors.Clone();
     FireBoardUpdated();
 }
開發者ID:glenwatson,項目名稱:Flood-It-Solver,代碼行數:5,代碼來源:Board.cs

示例11: Palette

 /// <summary>
 /// 
 /// </summary>
 /// <param name="aclr"></param>
 public Palette(Color[] aclr)
 {
     m_aclr = (Color[])aclr.Clone();
 }
開發者ID:RusselRains,項目名稱:hostile-takeover,代碼行數:8,代碼來源:palette.cs


注:本文中的Color.Clone方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。