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


C# StreamGeometry.Freeze方法代碼示例

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


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

示例1: CalculateShape

		private void CalculateShape()
		{
			//Vorberechnen für bessere Performance
			float angle = Angle * (float)(Math.PI / 180);
			float sinAngle = (float)Math.Sin(angle);
			float cosAngle = (float)Math.Cos(angle);

			//P_L
			startPoint = new Point(Size - cosAngle * Size, Size + sinAngle * Size);
			//P_O
			circleIntersectionPoint = new Point(2 * Size, Size);
			//P_R
			circleEndPoint = new Point(Size * 3 + cosAngle * Size, Size + sinAngle * Size);
			//P_U
			Vector angledVector = new Vector(-sinAngle, cosAngle);
			double lineLength = (2 * Size - (Size * 3 + cosAngle * Size)) / angledVector.X;
			trianglePoint = Point.Add(circleEndPoint, Vector.Multiply(angledVector, lineLength));

			//Form aus Punkten erstellen
			heart = new StreamGeometry();
			using (StreamGeometryContext ctx = heart.Open())
			{
				ctx.BeginFigure(startPoint, true, true);
				ctx.ArcTo(circleIntersectionPoint, new Size(Size, Size), Math.PI + angle, true, SweepDirection.Clockwise, true, false);
				ctx.ArcTo(circleEndPoint, new Size(Size, Size), Math.PI + angle, true, SweepDirection.Clockwise, true, false);
				ctx.LineTo(trianglePoint, true, false);
			}
			heart.Freeze();
		}
開發者ID:lkempf,項目名稱:Bwinf-34-r2,代碼行數:29,代碼來源:Cake.cs

示例2: MakeGeometry

        internal void MakeGeometry()
        {
            if (Edge.Points.Count > 0)
            {
                var points = Edge.Points;
                StreamGeometry g = new StreamGeometry();
                StreamGeometryContext c = g.Open();

                c.BeginFigure(points[0], false, false);
                var r = Edge.Points.Where(p => p != Edge.Points[0]);
                c.PolyBezierTo(r.ToList(), true, false);

                if (Edge.EndPoint.HasValue)
                {
                    Point from = Edge.Points.Last();
                    Point to = Edge.EndPoint.Value;

                    DrawArrow(c, from, to, 4);
                }

                if (Edge.StartPoint.HasValue)
                {
                    Point from = Edge.Points.First();
                    Point to = Edge.StartPoint.Value;

                    DrawArrow(c, from, to, 4);
                }

                c.Close();
                g.Freeze();

                EdgeGeometry = g;
            }
        }
開發者ID:smartcaveman,項目名稱:graphviznet,代碼行數:34,代碼來源:EdgePresenter.cs

示例3: Draw

 public void Draw(TextView textView, DrawingContext drawingContext)
 {
     foreach (TextSegment current in this.SearchHitsSegments)
     {
         foreach (Rect current2 in BackgroundGeometryBuilder.GetRectsForSegment(textView, current))
         {
             Point bottomLeft = current2.BottomLeft;
             Point bottomRight = current2.BottomRight;
             Pen pen = new Pen(new SolidColorBrush(Colors.OrangeRed), 1);
             pen.Freeze();
             double num = 2.5;
             int count = System.Math.Max((int)((bottomRight.X - bottomLeft.X) / num) + 1, 4);
             StreamGeometry streamGeometry = new StreamGeometry();
             using (StreamGeometryContext streamGeometryContext = streamGeometry.Open())
             {
                 streamGeometryContext.BeginFigure(bottomLeft, true, true);
                 streamGeometryContext.LineTo(current2.TopLeft, true, false);
                 streamGeometryContext.LineTo(current2.TopRight, true, false);
                 streamGeometryContext.LineTo(current2.BottomRight, true, false);
             }
             streamGeometry.Freeze();
             drawingContext.DrawGeometry(Brushes.Transparent, pen, streamGeometry);
         }
     }
 }
開發者ID:BernardNotarianni,項目名稱:DownmarkerWPF,代碼行數:25,代碼來源:SearchBackgroundRenderer.cs

示例4: GetOrCreateBoxGeometry

        protected override Geometry GetOrCreateBoxGeometry(Size renderSize)
        {
            var rect = new Rect(new Point(0, 0), renderSize);
            this.SetCurrentValue(RectProperty, rect);
            if (rect.Width <= 0 || rect.Height <= 0)
            {
                return Geometry.Empty;
            }

            if (this.CornerRadius.IsAllEqual())
            {
                // using TopLeft here as we have already checked that they are equal
                if (this.BoxGeometry is RectangleGeometry)
                {
                    return this.BoxGeometry;
                }

                var geometry = new RectangleGeometry();
                geometry.Bind(RectangleGeometry.RectProperty)
                    .OneWayTo(this, RectProperty);
                geometry.Bind(RectangleGeometry.RadiusXProperty)
                    .OneWayTo(this, CornerRadiusProperty, CornerRadiusTopLeftConverter.Default);
                geometry.Bind(RectangleGeometry.RadiusYProperty)
                    .OneWayTo(this, CornerRadiusProperty, CornerRadiusTopLeftConverter.Default);
                return geometry;
            }
            else
            {
                var geometry = new StreamGeometry();
                using (var context = geometry.Open())
                {
                    var cr = this.AdjustedCornerRadius();
                    var p = cr.TopLeft > 0
                        ? new Point(cr.TopLeft + this.StrokeThickness / 2, this.StrokeThickness / 2)
                        : new Point(this.StrokeThickness / 2, this.StrokeThickness / 2);
                    context.BeginFigure(p, true, true);
                    p = p.WithOffset(rect.Width - cr.TopLeft - cr.TopRight, 0);
                    context.LineTo(p, true, true);
                    p = context.DrawCorner(p, cr.TopRight, cr.TopRight);

                    p = p.WithOffset(0, rect.Height - cr.TopRight - cr.BottomRight);
                    context.LineTo(p, true, true);
                    p = context.DrawCorner(p, -cr.BottomRight, cr.BottomRight);

                    p = p.WithOffset(-rect.Width + cr.BottomRight + cr.BottomLeft, 0);
                    context.LineTo(p, true, true);
                    p = context.DrawCorner(p, -cr.BottomLeft, -cr.BottomLeft);

                    p = p.WithOffset(0, -rect.Height + cr.TopLeft + cr.BottomLeft);
                    context.LineTo(p, true, true);
                    context.DrawCorner(p, cr.TopLeft, -cr.TopLeft);
                }

                geometry.Freeze();
                return geometry;
            }
        }
開發者ID:JohanLarsson,項目名稱:Gu.Wpf.Geometry,代碼行數:57,代碼來源:BoxBalloon.cs

示例5: OnRender

		protected override void OnRender(DrawingContext drawingContext)
		{
			if (Plotter2D == null) return;
			if (DataSource == null) return;
			if (Collection == null) return;
			if (Collection.Lines.Count == 0)
			{
				IsolineBuilder.DataSource = DataSource;
			}

			var dc = drawingContext;
			var dataSource = DataSource;
			var localMinMax = dataSource.GetMinMax();
			var globalMinMax = dataSource.Range.Value;
			double lengthsRatio = globalMinMax.GetLength() / localMinMax.GetLength();

			if (lengthsRatio > 16)
			{
				double log = Math.Round(Math.Log(lengthsRatio, 2));
				double number = 2 * Math.Pow(2, log);
				double delta = globalMinMax.GetLength() / number;

				double start = Math.Floor((localMinMax.Min - globalMinMax.Min) / delta) * delta + globalMinMax.Min;
				double end = localMinMax.Max;

				var transform = Plotter2D.Transform;
				var strokeThickness = StrokeThickness;

				double x = start;
				while (x < end)
				{
					var collection = IsolineBuilder.BuildIsoline(x);

					foreach (LevelLine line in collection)
					{
						StreamGeometry lineGeometry = new StreamGeometry();
						using (var context = lineGeometry.Open())
						{
							context.BeginFigure(line.StartPoint.ViewportToScreen(transform), false, false);
							context.PolyLineTo(line.OtherPoints.ViewportToScreen(transform).ToArray(), true, true);
						}
						lineGeometry.Freeze();

						var paletteRatio = (line.RealValue - globalMinMax.Min) / globalMinMax.GetLength();
						Pen pen = new Pen(new SolidColorBrush(Palette.GetColor(paletteRatio)), strokeThickness);

						dc.DrawGeometry(null, pen, lineGeometry);
					}

					x += delta;
				}
			}
			//dc.DrawRectangle(Brushes.Green.MakeTransparent(0.3), null, new Rect(RenderSize));
		}
開發者ID:XiBeichuan,項目名稱:hydronumerics,代碼行數:54,代碼來源:AdditionalLinesDisplay.cs

示例6: DeserializeStreamGeometry

        internal static object DeserializeStreamGeometry( BinaryReader reader )
        {
            StreamGeometry geometry = new StreamGeometry();
            
            using (StreamGeometryContext context = geometry.Open())
            {
                ParserStreamGeometryContext.Deserialize( reader, context, geometry ); 
            }
            geometry.Freeze();

            return geometry; 
        }
開發者ID:JianwenSun,項目名稱:cc,代碼行數:12,代碼來源:parserscommon.cs

示例7: Invalidate

		public void Invalidate()
		{
			_geometry = new StreamGeometry();
			using (StreamGeometryContext ctx = _geometry.Open())
				foreach (var gridLine in GridLines)
				{
					ctx.BeginFigure(gridLine.Orientation == Orientation.Horizontal ? new Point(0, gridLine.Position) : new Point(gridLine.Position, 0), false, false);
					ctx.LineTo(gridLine.Orientation == Orientation.Horizontal ? new Point(_canvas.Width, gridLine.Position) : new Point(gridLine.Position, _canvas.Height), true, false);
				}
			_geometry.Freeze();
			_clipGeometry = new RectangleGeometry(new Rect(0, 0, _canvas.CanvasWidth, _canvas.CanvasHeight));
			_canvas.Refresh();
		}
開發者ID:saeednazari,項目名稱:Rubezh,代碼行數:13,代碼來源:GridLineController.cs

示例8: Draw

        public void Draw(DrawingContext dc, List<Point> filteredPoints, ChartStyle chartStyle)
        {
            var geometry = new StreamGeometry();
            using (StreamGeometryContext context = geometry.Open())
            {
                context.BeginFigure(filteredPoints[0], false, false);
                context.PolyLineTo(filteredPoints, true, true);
            }
            geometry.Freeze();

            Pen pen = new Pen(chartStyle.LineColor, 1);

            dc.DrawGeometry(null, pen, geometry);
        }
開發者ID:anndream,項目名稱:StockCharts-1,代碼行數:14,代碼來源:LineChart.cs

示例9: RegenerateShape

        public override void RegenerateShape(GMapControl map)
        {
            if (map != null)
            {
                if (Points.Count > 1)
                {
                    var localPath = new List<Point>();
                    var offset = map.FromLatLngToLocal(Points[0]);
                    foreach (PointLatLng i in Points)
                    {
                        var p = map.FromLatLngToLocal(new PointLatLng(i.Lat, i.Lng));
                        localPath.Add(new Point(p.X - offset.X, p.Y - offset.Y));
                    }

                    // Create a StreamGeometry to use to specify myPath.
                    var geometry = new StreamGeometry();

                    using (StreamGeometryContext ctx = geometry.Open())
                    {
                        ctx.BeginFigure(localPath[0], true, true);

                        // Draw a line to the next specified point.
                        ctx.PolyLineTo(localPath, true, true);
                    }

                    // Freeze the geometry (make it unmodifiable)
                    // for additional performance benefits.
                    geometry.Freeze();

                    // Create a path to draw a geometry with.
                    Shape = new Path
                        {
                            Data = geometry,
                            Fill = Brushes.Transparent,
                            StrokeThickness = 20,
                            Stroke = Brushes.Transparent,
                            IsHitTestVisible = true
                        };
                }
                else
                {
                    Shape = null;
                }
            }
        }
開發者ID:rmunn,項目名稱:cog,代碼行數:45,代碼來源:RegionHitMarker.cs

示例10: RemoveButton

		static RemoveButton()
		{
			_tabItemCloseButtonHoverBackgroundBrush = new SolidColorBrush((Color)ColorConverter.ConvertFromString("#FFc13535"));
			_tabItemCloseButtonPressedBackgroundBrush = new SolidColorBrush((Color)ColorConverter.ConvertFromString("#FF431e20"));
			_tabItemCloseButtonPressedForegroundPen = new Pen(new SolidColorBrush((Color)ColorConverter.ConvertFromString("#FFf9ebeb")), 2);
			_tabItemCloseButtonHoverForegroundPen = new Pen(new SolidColorBrush((Color)ColorConverter.ConvertFromString("#FFf9ebeb")), 2);
			_geometry = new StreamGeometry();
			using (StreamGeometryContext context = _geometry.Open())
			{
				context.BeginFigure(new Point(-3, -3), true, false);
				context.LineTo(new Point(3, 3), true, false);
				context.BeginFigure(new Point(-3, 3), true, false);
				context.LineTo(new Point(3, -3), true, false);
				context.Close();
			}
			_tabItemCloseButtonHoverBackgroundBrush.Freeze();
			_tabItemCloseButtonPressedBackgroundBrush.Freeze();
			_tabItemCloseButtonPressedForegroundPen.Freeze();
			_tabItemCloseButtonHoverForegroundPen.Freeze();
			_geometry.Freeze();
		}
開發者ID:saeednazari,項目名稱:Rubezh,代碼行數:21,代碼來源:RemoveButton.cs

示例11: Draw

 public void Draw(TextView textView, DrawingContext drawingContext)
 {
     foreach (var current in ErrorSegments)
     {
         foreach (var current2 in BackgroundGeometryBuilder.GetRectsForSegment(textView, current))
         {
             var bottomLeft = current2.BottomLeft;
             var bottomRight = current2.BottomRight;
             var pen = new Pen(new SolidColorBrush(Colors.Red), 0.6);
             pen.Freeze();
             const double num = 2.0;
             var count = Math.Max((int)((bottomRight.X - bottomLeft.X)/num) + 1, 4);
             var streamGeometry = new StreamGeometry();
             using (var streamGeometryContext = streamGeometry.Open())
             {
                 streamGeometryContext.BeginFigure(bottomLeft, false, false);
                 streamGeometryContext.PolyLineTo(CreatePoints(bottomLeft, num, count).ToArray(), true, false);
             }
             streamGeometry.Freeze();
             drawingContext.DrawGeometry(Brushes.Transparent, pen, streamGeometry);
         }
     }
 }
開發者ID:jhorv,項目名稱:Markdown-Edit,代碼行數:23,代碼來源:SpellCheckBackgroundRenderer.cs

示例12: Draw

        public override void Draw(DrawingContext dc)
        {
            Point p1 = A.Mid(B), p2 = B.Mid(C);

            //dc.DrawLine (pen, A, B);
            //dc.DrawLine (pen, B, C);
            double h1 = A.Heading(B), h2 = B.Heading(C);
            double hp1 = h1 + Math.PI / 2, hp2 = B.Heading(C) + Math.PI / 2;

            //dc.DrawEllipse (Brushes.Blue, null, p1, 2, 2);
            //dc.DrawEllipse (Brushes.Blue, null, p2, 2, 2);

            Point p3 = p1.PolarMove(500, hp1);
            Point p4 = p2.PolarMove(500, hp2);
            //dc.DrawLine (pen, p1, p3);
            //dc.DrawLine (pen, p2, p4);

            Point cen = Extensions.Intersect(p1, p3, p2, p4);
            //dc.DrawEllipse (Brushes.Green, null, cen, 5, 5);
            double rad = cen.DistTo(A);

            double turn = h2 - h1;
            if (turn < -Math.PI) turn += 2 * Math.PI;
            else if (turn > Math.PI) turn -= 2 * Math.PI;
            SweepDirection sweep = (turn < 0) ? SweepDirection.Counterclockwise : SweepDirection.Clockwise;
            bool largeArc = Math.Abs(turn) > Math.PI / 2;

            StreamGeometry sg = new StreamGeometry();
            using (StreamGeometryContext ctx = sg.Open())
            {
                ctx.BeginFigure(A, false, false);
                ctx.ArcTo(C, new Size(rad, rad), 0, largeArc, sweep, true, false);
            }
            sg.Freeze();
            dc.DrawGeometry(null, MakePen(), sg);
        }
開發者ID:keshavb-96,項目名稱:CAD,代碼行數:36,代碼來源:Drawing.cs

示例13: creategeometry

        //Redraw data
        private void creategeometry(int value)
        {
            // Create a StreamGeometry to use to specify myPath.
            geometry = new StreamGeometry();
            geometry.Open();
            // Open a StreamGeometryContext that can be used to describe this StreamGeometry  
            // object's contents. 
            using (StreamGeometryContext geo = geometry.Open())
            {
                if (direction == LineDirection.Horizontal)
                {
                    geo.BeginFigure(new Point(0, value), false, false);
                    geo.LineTo(new Point(view.XMAX, value), true, false);

                }
                else if (direction == LineDirection.Vertical)
                {
                    geo.BeginFigure(new Point(value, 0), false, false);
                    geo.LineTo(new Point(value, view.YMAX), true, false);
                }
            }
            geometry.Freeze();
            line.Data = geometry;
        }
開發者ID:DiLRandI,項目名稱:ArduinoMonitor,代碼行數:25,代碼來源:gridLine.cs

示例14: RenderIsolineCollection

		protected void RenderIsolineCollection(DrawingContext dc, double strokeThickness, IsolineCollection collection, CoordinateTransform transform)
		{
			foreach (LevelLine line in collection)
			{
				StreamGeometry lineGeometry = new StreamGeometry();
				using (var context = lineGeometry.Open())
				{
					context.BeginFigure(line.StartPoint.ViewportToScreen(transform), false, false);
					if (!UseBezierCurves)
					{
						context.PolyLineTo(line.OtherPoints.ViewportToScreen(transform).ToArray(), true, true);
					}
					else
					{
						context.PolyBezierTo(BezierBuilder.GetBezierPoints(line.AllPoints.ViewportToScreen(transform).ToArray()).Skip(1).ToArray(), true, true);
					}
				}
				lineGeometry.Freeze();

				Pen pen = new Pen(new SolidColorBrush(Palette.GetColor(line.Value01)), strokeThickness);

				dc.DrawGeometry(null, pen, lineGeometry);
			}
		}
開發者ID:XiBeichuan,項目名稱:hydronumerics,代碼行數:24,代碼來源:IsolineRenderer.cs

示例15: RegenerateShape

        public override void RegenerateShape(GMapControl map)
        {
            if (map != null)
            {
                if (Points.Count > 1)
                {
                    var localPath = new List<Point>();
                    var offset = map.FromLatLngToLocal(Points[0]);
                    foreach (PointLatLng i in Points)
                    {
                        var p = map.FromLatLngToLocal(new PointLatLng(i.Lat, i.Lng));
                        localPath.Add(new Point(p.X - offset.X, p.Y - offset.Y));
                    }

                    // Create a StreamGeometry to use to specify myPath.
                    var geometry = new StreamGeometry();

                    using (StreamGeometryContext ctx = geometry.Open())
                    {
                        ctx.BeginFigure(localPath[0], true, true);

                        // Draw a line to the next specified point.
                        ctx.PolyLineTo(localPath, true, true);
                    }

                    // Freeze the geometry (make it unmodifiable)
                    // for additional performance benefits.
                    geometry.Freeze();

                    var fillBrush = new SolidColorBrush();
                    BindingOperations.SetBinding(fillBrush, SolidColorBrush.ColorProperty, new Binding("Variety.ClusterIndex") {Converter = new IndexToColorConverter(), ConverterParameter = Colors.CornflowerBlue});
                    var strokeBrush = new SolidColorBrush();
                    BindingOperations.SetBinding(strokeBrush, SolidColorBrush.ColorProperty, new Binding("Color") {Source = fillBrush, Converter = new ColorBrightnessConverter(), ConverterParameter = -0.15});
                    // Create a path to draw a geometry with.
                    var path = new Path
                        {
                            Data = geometry,
                            Effect = new BlurEffect {KernelType = KernelType.Gaussian, Radius = 3.0, RenderingBias = RenderingBias.Quality},
                            Stroke = strokeBrush,
                            Fill = fillBrush,
                            StrokeThickness = 3,
                            Opacity = 0.5,
                            IsHitTestVisible = true,
                            DataContext = _region,
                            Visibility = Shape == null ? Visibility.Visible : Shape.Visibility
                        };
                    Shape = path;
                    Shape.MouseEnter += Shape_MouseEnter;
                    Shape.MouseLeave += Region_MouseLeave;
                }
                else
                {
                    Shape = null;
                }
            }
        }
開發者ID:StephenEhmann,項目名稱:cog,代碼行數:56,代碼來源:RegionMarker.cs


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