当前位置: 首页>>代码示例>>C#>>正文


C# Stroke.GetPoint方法代码示例

本文整理汇总了C#中Stroke.GetPoint方法的典型用法代码示例。如果您正苦于以下问题:C# Stroke.GetPoint方法的具体用法?C# Stroke.GetPoint怎么用?C# Stroke.GetPoint使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Stroke的用法示例。


在下文中一共展示了Stroke.GetPoint方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: TryTapToSelect

    private void TryTapToSelect(Stroke stroke)
    {
        // We interpret strokes with fewer than 25 packets,
        // starting and ending on the same body, as tap gestures.
        int np = stroke.PacketCount;
        Point head = stroke.GetPoint(0), tail = stroke.GetPoint(np-1);
        RigidBodyBase[] headhits = doc.HitTestBodies(head);
        RigidBodyBase[] tailhits = doc.HitTestBodies(tail);

        if (np <= 25 &&
            headhits.Length > 0 &&
            tailhits.Length > 0 &&
            Object.ReferenceEquals(headhits[0],tailhits[0]))
        {
            tappedbody = headhits[0];

            // Ensure we didn't just tap what's already selected.
            ArrayList selbodies = new ArrayList(
                doc.GetBodiesFor(inkoverlay.Selection));
            if (selbodies.Contains(tappedbody))
                return;

            // We must delay the call to set_Selection, until after InkOverlay is
            // finished looking at this stroke.  BeginInvoke seems to work nicely
            // for this purpose.
            dbg.WriteLine("-------TTS--------");
            base.BeginInvoke(new MethodInvoker(DelayTapToSelect));
        }
    }
开发者ID:pichiliani,项目名称:CoPhysicsSimulator,代码行数:29,代码来源:MainForm.cs

示例2: MakeRodRopeOrSpring

    private MechanismBase MakeRodRopeOrSpring(Stroke stroke, RigidBodyBase headbody, RigidBodyBase tailbody)
    {
        // Rod, Rope, or Spring: we decide based on straightness, curvyness, and loopiness.
        int np = stroke.PacketCount;
        Point head = stroke.GetPoint(0), tail = stroke.GetPoint(np-1);
        double distance = Geometry.DistanceBetween(head,tail);

        StrokeGeometry sg = new StrokeGeometry(stroke);
        double length = sg.IntegrateLength();

        // Consider spring: analyze total net curvature of the stroke, and call it a
        // spring if it makes at least 540 degrees (1.5 loops) in the same direction.
        double tt = StrokeAnalyzer.AnalyzeTotalCurvature(stroke,100.0);
        if (Math.Abs(Geometry.Rad2Deg(tt)) > 540.0)
        {
            dbg.WriteLine("new SpringMech");

            SpringMech newmech = new SpringMech();
            newmech.EndpointA = BodyRef.For(headbody,head);
            newmech.EndpointB = BodyRef.For(tailbody,tail);
            newmech.extension = distance;
            newmech.stiffness = MathEx.Square(tt)/100; //Heuristic: th²/100 feels about right.

            newmech.strokeid = stroke.Id;
            doc.Mechanisms.Add(newmech);
            return newmech;
        }

        // Straight and narrow?
        double rodropethreshold = 1.1; //heuristic
        if (length/distance < rodropethreshold)
        {
            dbg.WriteLine("new RodMech");

            RodMech newmech = new RodMech();
            newmech.EndpointA = BodyRef.For(headbody,head);
            newmech.EndpointB = BodyRef.For(tailbody,tail);
            newmech.length = distance;

            newmech.strokeid = stroke.Id;
            doc.Mechanisms.Add(newmech);
            return newmech;
        }
        else
        {
            dbg.WriteLine("new RopeMech");

            RopeMech newmech = new RopeMech();
            newmech.EndpointA = BodyRef.For(headbody,head);
            newmech.EndpointB = BodyRef.For(tailbody,tail);
            newmech.length = length;

            newmech.strokeid = stroke.Id;
            doc.Mechanisms.Add(newmech);
            return newmech;
        }
    }
开发者ID:pichiliani,项目名称:CoPhysicsSimulator,代码行数:57,代码来源:MainForm.cs

示例3: TappedNode

 /* Determines whether the given stroke was a tap
  * on a node in Graph g and if so, returns that node
  */
 public static Node TappedNode(Stroke s, Graph g)
 {
     if(s.PacketCount > 25) return null;
     Point[] points = {s.GetPoint(0),s.GetPoint(s.PacketCount-1)};
     foreach(Node n in g.Nodes)
     {
         Rectangle r = n.Stroke.GetBoundingBox();
         if(r.Contains(points[0]) && r.Contains(points[1]))
             return n;
     }
     return null;
 }
开发者ID:mdayaram,项目名称:graph-animator,代码行数:15,代码来源:StrokeManager.cs

示例4: AnalyzeClosedness

    // out double tAB, out double tPQ)
    public static void AnalyzeClosedness(Stroke stroke, double tolerance, 
		out bool closed, out Point[] vertices)
    {
        closed = false;
        vertices = null;

        // Formulate closure gap-tolerance, based on stroke length (but clipped to <= 500isu).
        double len = StrokeGeometry.IntegrateLength(stroke);

        double segtol = Math.Max(50,Math.Min(tolerance,len/20.0));
        double gaptol = Math.Max(150,Math.Min(tolerance,len/7.0));

        dbg.WriteLine(String.Format("length: {0}",len));
        dbg.WriteLine(String.Format("segtol: {0}",segtol));
        dbg.WriteLine(String.Format("gaptol: {0}",gaptol));

        // Break the stroke down into indices.
        int[] indices;
        vertices = SegmentizeStroke(stroke,segtol, out indices);
        int nv = vertices.Length;

        // Do the head/tail segments intersect?  Are they close?
        if (nv >= 4)
        {
            Point headA = (Point)vertices[0];
            Point headB = (Point)vertices[1];
            Point tailP = (Point)vertices[nv-2];
            Point tailQ = (Point)vertices[nv-1];

            double tAB, tPQ;
            SegmentCollision.HitTest(headA,headB,tailP,tailQ, out tAB, out tPQ);

            Point virtualIntersectH = Geometry.Interpolate(headA,headB,tAB);
            Point virtualIntersectT = Geometry.Interpolate(tailP,tailQ,tPQ);
            Point virtualIntersect = Geometry.Interpolate(virtualIntersectH,virtualIntersectT,0.5);

            double dh2i = Geometry.DistanceBetween(headA,virtualIntersect);
            double dt2i = Geometry.DistanceBetween(tailQ,virtualIntersect);

        #if DEBUG
            dbg.WriteLine(String.Format("numV: {0}",nv));
            dbg.WriteLine(String.Format("tAB: {0}",tAB));
            dbg.WriteLine(String.Format("tPQ: {0}",tPQ));

            dbg.WriteLine(String.Format("isct: {0}",virtualIntersect));

            dbg.WriteLine(String.Format("dh2i: {0}",dh2i));
            dbg.WriteLine(String.Format("dt2i: {0}",dt2i));
        #endif

            if (dh2i < gaptol && dt2i < gaptol)
            {
                closed = true;
                // Adjust the head point to the actual intersection.
                vertices[0] = virtualIntersect;
                dbg.WriteLine("Closed! Why? dh/t2i < gaptol");
            }
            else if ((-0.3 < tAB && tAB < 0.3) && (0.7 < tPQ && tPQ < 1.3))
            {
                closed = true;
                // Adjust the head point to the actual intersection.
                vertices[0] = virtualIntersect;
                dbg.WriteLine("Closed! Why? |t*| < 0.3");
            }
            else
            {
                // Last chance: measure nearest distance from head to tail segment.
                int closeI = StrokeGeometry.FindClosestPointTo(
                    stroke, headA, indices[nv-2], indices[nv-1]);
                Point close = stroke.GetPoint(closeI);
                double d = Geometry.DistanceBetween(headA,close);
                if (d < gaptol)
                {
                    closed = true; // Keep the head point; discard the tail point below.
                    dbg.WriteLine("Closed! Why? Last chance head/tail distance < gaptol");
                }
            }

            // Remove the last point as redundant if it's closed.
            if (closed)
            {
                Point[] verticesX = new Point[nv-1];
                Array.Copy(vertices,verticesX,nv-1);
                vertices = verticesX;
            }
        }
    }
开发者ID:pichiliani,项目名称:CoPhysicsSimulator,代码行数:88,代码来源:StrokeAnalyzer.cs

示例5: isClosed

 /* Returns true if the stroke is somewhat closed in the
  * sense that it comes back to itself.  Accomplishes
  * this by checking the distance between the first point
  * in the stroke and the last point in the stroke.
  */
 public static bool isClosed(Stroke s, double tolerance)
 {
     if(s == null)
         return false;
     Point[] pts = {s.GetPoint(0), s.GetPoint(s.PacketCount-1)};
     return StrokeManager.Distance(pts[0], pts[1]) <= tolerance;
 }
开发者ID:mdayaram,项目名称:graph-animator,代码行数:12,代码来源:StrokeManager.cs


注:本文中的Stroke.GetPoint方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。