Нарисуйте пунктирную линию в WPF adorner

Я нашел несколько статей в Интернете о том, как рисовать пунктирную линию в WPF. Однако они, похоже, вращаются вокруг, используя класс Line, который является UIElement в WPF. Это происходит примерно так:

Line myLine = new Line();
DoubleCollection dashes = new DoubleCollection();
dashes.Add(2);
dashes.Add(2);
myLine.StrokeDashArray = dashes;

Теперь я нахожусь в Adorner, где у меня есть доступ к контексту рисования. Там я более или менее сведен к примитивам рисования, кистям, ручкам, геометрии и т.д. Это больше похоже на:

var pen = new Pen(new SolidColorBrush(Color.FromRgb(200, 10, 20)), 2);
drawingContext.DrawLine(pen, point1, point2);

Я застрял, как сделать пунктирную линию на этом уровне API. Надеюсь, это не значит "рисовать маленькие линии один за другим", а что-то еще, чего я не видел...

Ответ 1

Посмотрите на свойство Pen.DashStyle. Вы можете использовать члены класса DashStyles, которые дают некоторые предопределенные стили стилей, или вы можете указать собственный шаблон тире и пробелов, создав новый DashStyle экземпляр.

var pen = new Pen(new SolidColorBrush(Color.FromRgb(200, 10, 20)), 2);
pen.DashStyle = DashStyles.Dash;
drawingContext.DrawLine(pen, point1, point2);

Ответ 2

Вы не привязаны к примитивам. Если вы будете следовать этому шаблону, вы можете добавить что-нибудь к adorner.

public class ContainerAdorner : Adorner
{
    // To store and manage the adorner visual children.
    VisualCollection visualChildren;

    // Override the VisualChildrenCount and GetVisualChild properties to interface with 
    // the adorner visual collection.
    protected override int VisualChildrenCount { get { return visualChildren.Count; } }
    protected override Visual GetVisualChild(int index) { return visualChildren[index]; }

    // Initialize the ResizingAdorner.
    public ContainerAdorner (UIElement adornedElement)
        : base(adornedElement)
    {
        visualChildren = new VisualCollection(this);
        visualChildren.Add(_Container);
    }
    ContainerClass _Container= new ContainerClass();

    protected override Size ArrangeOverride(Size finalSize)
    {
        // desiredWidth and desiredHeight are the width and height of the element that being adorned.  
        // These will be used to place the Adorner at the corners of the adorned element.  
        double desiredWidth = AdornedElement.DesiredSize.Width;
        double desiredHeight = AdornedElement.DesiredSize.Height;

        FrameworkElement fe;
        if ((fe = AdornedElement as FrameworkElement) != null)
        {
            desiredWidth = fe.ActualWidth;
            desiredHeight = fe.ActualHeight;
        }

        _Container.Arrange(new Rect(0, 0, desiredWidth, desiredHeight));

        return finalSize;
    }
}