本文整理匯總了C#中System.Windows.Media.Geometry類的典型用法代碼示例。如果您正苦於以下問題:C# Geometry類的具體用法?C# Geometry怎麽用?C# Geometry使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
Geometry類屬於System.Windows.Media命名空間,在下文中一共展示了Geometry類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: Read
///<summary>
/// Converts a flat path to a <see cref="IGeometry"/>.
///</summary>
/// <param name="pathIt">The path iterator of the path to convert</param>
/// <returns>A Geometry representing the path</returns>
public IGeometry Read(WpfGeometry pathIt)
{
var pathPtSeq = ToCoordinates(pathIt);
var polys = new List<IGeometry>();
var seqIndex = 0;
while (seqIndex < pathPtSeq.Count)
{
// assume next seq is shell
// TODO: test this
var pts = pathPtSeq[seqIndex];
var shell = _geometryFactory.CreateLinearRing(pts);
seqIndex++;
var holes = new List<ILinearRing>();
Coordinate[] holePts;
// add holes as long as rings are CCW
while (seqIndex < pathPtSeq.Count && IsHole(holePts = pathPtSeq[seqIndex]))
{
var hole = _geometryFactory.CreateLinearRing(holePts);
holes.Add(hole);
seqIndex++;
}
var holeArray = holes.ToArray();//GeometryFactory.ToLinearRingArray(holes);
polys.Add(_geometryFactory.CreatePolygon(shell, holeArray));
}
return _geometryFactory.BuildGeometry(polys);
}
示例2: CameraPicture
internal CameraPicture()
{
_geometry = new CombinedGeometry()
{
Geometry1 = new RectangleGeometry(new Rect(0, 3, 14, 8), 1, 1),
Geometry2 = new PathGeometry()
{
Figures = new PathFigureCollection()
{
new PathFigure()
{
StartPoint = new Point(16,5),
IsClosed = false,
Segments = new PathSegmentCollection()
{
new LineSegment(new Point(20,2),true),
new LineSegment(new Point(20,12),true),
new LineSegment(new Point(16,9),true),
}
}
}
}
};
_geometry.Freeze();
_brushes = new Dictionary<Brush, Brush>();
}
示例3: DrawGeometry
/// <summary>
/// DrawGeometry -
/// Draw a Geometry with the provided Brush and/or Pen.
/// If both the Brush and Pen are null this call is a no-op.
/// </summary>
/// <param name="brush">
/// The Brush with which to fill the Geometry.
/// This is optional, and can be null, in which case no fill is performed.
/// </param>
/// <param name="pen">
/// The Pen with which to stroke the Geometry.
/// This is optional, and can be null, in which case no stroke is performed.
/// </param>
/// <param name="geometry"> The Geometry to fill and/or stroke. </param>
public override void DrawGeometry(
Brush brush,
Pen pen,
Geometry geometry)
{
if (IsCurrentLayerNoOp ||(geometry == null) || geometry.IsEmpty())
{
return;
}
if (brush != null)
{
_contains |= geometry.FillContains(_point);
}
// If we have a pen and we haven't yet hit, try the widened geometry.
if ((pen != null) && !_contains)
{
_contains |= geometry.StrokeContains(pen, _point);
}
// If we've hit, stop walking.
if (_contains)
{
StopWalking();
}
}
示例4: GetPositionedCodeTag
private UIElement GetPositionedCodeTag(ITextViewLine line, IWpfTextViewLineCollection textViewLines, Geometry geometry)
{
int lineNumber = _view.TextSnapshot.GetLineNumberFromPosition(line.Start.Position) + 1;
UIElement codeTagElement = CodeLine.ElementAt(lineNumber, GetFilename);
PlaceVisualNextToGeometry(geometry, codeTagElement);
return codeTagElement;
}
示例5: ConvertGeometry
public static Telerik.Windows.Documents.Fixed.Model.Graphics.GeometryBase ConvertGeometry(Geometry geometry)
{
#if SILVERLIGHT
var cloner = new Telerik.Windows.Controls.GeometryCloneConverter();
geometry = (Geometry)cloner.Convert(geometry, null, null, null);
#endif
PathGeometry pathGeometry = geometry as PathGeometry;
if (pathGeometry != null)
{
return ConvertPathGeometry(pathGeometry);
}
RectangleGeometry rectangleGeometry = geometry as RectangleGeometry;
if (rectangleGeometry != null)
{
return ConvertRectangleGeometry(rectangleGeometry);
}
EllipseGeometry ellipseGeometry = geometry as EllipseGeometry;
if (ellipseGeometry != null)
{
return ConvertEllipseGeometry(ellipseGeometry);
}
#if WPF
StreamGeometry streamGeometry = geometry as StreamGeometry;
if (streamGeometry != null)
{
return ConvertStreamGeometry(streamGeometry);
}
#endif
return null;
}
示例6: MeasureOverride
protected override Size MeasureOverride(Size constraint)
{
var midX = X1 + ((X2 - X1) / 2);
_geometry = new PathGeometry
{
Figures =
{
new PathFigure
{
IsFilled = false,
StartPoint = new Point(X1, Y1),
Segments =
{
new BezierSegment
{
Point1 = new Point(midX, Y1),
Point2 = new Point(midX, Y2),
Point3 = new Point(X2, Y2),
IsStroked = true
}
}
}
}
};
return base.MeasureOverride(constraint);
}
示例7: UpdateMarkersVisual
void UpdateMarkersVisual(Geometry geometry)
{
DrawingContext context = markers.RenderOpen();
context.DrawRectangle(Brushes.Red, new Pen(Brushes.Red, 1), new Rect(30, 30, 30, 30));
context.Close();
}
示例8: ScoreFromGeometries
/// <summary>
/// Calculates the score from the shape the players have to fill and their overall shadow.
/// </summary>
/// <param name="shapeToFill">The shape players have to fill.</param>
/// <param name="peoplesShadows">The players' overall shadow.</param>
/// <returns>The players' score.</returns>
public int ScoreFromGeometries(Geometry shapeToFill, Geometry peoplesShadows)
{
double fillScore = Geometry.Combine(shapeToFill, peoplesShadows, GeometryCombineMode.Intersect, null).GetArea();
double penalties = Geometry.Combine(peoplesShadows, shapeToFill, GeometryCombineMode.Exclude, null).GetArea();
double score = fillScore * 15 - (penalties / 50);
return score > 0 ? (int)score : 0;
}
示例9: GetGraphics
public override GraphicsResult GetGraphics(IWpfTextView view, Geometry geometry)
{
Initialize(view);
// We clip off a bit off the start of the line to prevent a half-square being
// drawn.
var clipRectangle = geometry.Bounds;
clipRectangle.Offset(2, 0);
var line = new Line
{
X1 = geometry.Bounds.Left,
Y1 = geometry.Bounds.Bottom - _graphicsTagPen.Thickness,
X2 = geometry.Bounds.Right,
Y2 = geometry.Bounds.Bottom - _graphicsTagPen.Thickness,
Clip = new RectangleGeometry { Rect = clipRectangle }
};
// RenderOptions.SetEdgeMode(line, EdgeMode.Aliased);
ApplyPen(line, _graphicsTagPen);
// Shift the line over to offset the clipping we did.
line.RenderTransform = new TranslateTransform(-_graphicsTagPen.Thickness, 0);
return new GraphicsResult(line, null);
}
示例10: DrawGeometry
//public void DrawEllipse(Brush brush, Pen pen, Point center, AnimationClock centerAnimations, double radiusX, AnimationClock radiusXAnimations, double radiusY, AnimationClock radiusYAnimations);
public void DrawGeometry(Brush brush, Pen pen, Geometry geometry)
{
Path path = new Path();
SetupShape(path, 0, 0, Double.NaN, Double.NaN, brush, pen);
path.Data = geometry;
ActiveCanvas.Children.Add(path);
}
示例11: PuzzlePiece
/// <summary>
/// Constructor.
/// </summary>
/// <param name="pieceNumber">Which piece number this piece contains.</param>
/// <param name="pieceShape">The shape of the pieces.</param>
/// <param name="brush">The image and viewbox to use as this piece's visual.</param>
public PuzzlePiece(int pieceNumber, Geometry pieceShape, VisualBrush brush)
{
clipShape = pieceShape;
imageBrush = brush;
pieces = new HashSet<int>();
pieces.Add(pieceNumber);
}
示例12: CreateText
/// <summary>
/// Create the outline geometry based on the formatted text.
/// </summary>
public void CreateText()
{
FontStyle fontStyle = FontStyles.Normal;
FontWeight fontWeight = FontWeights.Medium;
if (Bold == true) fontWeight = FontWeights.Bold;
if (Italic == true) fontStyle = FontStyles.Italic;
// Create the formatted text based on the properties set.
FormattedText formattedText = new FormattedText(
Text,
CultureInfo.GetCultureInfo("en-us"),
FlowDirection.LeftToRight,
new Typeface(Font, fontStyle, fontWeight, FontStretches.Normal),
FontSize,
Brushes.Black // This brush does not matter since we use the geometry of the text.
);
// Build the geometry object that represents the text.
_textGeometry = formattedText.BuildGeometry(new Point(0, 0));
//set the size of the custome control based on the size of the text
this.MinWidth = formattedText.Width;
this.MinHeight = formattedText.Height;
}
示例13: GetGraphics
/// <summary>
/// Creates a very long line at the bottom of bounds.
/// </summary>
public override GraphicsResult GetGraphics(IWpfTextView view, Geometry bounds)
{
Initialize(view);
var border = new Border()
{
BorderBrush = _graphicsTagBrush,
BorderThickness = new Thickness(0, 0, 0, bottom: 1),
Height = 1,
Width = view.ViewportWidth
};
EventHandler viewportWidthChangedHandler = (s, e) =>
{
border.Width = view.ViewportWidth;
};
view.ViewportWidthChanged += viewportWidthChangedHandler;
// Subtract rect.Height to ensure that the line separator is drawn
// at the bottom of the line, rather than immediately below.
// This makes the line separator line up with the outlining bracket.
Canvas.SetTop(border, bounds.Bounds.Bottom - border.Height);
return new GraphicsResult(border,
() => view.ViewportWidthChanged -= viewportWidthChangedHandler);
}
示例14: PointRelativeToOrigin
public Point PointRelativeToOrigin(Geometry.Shapes.Point point)
{
m_Converter.GeometryPoint = point;
m_Converter.Convert();
return m_Converter.Point;
}
示例15: PostInfoDisplay
public PostInfoDisplay(double textRightEdge,
double viewRightEdge,
Geometry newTextGeometry,
string body)
{
if (brush == null)
{
brush = new SolidColorBrush(Color.FromArgb(0x20, 0x48, 0x3d, 0x8b));
brush.Freeze();
Brush penBrush = new SolidColorBrush(Colors.DarkSlateBlue);
penBrush.Freeze();
solidPen = new Pen(penBrush, 0.5);
solidPen.Freeze();
dashPen = new Pen(penBrush, 0.5);
dashPen.DashStyle = DashStyles.Dash;
dashPen.Freeze();
}
this.textGeometry = newTextGeometry;
TextBlock tb = new TextBlock();
tb.Text = "Blog Entry: " + body;
const int MarginWidth = 8;
this.postGrid = new Grid();
this.postGrid.RowDefinitions.Add(new RowDefinition());
this.postGrid.RowDefinitions.Add(new RowDefinition());
ColumnDefinition cEdge = new ColumnDefinition();
cEdge.Width = new GridLength(MarginWidth);
ColumnDefinition cEdge2 = new ColumnDefinition();
cEdge2.Width = new GridLength(MarginWidth);
this.postGrid.ColumnDefinitions.Add(cEdge);
this.postGrid.ColumnDefinitions.Add(new ColumnDefinition());
this.postGrid.ColumnDefinitions.Add(cEdge2);
System.Windows.Shapes.Rectangle rect = new System.Windows.Shapes.Rectangle();
rect.RadiusX = 6;
rect.RadiusY = 3;
rect.Fill = brush;
rect.Stroke = Brushes.DarkSlateBlue;
Size inf = new Size(double.PositiveInfinity, double.PositiveInfinity);
tb.Measure(inf);
this.postGrid.Width = tb.DesiredSize.Width + 2 * MarginWidth;
Grid.SetColumn(rect, 0);
Grid.SetRow(rect, 0);
Grid.SetRowSpan(rect, 1);
Grid.SetColumnSpan(rect, 3);
Grid.SetRow(tb, 0);
Grid.SetColumn(tb, 1);
this.postGrid.Children.Add(rect);
this.postGrid.Children.Add(tb);
Canvas.SetLeft(this.postGrid, Math.Max(viewRightEdge - this.postGrid.Width - 20.0, textRightEdge + 20.0));
Canvas.SetTop(this.postGrid, textGeometry.GetRenderBounds(solidPen).Top);
this.Children.Add(this.postGrid);
}