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


C# Coordinate.Equals2D方法代碼示例

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


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

示例1: SegmentNode

 /// <summary>
 /// Initializes a new instance of the <see cref="SegmentNode"/> class.
 /// </summary>
 /// <param name="segString"></param>
 /// <param name="coord"></param>
 /// <param name="segmentIndex"></param>
 /// <param name="segmentOctant"></param>
 public SegmentNode(SegmentString segString, Coordinate coord, int segmentIndex, OctantDirection segmentOctant)
 {
     Coordinate = new Coordinate(coord);
     SegmentIndex = segmentIndex;
     _segmentOctant = segmentOctant;
     _isInterior = !coord.Equals2D(segString.GetCoordinate(segmentIndex));
 }
開發者ID:ExRam,項目名稱:DotSpatial-PCL,代碼行數:14,代碼來源:SegmentNode.cs

示例2: Equals2D_ReturnsTrueForCoordinateWithTheSameOrdinates

        public void Equals2D_ReturnsTrueForCoordinateWithTheSameOrdinates()
        {
            Coordinate target = new Coordinate(xCoordinate, yCoordinate, zCoordinate, mValue);
            Coordinate other = new Coordinate(xCoordinate, yCoordinate, zCoordinate, mValue);

            Assert.True(target.Equals2D(other));
        }
開發者ID:najira,項目名稱:spatiallite-net,代碼行數:7,代碼來源:CoordinateTests.cs

示例3: Equals2D_ReturnsFalseForCoordinateWithDifferentXYOrdinates

        public void Equals2D_ReturnsFalseForCoordinateWithDifferentXYOrdinates()
        {
            Coordinate target = new Coordinate(xCoordinate, yCoordinate, zCoordinate, mValue);
            Coordinate other = new Coordinate(xCoordinate + 1, yCoordinate + 1, zCoordinate, mValue);

            Assert.False(target.Equals2D(other));
        }
開發者ID:najira,項目名稱:spatiallite-net,代碼行數:7,代碼來源:CoordinateTests.cs

示例4: Compare

        /// <summary>
        ///  Compares two <see cref="Coordinate" />s for their relative position along a segment
        /// lying in the specified <see cref="Octant" />.
        /// </summary>
        /// <param name="octant"></param>
        /// <param name="p0"></param>
        /// <param name="p1"></param>
        /// <returns>
        /// -1 if node0 occurs first, or
        ///  0 if the two nodes are equal, or
        ///  1 if node1 occurs first.
        /// </returns>
        public static int Compare(Octants octant, Coordinate p0, Coordinate p1)
        {
            // nodes can only be equal if their coordinates are equal
            if (p0.Equals2D(p1)) 
                return 0;

            int xSign = RelativeSign(p0.X, p1.X);
            int ySign = RelativeSign(p0.Y, p1.Y);

            switch (octant)
            {
                case Octants.Zero: 
                    return CompareValue(xSign, ySign);
                case Octants.One:
                    return CompareValue(ySign, xSign);
                case Octants.Two:
                    return CompareValue(ySign, -xSign);
                case Octants.Three:
                    return CompareValue(-xSign, ySign);
                case Octants.Four:
                    return CompareValue(-xSign, -ySign);
                case Octants.Five:
                    return CompareValue(-ySign, -xSign);
                case Octants.Six:
                    return CompareValue(-ySign, xSign);
                case Octants.Seven:
                    return CompareValue(xSign, -ySign);
            }

            Assert.ShouldNeverReachHere("invalid octant value: " + octant);
            return 0;
        }
開發者ID:zhongshuiyuan,項目名稱:mapwindowsix,代碼行數:44,代碼來源:SegmentPointComparator.cs

示例5: SegmentNode

 /// <summary>
 /// Initializes a new instance of the <see cref="SegmentNode"/> class.
 /// </summary>
 /// <param name="segString"></param>
 /// <param name="coord"></param>
 /// <param name="segmentIndex"></param>
 /// <param name="segmentOctant"></param>
 public SegmentNode(SegmentString segString, Coordinate coord, int segmentIndex, Octants segmentOctant) 
 {
     this.segString = segString;
     this.Coordinate = new Coordinate(coord);
     this.SegmentIndex = segmentIndex;
     this.segmentOctant = segmentOctant;
     isInterior = !coord.Equals2D(segString.GetCoordinate(segmentIndex));
 }
開發者ID:zhongshuiyuan,項目名稱:mapwindowsix,代碼行數:15,代碼來源:SegmentNode.cs

示例6: SegmentNode

 /// <summary>
 /// Initializes a new instance of the <see cref="SegmentNode"/> class.
 /// </summary>
 /// <param name="segString"></param>
 /// <param name="coord"></param>
 /// <param name="segmentIndex"></param>
 /// <param name="segmentOctant"></param>
 public SegmentNode(INodableSegmentString segString, Coordinate coord, int segmentIndex, Octants segmentOctant) 
 {
     Coord = null;
     _segString = segString;
     Coord = new Coordinate(coord.X, coord.Y, coord.Z);
     SegmentIndex = segmentIndex;
     _segmentOctant = segmentOctant;
     _isInterior = !coord.Equals2D(segString.Coordinates[segmentIndex]);
 }
開發者ID:ste10k41,項目名稱:nettopologysuite,代碼行數:16,代碼來源:SegmentNode.cs

示例7: PreciseCoordinateTester

        private static void PreciseCoordinateTester(IPrecisionModel pm,
            double x1, double y1,
            double x2, double y2)
        {
            var p = new Coordinate(x1, y1);
            pm.MakePrecise(p);

            var pPrecise = new Coordinate(x2, y2);
            Assert.IsTrue(p.Equals2D(pPrecise), "Expected {0}, but got {1}", pPrecise, p);
        }
開發者ID:Walt-D-Cat,項目名稱:NetTopologySuite,代碼行數:10,代碼來源:PrecisionModelTest.cs

示例8: TestEquals

        public void TestEquals()
        {
            Coordinate c1 = new Coordinate(1, 2, 3);
            const string s = "Not a coordinate";
            Assert.IsFalse(c1.Equals(s));

            Coordinate c2 = new Coordinate(1, 2, 3);
            Assert.IsTrue(c1.Equals2D(c2));

            Coordinate c3 = new Coordinate(1, 22, 3);
            Assert.IsFalse(c1.Equals2D(c3));
        }
開發者ID:Walt-D-Cat,項目名稱:NetTopologySuite,代碼行數:12,代碼來源:CoordinateTest.cs

示例9: ComputeEdgeDistance

        /// <summary> 
        /// Computes the "edge distance" of an intersection point p along a segment.
        /// The edge distance is a metric of the point along the edge.
        /// The metric used is a robust and easy to compute metric function.
        /// It is not equivalent to the usual Euclidean metric.
        /// It relies on the fact that either the x or the y ordinates of the
        /// points in the edge are unique, depending on whether the edge is longer in
        /// the horizontal or vertical direction.
        /// NOTE: This function may produce incorrect distances
        /// for inputs where p is not precisely on p1-p2
        /// (E.g. p = (139,9) p1 = (139,10), p2 = (280,1) produces distanct 0.0, which is incorrect.
        /// My hypothesis is that the function is safe to use for points which are the
        /// result of rounding points which lie on the line, but not safe to use for truncated points.
        /// </summary>
        public static double ComputeEdgeDistance(Coordinate p, Coordinate p0, Coordinate p1)
        {
            var dx = Math.Abs(p1.X - p0.X);
            var dy = Math.Abs(p1.Y - p0.Y);

            var dist = -1.0;   // sentinel value
            if (p.Equals(p0)) 
                dist = 0.0;            
            else if (p.Equals(p1)) 
            {
                dist = dx > dy ? dx : dy;
            }
            else 
            {
                double pdx = Math.Abs(p.X - p0.X);
                double pdy = Math.Abs(p.Y - p0.Y);
                dist = dx > dy ? pdx : pdy;

                // <FIX>: hack to ensure that non-endpoints always have a non-zero distance
                if (dist == 0.0 && ! p.Equals2D(p0))                
                    dist = Math.Max(pdx, pdy);
                
            }
            Assert.IsTrue(!(dist == 0.0 && ! p.Equals(p0)), "Bad distance calculation");
            return dist;
        }
開發者ID:Walt-D-Cat,項目名稱:NetTopologySuite,代碼行數:40,代碼來源:LineIntersector.cs

示例10: Arc

 private Arc(Circle circle, Coordinate p1, Coordinate p2, bool isClockwise)
 {
     this.p1 = p1;
     this.p2 = p2;
     clockwise = isClockwise;
     p1Angle = circle.GetAngle(p1);
     if (p1.Equals2D(p2))
     {
         p2Angle = TWO_PI + p1Angle;
     }
     else
     {
         p2Angle = circle.GetAngle(p2);
     }
     DetermineArcAngle();
 }
開發者ID:abrobston,項目名稱:NHibernate.Spatial,代碼行數:16,代碼來源:Circle.cs

示例11: IsInteriorIntersection

 /// <summary>
 /// Tests whether either intersection point is an interior point of the specified input segment.
 /// </summary>
 /// <returns> 
 /// <c>true</c> if either intersection point is in the interior of the input segment.
 /// </returns>
 public virtual bool IsInteriorIntersection(int inputLineIndex)
 {
     Coordinate ptI;
     for (int i = 0; i < (int)_result; i++)
     {
         ptI = new Coordinate(_intPt[i]);
          if (!(ptI.Equals2D(_inputLines[inputLineIndex, 0]) || ptI.Equals2D(_inputLines[inputLineIndex, 1])))                                   
             return true;    
     }
     return false;
 }
開發者ID:zhongshuiyuan,項目名稱:mapwindowsix,代碼行數:17,代碼來源:LineIntersector.cs

示例12: CalculateDistance

        /// <summary>
        /// Calculates distance between a point and a line AB
        /// </summary>
        /// <param name="c">The coordinate to compute the distance for.</param>
        /// <param name="a">One point of the line.</param>
        /// <param name="b">Another point of the line.</param>
        /// <param name="mode">LineMode value that specifies whether AB should be treated as infinite line or as line segment.</param>
        /// <returns> The distance from C to line AB in coordinate's units.</returns>
        public double CalculateDistance(Coordinate c, Coordinate a, Coordinate b, LineMode mode)
        {
            if (a.Equals2D(b)) {
                return this.CalculateDistance(c, a);
            }

            double deltaX = b.X - a.X;
            double deltaY = b.Y - a.Y;

            if (mode == LineMode.LineSegment) {
                /*
                        Let P be the point of perpendicular projection of C on AB.  The parameter
                        r, which indicates P's position along AB, is computed by the dot product
                        of AC and AB divided by the square of the length of AB:

                                        AC dot AB
                                r = ---------
                                        ||AB||^2

                        r has the following meaning:

                                r=0      P = A
                                r=1      P = B
                                r<0      P is on the backward extension of AB
                                r>1      P is on the forward extension of AB
                                0<r<1    P is interior to AB
                */

                double r = ((c.X - a.X) * deltaX + (c.Y - a.Y) * deltaY) / (deltaX * deltaX + deltaY * deltaY);

                if (r <= 0.0) {
                    return this.CalculateDistance(c, a);
                }

                if (r >= 1.0) {
                    return this.CalculateDistance(c, b);
                }
            }

            /*
                    Use another parameter s to indicate the location along PC, with the  following meaning:
                             s<0      C is left of AB
                             s>0      C is right of AB
                             s=0      C is on AB

                    (principialy the same as r - only use perpendicular vector)

                    Compute s as follows:

                                (Ay-Cy)(Bx-Ax)-(Ax-Cx)(By-Ay)
                        s = -----------------------------
                                                        L^2
            */

            double s = ((a.Y - c.Y) * deltaX - (a.X - c.X) * deltaY) / (deltaX * deltaX + deltaY * deltaY);

            /*
                    Then the distance from C to P = |s|*L.
            */

            return Math.Abs(s) * Math.Sqrt(deltaX * deltaX + deltaY * deltaY);
        }
開發者ID:najira,項目名稱:spatiallite-net,代碼行數:70,代碼來源:Euclidean2DCalculator.cs

示例13: SafeOctant

 private static Octants SafeOctant(Coordinate p0, Coordinate p1)
 {
     if (p0.Equals2D(p1)) return Octants.Zero;
       	        return Octant.GetOctant(p0, p1);
 }
開發者ID:Walt-D-Cat,項目名稱:NetTopologySuite,代碼行數:5,代碼來源:SegmentString.cs

示例14: AddIntersection

        /// <summary>
        /// 
        /// </summary>
        /// <param name="intPt"></param>
        /// <param name="segmentIndex"></param>
        public void AddIntersection(Coordinate intPt, int segmentIndex)
        {
            var normalizedSegmentIndex = segmentIndex;
            // normalize the intersection point location
            var nextSegIndex = normalizedSegmentIndex + 1;
            if(nextSegIndex < _pts.Length)
            {
                var nextPt = _pts[nextSegIndex];

                // Normalize segment index if intPt falls on vertex
                // The check for point equality is 2D only - Z values are ignored
                if (intPt.Equals2D(nextPt))
                    normalizedSegmentIndex = nextSegIndex;
            }

            // Add the intersection point to edge intersection list.
            /*var ei = */_nodeList.Add(intPt, normalizedSegmentIndex);
        }
開發者ID:Walt-D-Cat,項目名稱:NetTopologySuite,代碼行數:23,代碼來源:SegmentString.cs

示例15: IsSnapped

 private static bool IsSnapped(Coordinate v, Coordinate p0, Coordinate p1)
 {
     if (v.Equals2D(p0)) return true;
     if (v.Equals2D(p1)) return true;
     var seg = new LineSegment(p0, p1);
     var dist = seg.Distance(v);
     if (dist < SnapTolerance / 2.05) return false;
     return true;
 }
開發者ID:Walt-D-Cat,項目名稱:NetTopologySuite,代碼行數:9,代碼來源:SnapRoundingTest.cs


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