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


C# PathGeometry.GetPointAtFractionLength方法代码示例

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


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

示例1: ComparePoints

 public static Point[] ComparePoints(PathGeometry user, PathGeometry target, double progress)
 {
     Point pU, pT1, pT2, tU, tT1, tT2;
     user.GetPointAtFractionLength(progress, out pU, out tU);
     target.GetPointAtFractionLength(progress, out pT1, out tT1);
     target.GetPointAtFractionLength(1-progress, out pT2, out tT2);
     return new[] {pU, pT1, pT2};
 }
开发者ID:yong-ja,项目名称:starodyssey,代码行数:8,代码来源:Bezier.cs

示例2: ArrangeOverride

        //Size newArrangeOverride(Size finalSize)
        protected override Size ArrangeOverride(Size finalSize)
        {
            var bezier = new QuadraticBezierSegment(InnerPoint, new Point(finalSize.Width, finalSize.Height), true);
            var pathFigure = new PathFigure(new Point(10, 10), new[] { bezier }, false);

            var pathLength = TextOnPathBase.GetPathFigureLength(pathFigure);
            var neededSpace = 0.0; // finalSize.Width;


            foreach (UIElement child in Children)
            {
                //child.Measure(new Size(Double.PositiveInfinity,
                //                       Double.PositiveInfinity));
                neededSpace += child.DesiredSize.Width;
            }

            if (!pathLength.Equals(0.0) && !neededSpace.Equals(0.0) && !finalSize.Width.Equals(0.0))
            {
                var spaceAvail = pathLength - neededSpace;
                var spaceStep = spaceAvail / Children.Count;
                var stepPerc = spaceStep / spaceAvail;

                var scalingFactor = pathLength / neededSpace;
                var pathGeometry = new PathGeometry(new[] {pathFigure});
                var baseline = scalingFactor;

                var progress = 0.0; // stepPerc / 2;

                foreach (UIElement element in Children)
                {
                    var width = /*scalingFactor**/element.DesiredSize.Width;
                    progress += stepPerc / 2;

                    Point point, tangent;
                    pathGeometry.GetPointAtFractionLength(progress,
                                                          out point, out tangent);

                    var transformGroup = new TransformGroup();

                    //transformGroup.Children.Add(
                    //    new ScaleTransform(scalingFactor, scalingFactor));
                    transformGroup.Children.Add(
                        new RotateTransform(Math.Atan2(tangent.Y, tangent.X)
                                                *180/Math.PI, width/2, baseline));
                    //transformGroup.Children.Add(
                    //    new TranslateTransform(point.X - width / 2,
                    //                           point.Y - baseline));

                    element.RenderTransform = transformGroup;

                    element.Arrange(new Rect(point.X, point.Y, element.DesiredSize.Width, element.DesiredSize.Height));

                    progress += stepPerc / 2;
                }
            }
            return base.ArrangeOverride(finalSize);
        }
开发者ID:Slesa,项目名称:Playground,代码行数:58,代码来源:BezierPanel.cs

示例3: GetPosition

 private Point GetPosition(double value, EllipseGeometry geometry)
 {
     var pathGeometry = geometry.GetOutlinedPathGeometry();
     if (pathGeometry.Figures.Count == 0)
         return geometry.Center;
     var outherGeometry = new PathGeometry(new[] { pathGeometry.Figures[0] });
     Point outherPoint, outherTangent;
     outherGeometry.GetPointAtFractionLength(value, out outherPoint, out outherTangent);
     return outherPoint;
 }
开发者ID:bisato,项目名称:DW.WPFToolkit,代码行数:10,代码来源:EllipsedProgressBar.cs

示例4: ConstructArcSegment

        // Create an ESRI polyline based on a densified representation of WPFs ArcSegment
        public static ESRI.ArcGIS.Client.Geometry.Polyline ConstructArcSegment(ESRI.ArcGIS.Client.Geometry.MapPoint startPoint, ESRI.ArcGIS.Client.Geometry.MapPoint endPoint, double radius, bool isMinor, SweepDirection direction)
        {
            if (endPoint == null)
            return null;

              // WPF ArcSegment has issue with high coordinates values.
              // Bring coordinates down to 0,0 and translate back to real world later.

              double startX = startPoint.X;
              double startY = startPoint.Y;

              double absRadius = Math.Abs(radius);

              // We need to switch the curve direction, b/c we are starting with the end point
              if (radius > 0)
            direction = direction == SweepDirection.Clockwise ? SweepDirection.Counterclockwise : SweepDirection.Clockwise;

              Size radiusAspect = new Size(absRadius, absRadius);
              Point myEndPoint = new Point(endPoint.X - startX, endPoint.Y - startY);

              bool isLargeArc = !isMinor;
              ArcSegment wpfArcSegment = new ArcSegment(myEndPoint, radiusAspect, 0, isLargeArc, direction, false);

              // compose one or more segments into a collection
              var pathcoll = new PathSegmentCollection();
              pathcoll.Add(wpfArcSegment);

              // create a figure based on the set of segments
              var pathFigure = new PathFigure();
              pathFigure.Segments = pathcoll;
              pathFigure.IsClosed = false;

              // compose a collection of figures
              var figureCollection = new PathFigureCollection();
              figureCollection.Add(pathFigure);

              // create a path-geometry using the figures collection
              var geometryPath = new PathGeometry(figureCollection);

              ESRI.ArcGIS.Client.Geometry.PointCollection pointCollection = new ESRI.ArcGIS.Client.Geometry.PointCollection();

              double numSegments = 1.0 / 50;        // Default 50
              Point point, tangent;

              Point pointA, pointB;
              geometryPath.GetPointAtFractionLength(0, out pointA, out tangent);
              geometryPath.GetPointAtFractionLength(numSegments, out pointB, out tangent);
              double partDistance = LineLength(pointA.X, pointA.Y, pointB.X, pointB.Y);
              if (partDistance > 1.0)
            numSegments /= partDistance;
              if (1 / numSegments > 160)            // cap it at 160 vertexes
            numSegments = 1.0 / 160;            // Server is having issue with 185+ vertexes (180 seems ok)

              for (double fraction = 0.0; fraction < 1.0; fraction += numSegments)
              {
            geometryPath.GetPointAtFractionLength(fraction, out point, out tangent);
            pointCollection.Add(new ESRI.ArcGIS.Client.Geometry.MapPoint(point.X + startX, point.Y + startY));
              }
              pointCollection.Add(endPoint);  // faction 1 can be skipped, so add it here.

              ESRI.ArcGIS.Client.Geometry.Polyline polyline = new ESRI.ArcGIS.Client.Geometry.Polyline();
              polyline.Paths.Add(pointCollection);

              return polyline;
        }
开发者ID:Esri,项目名称:deed-drafter,代码行数:66,代码来源:Utilities.cs

示例5: ArrangeOverride

        /// <summary>
        /// Positionates each child in an arc line form depending on the Bend and amount of child controls.
        /// </summary>
        /// <param name="finalSize">The maximum possible space given by the parent control.</param>
        /// <returns>The calculated needed space in sum of all available child controls.</returns>
        protected override Size ArrangeOverride(Size finalSize)
        {
            if (InternalChildren.Count <= 0 || !(finalSize.Width > 0))
                return base.ArrangeOverride(finalSize);

            ResetArc(finalSize);

            var pathLength = PathCalculator.GetPathFigureLength(_figure);
            var pathGeometry = new PathGeometry(new PathFigure[] { _figure });
            var distance = (double)1 / (double)(InternalChildren.Count + 1);
            var position = distance;
            foreach (UIElement child in InternalChildren)
            {
                Point point, tangent;
                pathGeometry.GetPointAtFractionLength(position, out point, out tangent);

                Size childSize = child.DesiredSize;
                point.X -= childSize.Width / 2;
                point.Y -= childSize.Height;
                child.Arrange(new Rect(point, childSize));

                if (RotateElements)
                {
                    var elementCenter = new Size(childSize.Width / 2, childSize.Height / 2);
                    var transforms = new TransformGroup();
                    transforms.Children.Add(new RotateTransform((Math.Atan2(tangent.Y, tangent.X)
                                                                 * 180
                                                                 / Math.PI),
                        elementCenter.Width,
                        elementCenter.Height));
                    child.RenderTransform = transforms;
                }
                else
                    child.RenderTransform = null;
                    
                position += distance;
            }
            return base.ArrangeOverride(finalSize);
        }
开发者ID:bisato,项目名称:DW.WPFToolkit,代码行数:44,代码来源:ArcPanel.cs

示例6: OriginalArrangeOverride

        //protected override Size ArrangeOverride(Size finalSize)
        Size OriginalArrangeOverride(Size finalSize)
        {
            var pathLength = TextOnPathBase.GetPathFigureLength(PathFigure);
            var textLength = 0.0; // finalSize.Width;


            foreach (UIElement child in Children)
            {
                //child.Measure(new Size(Double.PositiveInfinity,
                //                       Double.PositiveInfinity));
                textLength += child.DesiredSize.Width;
            }

            if (!pathLength.Equals(0.0) && !textLength.Equals(0.0) && !finalSize.Width.Equals(0.0))
            {
                var scalingFactor = pathLength/textLength;
                var pathGeometry = new PathGeometry(new PathFigure[] {PathFigure});
                var baseline = scalingFactor;
                var progress = 0.0;

                foreach (UIElement element in Children)
                {
                    var width = scalingFactor*element.DesiredSize.Width;
                    progress += width/2/pathLength;
                    Point point, tangent;

                    pathGeometry.GetPointAtFractionLength(progress,
                                                          out point, out tangent);

                    var transformGroup = new TransformGroup();

                    //transformGroup.Children.Add(
                    //    new ScaleTransform(scalingFactor, scalingFactor));
                    transformGroup.Children.Add(
                        new RotateTransform(Math.Atan2(tangent.Y, tangent.X)
                                                *180/Math.PI, width/2, baseline));
                    //transformGroup.Children.Add(
                    //    new TranslateTransform(point.X - width / 2,
                    //                           point.Y - baseline));

                    element.RenderTransform = transformGroup;

                    element.Arrange(new Rect(point.X, point.Y, element.DesiredSize.Width, element.DesiredSize.Height));

                    progress += width/2/pathLength;
                }
            }
            return base.ArrangeOverride(finalSize);
        }
开发者ID:Slesa,项目名称:Playground,代码行数:50,代码来源:BezierPanel.cs

示例7: OrientTextOnPath

        void OrientTextOnPath()
        {
            var pathLength = TextOnPathBase.GetPathFigureLength(PathFigure);
            var textLength = 0.0;

            foreach (UIElement child in _mainPanel.Children)
            {
                child.Measure(new Size(Double.PositiveInfinity,
                                       Double.PositiveInfinity));
                textLength += child.DesiredSize.Width;
            }

            if (pathLength == 0 || textLength == 0)
                return;

            var scalingFactor = pathLength / textLength;
            var pathGeometry = new PathGeometry(new PathFigure[] { PathFigure });
            var baseline = scalingFactor * Fontsize * FontFamily.Baseline;
            var progress = 0.0;

            foreach (UIElement child in _mainPanel.Children)
            {
                var width = scalingFactor * child.DesiredSize.Width;
                progress += width / 2 / pathLength;
                Point point, tangent;

                pathGeometry.GetPointAtFractionLength(progress,
                                                out point, out tangent);

                var transformGroup = new TransformGroup();

                transformGroup.Children.Add(
                    new ScaleTransform(scalingFactor, scalingFactor));
                transformGroup.Children.Add(
                    new RotateTransform(Math.Atan2(tangent.Y, tangent.X)
                        * 180 / Math.PI, width / 2, baseline));
                transformGroup.Children.Add(
                    new TranslateTransform(point.X - width / 2,
                                           point.Y - baseline));

                child.RenderTransform = transformGroup;
                progress += width / 2 / pathLength;
            }
        }
开发者ID:Slesa,项目名称:Playground,代码行数:44,代码来源:TextOnPathControl.cs

示例8: ArrangeOverride

        /// <summary>
        /// Positionates each child in an ellipse form depending on the amount of child controls.
        /// </summary>
        /// <param name="finalSize">The maximum possible space given by the parent control.</param>
        /// <returns>The calculated needed space in sum of all available child controls.</returns>
        protected override Size ArrangeOverride(Size finalSize)
        {
            if (finalSize.Height <= 0 ||
                finalSize.Width <= 0)
                return finalSize;

            if (InternalChildren.Count <= 0)
                return base.ArrangeOverride(finalSize);

            ResetEllipse(finalSize);

            var figure = _ellipse.GetOutlinedPathGeometry().Figures[0];
            var pathGeometry = new PathGeometry(new[] { figure });

            var points = new List<Point>();
            var tangents = new List<Point>();
            var distance = (double)1 / (double)InternalChildren.Count;
            var position = GetElementStartPositionValue();
            foreach (var child in InternalChildren)
            {
                Point point, tangent;
                pathGeometry.GetPointAtFractionLength(position, out point, out tangent);
                points.Add(point);
                tangents.Add(tangent);
                position += distance;
                if (position > 1)
                    position -= 1;
            }

            if (EllipseRotateDirection == SweepDirection.Counterclockwise)
            {
                points.Reverse();
                tangents.Reverse();
                var point = points.Last();
                points.Remove(point);
                points.Insert(0, point);

                var tangent = tangents.Last();
                tangents.Remove(tangent);
                tangents.Insert(0, tangent);
            }

            int pos = 0;
            foreach (UIElement child in InternalChildren)
            {
                var childSize = child.DesiredSize;
                var elementPos = points[pos];
                elementPos.X -= childSize.Width / 2;
                elementPos.Y -= childSize.Height / 2;
                child.SnapsToDevicePixels = true;
                child.Arrange(new Rect(elementPos, childSize));
                if (RotateElements)
                {
                    var elementCenter = new Size(childSize.Width / 2, childSize.Height / 2);
                    var transforms = new TransformGroup();

                    var centerPoint = new Point(finalSize.Width / 2, finalSize.Height / 2);
                    var angle = CalculatePileToPlayerAngle(elementPos, centerPoint);
                    transforms.Children.Add(new RotateTransform(angle, elementCenter.Width, elementCenter.Height));

                    //transforms.Children.Add(new RotateTransform((Math.Atan2(tangents[pos].Y, tangents[pos].X)
                    //                                                * 180
                    //                                                / Math.PI)
                    //                                                + GetElementsRotateDirectionValue(),
                    //                                            elementCenter.Width,
                    //                                            elementCenter.Height));
                    child.RenderTransform = transforms;
                }
                else
                    child.RenderTransform = null;
                ++pos;
            }
            return base.ArrangeOverride(finalSize);
        }
开发者ID:bisato,项目名称:DW.WPFToolkit,代码行数:79,代码来源:EllipsePanel.cs

示例9: DrawStartAlignedTextPath

        private void DrawStartAlignedTextPath(DrawingContext dc, PathGeometry pathGeometry,
            ISvgAnimatedLength startOffset, TextAlignment alignment)
        {
            if (pathGeometry == null || pathGeometry.Figures == null ||
                pathGeometry.Figures.Count != 1)
            {
                return;
            }

            _pathLength = GetPathFigureLength(pathGeometry.Figures[0]);
            if (_pathLength == 0 || _textLength == 0)
                return;

            //double scalingFactor = pathLength / textLength;
            double scalingFactor   = 1.0; // Not scaling the text to fit...
            double progress = 0;
            if (startOffset != null)
            {
                ISvgLength offsetLength = startOffset.AnimVal;
                if (offsetLength != null)
                {
                    switch (offsetLength.UnitType)
                    {
                        case SvgLengthType.Percentage:
                            if ((float)offsetLength.ValueInSpecifiedUnits != 0)
                            {
                                progress += offsetLength.ValueInSpecifiedUnits / 100d;
                            }
                            break;
                    }
                }
            }
            //PathGeometry pathGeometry =
            //    new PathGeometry(new PathFigure[] { PathFigure });

            Point ptOld = new Point(0, 0);

            for (int i = 0; i < _formattedChars.Count; i++)
            {
                FormattedText formText = _formattedChars[i];

                double width = scalingFactor *
                            formText.WidthIncludingTrailingWhitespace;
                double baseline = scalingFactor * formText.Baseline;
                progress += width / 2 / _pathLength;
                Point point, tangent;

                pathGeometry.GetPointAtFractionLength(progress,
                                                out point, out tangent);

                if (i != 0)
                {
                    if (point == ptOld)
                    {
                        break;
                    }
                }

                dc.PushTransform(
                    new TranslateTransform(point.X - width / 2,
                                           point.Y - baseline));
                dc.PushTransform(
                    new RotateTransform(Math.Atan2(tangent.Y, tangent.X)
                            * 180 / Math.PI, width / 2, baseline));
                //dc.PushTransform(
                //    new ScaleTransform(scalingFactor, scalingFactor));

                dc.DrawText(formText, _formattedOrigins[i]);
                dc.Pop();
                dc.Pop();
                //dc.Pop();

                progress += width / 2 / _pathLength;

                ptOld = point;
            }
        }
开发者ID:jogibear9988,项目名称:SharpVectors,代码行数:77,代码来源:WpfTextOnPathDrawing.cs

示例10: DrawEndAlignedTextPath

        private void DrawEndAlignedTextPath(DrawingContext dc, PathGeometry pathGeometry,
            ISvgAnimatedLength startOffset)
        {
            if (pathGeometry == null || pathGeometry.Figures == null ||
                pathGeometry.Figures.Count != 1)
            {
                return;
            }

            _pathLength = GetPathFigureLength(pathGeometry.Figures[0]);
            if (_pathLength == 0 || _textLength == 0)
                return;

            //double scalingFactor = pathLength / textLength;
            double scalingFactor   = 1.0; // Not scaling the text to fit...
            double progress = 1.0;
            //PathGeometry pathGeometry =
            //    new PathGeometry(new PathFigure[] { PathFigure });

            Point ptOld = new Point(0, 0);

            int itemCount = _formattedChars.Count - 1;

            for (int i = itemCount; i >= 0; i--)
            {
                FormattedText formText = _formattedChars[i];

                double width = scalingFactor *
                            formText.WidthIncludingTrailingWhitespace;
                double baseline = scalingFactor * formText.Baseline;
                progress -= width / 2 / _pathLength;
                Point point, tangent;

                pathGeometry.GetPointAtFractionLength(progress,
                                                out point, out tangent);

                if (i != itemCount)
                {
                    if (point == ptOld)
                    {
                        break;
                    }
                }

                dc.PushTransform(
                    new TranslateTransform(point.X - width / 2,
                                           point.Y - baseline));
                dc.PushTransform(
                    new RotateTransform(Math.Atan2(tangent.Y, tangent.X)
                            * 180 / Math.PI, width / 2, baseline));
                //dc.PushTransform(
                //    new ScaleTransform(scalingFactor, scalingFactor));

                dc.DrawText(formText, _formattedOrigins[i]);
                dc.Pop();
                dc.Pop();
                //dc.Pop();

                progress -= width / 2 / _pathLength;

                ptOld = point;
            }
        }
开发者ID:jogibear9988,项目名称:SharpVectors,代码行数:63,代码来源:WpfTextOnPathDrawing.cs

示例11: OrientTextOnPath

		private void OrientTextOnPath()
		{
			double pathFigureLength = TextOnPathBase.GetPathFigureLength(this.PathFigure);
			double num = 0.0;
			foreach (UIElement uIElement in this.mainPanel.Children)
			{
				uIElement.Measure(new Size(double.PositiveInfinity, double.PositiveInfinity));
				num += uIElement.DesiredSize.Width;
			}
			if (pathFigureLength != 0.0 && num != 0.0)
			{
				double num2 = pathFigureLength / num;
				PathGeometry pathGeometry = new PathGeometry(new PathFigure[]
				{
					this.PathFigure
				});
				double num3 = num2 * 100.0 * base.FontFamily.Baseline;
				double num4 = 0.0;
				foreach (UIElement uIElement in this.mainPanel.Children)
				{
					double num5 = num2 * uIElement.DesiredSize.Width;
					num4 += num5 / 2.0 / pathFigureLength;
					Point point;
					Point point2;
					pathGeometry.GetPointAtFractionLength(num4, out point, out point2);
					uIElement.RenderTransform = new TransformGroup
					{
						Children = 
						{
							new ScaleTransform(num2, num2),
							new RotateTransform(Math.Atan2(point2.Y, point2.X) * 180.0 / 3.1415926535897931, num5 / 2.0, num3),
							new TranslateTransform(point.X - num5 / 2.0, point.Y - num3)
						}
					};
					num4 += num5 / 2.0 / pathFigureLength;
				}
			}
		}
开发者ID:akordowski,项目名称:Source-Code-Atomiq,代码行数:38,代码来源:TextOnPathControl.cs

示例12: TransformVisualChildren

        protected virtual void TransformVisualChildren()
            {
            this.measureRect = new Rect();
            this.ContentRect = RectangleD.Empty;

            if (this.pathLength == 0 || this.textLength == 0 || this.textHeight == 0)
                return;

            if (this.formattedChars.Count != this.visualChildren.Count)
                return;

            double scalingFactor;
            double fontSize = this.FontSize;
            if (fontSize.IsFinite() && fontSize > 0)
                {
                // Scale to particular height, but not longer than the path
                scalingFactor = Math.Min(fontSize / this.textHeight, this.pathLength / this.textLength);
                }
            else
                {
                // Scale to the length of the path
                scalingFactor = this.pathLength / this.textLength;
                }

            PathGeometry pathGeometry = new PathGeometry(new PathFigure[] { PathFigure });
            
            // If we're not scaled to the full path length, then center in what we do use
            double progressFraction = ((this.pathLength - this.textLength * scalingFactor) / 2) / this.pathLength;

            for (int index = 0; index < visualChildren.Count; index++)
                {
                FormattedText formText  = this.formattedChars[index];
                double        width     = scalingFactor * formText.WidthIncludingTrailingWhitespace;
                double        height    = scalingFactor * (formText.Height);
                double        baseline  = scalingFactor * formText.Baseline;

                progressFraction += width / 2 / this.pathLength;

                Point point, tangent;
                pathGeometry.GetPointAtFractionLength(progressFraction, out point, out tangent);

                DrawingVisual       drawingVisual      = this.visualChildren[index] as DrawingVisual;
                TransformGroup      transformGroup     = drawingVisual.Transform    as TransformGroup;
                ScaleTransform      scaleTransform     = transformGroup.Children[0] as ScaleTransform;
                RotateTransform     rotateTransform    = transformGroup.Children[1] as RotateTransform;
                TranslateTransform  translateTransform = transformGroup.Children[2] as TranslateTransform;

                scaleTransform.ScaleX   = scalingFactor;
                scaleTransform.ScaleY   = scalingFactor;
                rotateTransform.Angle   = Math.Atan2(tangent.Y, tangent.X) * 180 / Math.PI;
                rotateTransform.CenterX = width / 2;
                rotateTransform.CenterY = baseline;
                translateTransform.X    = point.X - width / 2;
                translateTransform.Y    = this.FontVerticallyCentered ? (point.Y - height / 2 - this.FontBaseline) : (point.Y - baseline - this.FontBaseline);

                Rect rc = drawingVisual.ContentBounds;
                rc.Transform(transformGroup.Value);

                this.ContentRect = this.ContentRect.UnionD(new RectangleD(rc));
                this.measureRect.Union(rc);

                progressFraction += width / 2 / pathLength;
                }

            InvalidateMeasure();
            }
开发者ID:rgatkinson,项目名称:nadir,代码行数:66,代码来源:TextOnPath.cs

示例13: WarpAllPoints

        void WarpAllPoints(PathGeometry warpedTextPathGeometry, PathGeometry flattenedTextPathGeometry)
        {
            PathGeometry pathGeometry = new PathGeometry(new PathFigure[] { PathFigure });
            double scalingFactor = pathLength / textLength;

            LoopThroughAllFlattenedPathPoints(warpedTextPathGeometry, flattenedTextPathGeometry, delegate(Point pointSrc)
            {
                double fractionLength = Math.Max(0, Math.Min(1, pointSrc.X / textLength));
                double offsetFromBaseline = scalingFactor * (baseline - pointSrc.Y);
                Point pathPoint, pathTangent;

                pathGeometry.GetPointAtFractionLength(fractionLength, out pathPoint, out pathTangent);
                double angle = Math.Atan2(pathTangent.Y, pathTangent.X);

                Point pointDst = new Point();
                pointDst.X = pathPoint.X + offsetFromBaseline * Math.Sin(angle);
                pointDst.Y = pathPoint.Y - offsetFromBaseline * Math.Cos(angle);

                return pointDst;
            });

            if (ShiftToOrigin)
            {
                Rect boundsRect = warpedTextPathGeometry.Bounds;

                LoopThroughAllFlattenedPathPoints(warpedTextPathGeometry, warpedTextPathGeometry, delegate(Point pointSrc)
                {
                    Point pointDst = new Point();
                    pointDst.X = pointSrc.X - boundsRect.Left;
                    pointDst.Y = pointSrc.Y - boundsRect.Top;
                    return pointDst;
                });
            }
        }
开发者ID:CodeByBerglund,项目名称:nai-framework,代码行数:34,代码来源:TextOnPathWarped.cs

示例14: TransformVisualChildren

        protected virtual void TransformVisualChildren()
        {
            boundingRect = new Rect();

            if (pathLength == 0 || textLength == 0)
                return;

            if (formattedChars.Count != visualChildren.Count)
                return;

            double scalingFactor = pathLength / textLength;
            PathGeometry pathGeometry =
                new PathGeometry(new PathFigure[] { PathFigure });
            double progress = 0;
            boundingRect = new Rect();

            for (int index = 0; index < visualChildren.Count; index++)
            {
                FormattedText formText = formattedChars[index];
                double width = scalingFactor *
                            formText.WidthIncludingTrailingWhitespace;
                double baseline = scalingFactor * formText.Baseline;
                progress += width / 2 / pathLength;
                Point point, tangent;
                pathGeometry.GetPointAtFractionLength(progress,
                                            out point, out tangent);

                DrawingVisual drawingVisual =
                    visualChildren[index] as DrawingVisual;
                TransformGroup transformGroup =
                    drawingVisual.Transform as TransformGroup;
                ScaleTransform scaleTransform =
                    transformGroup.Children[0] as ScaleTransform;
                RotateTransform rotateTransform =
                    transformGroup.Children[1] as RotateTransform;
                TranslateTransform translateTransform =
                    transformGroup.Children[2] as TranslateTransform;

                scaleTransform.ScaleX = scalingFactor;
                scaleTransform.ScaleY = scalingFactor;
                rotateTransform.Angle =
                    Math.Atan2(tangent.Y, tangent.X) * 180 / Math.PI;
                rotateTransform.CenterX = width / 2;
                rotateTransform.CenterY = baseline;
                translateTransform.X = point.X - width / 2;
                translateTransform.Y = point.Y - baseline;

                Rect rect = drawingVisual.ContentBounds;
                rect.Transform(transformGroup.Value);
                boundingRect.Union(rect);

                progress += width / 2 / pathLength;
            }
            InvalidateMeasure();
        }
开发者ID:CodeByBerglund,项目名称:nai-framework,代码行数:55,代码来源:TextOnPathVisuals.cs

示例15: TransformVisualChildren

		protected virtual void TransformVisualChildren()
		{
			this.boundingRect = default(Rect);
			if (this.pathLength != 0.0 && this.textLength != 0.0)
			{
				if (this.formattedChars.Count == this.visualChildren.Count)
				{
					double num = this.pathLength / this.textLength;
					PathGeometry pathGeometry = new PathGeometry(new PathFigure[]
					{
						base.PathFigure
					});
					double num2 = 0.0;
					this.boundingRect = default(Rect);
					for (int i = 0; i < this.visualChildren.Count; i++)
					{
						FormattedText formattedText = this.formattedChars[i];
						double num3 = num * formattedText.WidthIncludingTrailingWhitespace;
						double num4 = num * formattedText.Baseline;
						num2 += num3 / 2.0 / this.pathLength;
						Point point;
						Point point2;
						pathGeometry.GetPointAtFractionLength(num2, out point, out point2);
						DrawingVisual drawingVisual = this.visualChildren[i] as DrawingVisual;
						TransformGroup transformGroup = drawingVisual.Transform as TransformGroup;
						ScaleTransform scaleTransform = transformGroup.Children[0] as ScaleTransform;
						RotateTransform rotateTransform = transformGroup.Children[1] as RotateTransform;
						TranslateTransform translateTransform = transformGroup.Children[2] as TranslateTransform;
						scaleTransform.ScaleX = num;
						scaleTransform.ScaleY = num;
						rotateTransform.Angle = Math.Atan2(point2.Y, point2.X) * 180.0 / 3.1415926535897931;
						rotateTransform.CenterX = num3 / 2.0;
						rotateTransform.CenterY = num4;
						translateTransform.X = point.X - num3 / 2.0;
						translateTransform.Y = point.Y - num4;
						Rect contentBounds = drawingVisual.ContentBounds;
						contentBounds.Transform(transformGroup.Value);
						this.boundingRect.Union(contentBounds);
						num2 += num3 / 2.0 / this.pathLength;
					}
					base.InvalidateMeasure();
				}
			}
		}
开发者ID:akordowski,项目名称:Source-Code-Atomiq,代码行数:44,代码来源:TextOnPathVisuals.cs


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