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


C# PointF.Clone方法代碼示例

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


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

示例1: GetAnimateValue

 public static object GetAnimateValue(SvgElement element, string attributename, DomType domtype, object orivalue)
 {
     PointF[] tfArray6;
     PointF[] tfArray7;
     PointF[] tfArray8;
     int num8;
     Matrix matrix1 = new Matrix();
     string text1 = string.Empty;
     GraphicsPath path1 = null;
     string text2 = string.Empty;
     PointF[] tfArray1 = null;
     bool flag1 = true;
     if (element.AnimateNameValues.ContainsKey(attributename))
     {
         AnimateInfo info1 = (AnimateInfo) element.AnimateNameValues[attributename];
         object[] objArray1 = info1.AnimateValues;
         bool[] flagArray1 = info1.ValueAdds;
         int num1 = 0;
         if ((domtype == DomType.SvgString) || (domtype == DomType.SvgLink))
         {
             for (int num2 = objArray1.Length - 1; num2 >= 0; num2--)
             {
                 if ((objArray1[num2] is string) && (objArray1[num2].ToString() != string.Empty))
                 {
                     if (element is ItopVector.Core.Figure.Image)
                     {
                         ((ItopVector.Core.Figure.Image) element).RefImage = ImageFunc.GetImageForURL(objArray1[num2].ToString(), element);
                     }
                     return objArray1[num2].ToString();
                 }
             }
             return orivalue;
         }
         object[] objArray2 = objArray1;
         for (int num10 = 0; num10 < objArray2.Length; num10++)
         {
             PointF[] tfArray2;
             float single3;
             GraphicsPath path2;
             PointF[] tfArray3;
             PointF[] tfArray4;
             PointF[] tfArray5;
             object obj1 = objArray2[num10];
             bool flag2 = flagArray1[num1];
             switch (domtype)
             {
                 case DomType.SvgMatrix:
                 {
                     Matrix matrix2 = new Matrix();
                     if ((obj1 != null) && (obj1.ToString() != string.Empty))
                     {
                         matrix2 = ((Matrix) obj1).Clone();
                     }
                     if (flag2)
                     {
                         matrix1.Multiply(matrix2);
                         goto Label_046F;
                     }
                     matrix1 = matrix2;
                     goto Label_046F;
                 }
                 case DomType.SvgNumber:
                 {
                     single3 = 0f;
                     if ((obj1 != null) && (obj1.ToString() != string.Empty))
                     {
                         single3 = (float) obj1;
                         if (!flag2 || (text1 == string.Empty))
                         {
                             goto Label_0246;
                         }
                         float single9 = float.Parse(text1) + single3;
                         text1 = single9.ToString();
                     }
                     goto Label_046F;
                 }
                 case DomType.SvgString:
                 {
                     goto Label_046F;
                 }
                 case DomType.SvgColor:
                 {
                     string text3 = string.Empty;
                     if ((obj1 != null) && (obj1.ToString() != string.Empty))
                     {
                         text3 = (string) obj1;
                     }
                     if (text3 != string.Empty)
                     {
                         if ((flag2 && (text2 != string.Empty)) && (!text2.Trim().StartsWith("url") && !text3.Trim().StartsWith("url")))
                         {
                             Color color1 = ColorFunc.ParseColor(text3);
                             Color color2 = ColorFunc.ParseColor(text2);
                             int num4 = (color1.R + color2.R) / 2;
                             int num5 = (color1.G + color2.G) / 2;
                             int num6 = (color1.B + color2.B) / 2;
                             string[] textArray1 = new string[7] { "rgb(", num4.ToString(), ",", num5.ToString(), ",", num6.ToString(), ")" } ;
                             text2 = string.Concat(textArray1);
                             goto Label_046F;
                         }
//.........這裏部分代碼省略.........
開發者ID:EdgarEDT,項目名稱:myitoppsp,代碼行數:101,代碼來源:AnimFunc.cs

示例2: FillPolygon

        public void FillPolygon(Brush brush, PointF[] inputPoints)
        {
            PointF[] points = (PointF[])inputPoints.Clone();

            Graphics g = _g;
            if (g == null)
            {
                return;
            }

            lock (this)
            {
                for (int i = 0; i < points.Length; i++)
                {
                    Convert(ref points[i]);
                }
                g.FillPolygon(brush, points);
            }
        }
開發者ID:redrhino,項目名稱:DotNetConnectTerminal,代碼行數:19,代碼來源:GraphicsWrapper.cs

示例3: ScaleRotateTranslatePoints

        /// <summary>
        /// Scale and rotate a graphics path around 0,0 the moves path to the given
        /// origin
        /// </summary>
        /// <param name="gp"></param>
        /// <param name="origin"></param>
        /// <param name="rotation"></param>
        /// <param name="xScale"></param>
        /// <param name="yScale"></param>
        public static PointF[] ScaleRotateTranslatePoints(PointF[] p0,
            PointF origin,
            float rotation,
            float xScale, float yScale)
        {
            // create affine transform

            Matrix m = new Matrix();

            // clone original points

            PointF[] p1 = (PointF[])p0.Clone();

            // rotate and scale

            m.Scale(xScale, yScale, MatrixOrder.Prepend);

            m.Rotate(rotation, MatrixOrder.Prepend);

            m.Translate(origin.X, origin.Y);

            // transform points

            m.TransformPoints(p1);

            // return points

            return p1;
        }
開發者ID:duncanmeech,項目名稱:RedEye,代碼行數:38,代碼來源:ImageUtility.cs

示例4: AddBeziers

    /// <summary>
    /// Adds a sequence of connected cubic Bézier curves to the current figure.
    /// </summary>
    public void AddBeziers(PointF[] points)
    {
      if (points.Length < 4)
        throw new ArgumentException("At least four points required for bezier curve.", "points");

      if ((points.Length - 1) % 3 != 0)
        throw new ArgumentException("Invalid number of points for bezier curve. Number must fulfil 4+3n.", "points");

      this.items.Add(new XGraphicsPathItem(XGraphicsPathItemType.Beziers, points.Clone() as XPoint[]));
      this.dirty = true;
      this.gdipPath.AddBeziers(points);
    }
開發者ID:BackupTheBerlios,項目名稱:zp7-svn,代碼行數:15,代碼來源:XGraphicsPath.cs

示例5: DrawPolygon

        public void DrawPolygon(Pen pen, PointF[] inputPoints)
        {
            PointF[] points = (PointF[])inputPoints.Clone();

            Graphics g = _g;
            if (g == null)
            {
                return;
            }

            lock (this)
            {
                for (int i = 0; i < points.Length; i++)
                {
                    Convert(ref points[i]);
                }
                g.DrawPolygon(pen, points);
            }
        }
開發者ID:redrhino,項目名稱:DotNetConnectTerminal,代碼行數:19,代碼來源:GraphicsWrapper.cs

示例6: DrawPolygon

 public void DrawPolygon(Pen pen, PointF[] inputPoints)
 {
     PointF[] points = (PointF[])inputPoints.Clone();
     lock (this)
     {
         for (int i = 0; i < points.Length; i++)
         {
             Convert(ref points[i]);
         }
         _g.DrawPolygon(pen, points);
     }
 }
開發者ID:harryho,項目名稱:demo-fx-trading-platform-prototype,代碼行數:12,代碼來源:GraphicsWrapper.cs

示例7: UpdateGraph

        private void UpdateGraph(SvgElement polyline, PointF[] newpoints)
        {
            if (polyline != null)
            {
                StringBuilder text1 = new StringBuilder();
                PointF[] tfArray1 = (PointF[])newpoints.Clone();

                for (int num10 = 0; num10 < tfArray1.Length; num10++)
                {
                    PointF tf1 = tfArray1[num10];
                    text1.Append( tf1.X.ToString() + " " + tf1.Y.ToString());
                    if (num10 < (tfArray1.Length - 1))
                    {
                        text1.Append(",");
                    }
                }
                SvgDocument document1 = this.mouseAreaControl.SVGDocument;
                bool flag1 = document1.AcceptChanges;
                document1.AcceptChanges = true;
                document1.NumberOfUndoOperations = 200;
                if (( (((polyline).InfoList.Count == 1) && (this.mouseAreaControl.SVGDocument.ControlTime == 0))) || ((polyline).ParentNode == null))
                {
                    AttributeFunc.SetAttributeValue(polyline, "points", text1.ToString());
                }

                document1.NotifyUndo();
                document1.AcceptChanges = flag1;
            }
        }
開發者ID:EdgarEDT,項目名稱:myitoppsp,代碼行數:29,代碼來源:PolyOperation.cs

示例8: WorldToView

 public void WorldToView(PointF[] worldPts, out PointF[] viewPts)
 {
     viewPts = (PointF[])worldPts.Clone();
     mViewMatrix.TransformPoints(viewPts);
 }
開發者ID:JackWangCUMT,項目名稱:mathnet-yttrium,代碼行數:5,代碼來源:ViewBase.cs

示例9: ViewToWorld

 /// <summary>
 /// Converts the given point array from View coordinates to the absolute World coordinates.
 /// </summary>
 /// <param name="viewPts">The view PTS.</param>
 /// <param name="worldPts">The world PTS.</param>
 public void ViewToWorld(PointF[] viewPts, out PointF[] worldPts)
 {
     worldPts = (PointF[])viewPts.Clone();
     //Matrix matrix = GetViewMatrix();
     //matrix.Invert();
     mInvertedViewMatrix.TransformPoints(worldPts);
 }
開發者ID:JackWangCUMT,項目名稱:mathnet-yttrium,代碼行數:12,代碼來源:ViewBase.cs

示例10: digitalizar

 ///Crea una secuencia de puntos que permita dibujar
 ///la curva de forma digital. Lo que se hace es
 ///remuestrear la señal una y otra vez, interpolando puntos
 ///hasta que se alcanza el grado de mejora;
 private PointF[] digitalizar(PointF[] curva, int numMuestras)
 {
     PointF[] curvaParaDevolver = (PointF[])curva.Clone(); ;
     if (numMuestras == curva.Length)
     {
         return curva;
     }
     //Al principio toda curva tiene cuatro puntos;
     int gradoMejora = 4;
     while (gradoMejora != numMuestras)
     {
         curvaParaDevolver = duplicarMuestras(curvaParaDevolver);
         gradoMejora *= 2;
     }
     return curvaParaDevolver;
 }
開發者ID:oogg06,項目名稱:SimAmMod,代碼行數:20,代碼來源:FormularioPrincipal.cs

示例11: ChangeSpecialLocations

        // Change the locations associated with a special.
        public static void ChangeSpecialLocations(EventDB eventDB, Id<Special> specialId, PointF[] newLocations)
        {
            Special special = eventDB.GetSpecial(specialId);

            special = (Special) special.Clone();
            special.locations = (PointF[]) newLocations.Clone();

            eventDB.ReplaceSpecial(specialId, special);
        }
開發者ID:petergolde,項目名稱:PurplePen,代碼行數:10,代碼來源:ChangeEvent.cs

示例12: Special

 public Special(SpecialKind kind, PointF[] locations)
 {
     this.kind = kind;
     this.locations = (PointF[]) locations.Clone();
     this.allCourses = true;
 }
開發者ID:petergolde,項目名稱:PurplePen,代碼行數:6,代碼來源:EventDB.cs

示例13: docToLocal

		/// <summary>
		/// Transforms the specified points from document
		/// coordinates to coordinates relative to the left-top
		/// point of the box.
		/// </summary>
		private PointF[] docToLocal(PointF[] points)
		{
			if (points == null)
				return null;

			PointF[] result = (PointF[])points.Clone();
			RectangleF nrect = Utilities.normalizeRect(this.rect);

			for (int i = 0; i < result.Length; i++)
			{
				result[i].X -= nrect.X;
				result[i].Y -= nrect.Y;
			}

			return result;
		}
開發者ID:ChrisMoreton,項目名稱:Test3,代碼行數:21,代碼來源:Box.cs

示例14: FillPolygon

 public void FillPolygon(Brush brush, PointF[] inputPoints)
 {
     PointF[] points = (PointF[])inputPoints.Clone();
     lock (this)
     {
         for (int i = 0; i < points.Length; i++)
         {
             Convert(ref points[i]);
         }
         _g.FillPolygon(brush, points);
     }
 }
開發者ID:harryho,項目名稱:demo-fx-trading-platform-prototype,代碼行數:12,代碼來源:GraphicsWrapper.cs

示例15: ConvertSweepAngle

		internal static float ConvertSweepAngle(float sweepAngle, float startAngle, SpatialTransform transform, CoordinateSystem targetSystem)
		{
			PointF x = new PointF(100, 0);

			PointF[] startVector = new PointF[] { x };
			Matrix rotation = new Matrix();
			rotation.Rotate(startAngle);
			rotation.TransformVectors(startVector);

			PointF[] sweepVector = (PointF[])startVector.Clone();
			rotation.Reset();
			rotation.Rotate(sweepAngle);
			rotation.TransformVectors(sweepVector);
			rotation.Dispose();

			SizeF startVectorTransformed, sweepVectorTransformed;
			if (targetSystem == Graphics.CoordinateSystem.Destination)
			{
				startVectorTransformed = transform.ConvertToDestination(new SizeF(startVector[0]));
				sweepVectorTransformed = transform.ConvertToDestination(new SizeF(sweepVector[0]));
			}
			else
			{
				startVectorTransformed = transform.ConvertToSource(new SizeF(startVector[0]));
				sweepVectorTransformed = transform.ConvertToSource(new SizeF(sweepVector[0]));
			}

			// simply return the angle between the start and sweep angle, in the target system.
			return (int)Math.Round(Vector.SubtendedAngle(sweepVectorTransformed.ToPointF(), PointF.Empty, startVectorTransformed.ToPointF()));
		}
開發者ID:UIKit0,項目名稱:ClearCanvas,代碼行數:30,代碼來源:ArcPrimitive.cs


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