How to draw a dashed line over an object?
Asked Answered
P

6

19

I am drawing a line on a control on my Windows form like this:

            // Get Graphics object from chart
            Graphics graph = e.ChartGraphics.Graphics;

            PointF point1 = PointF.Empty;
            PointF point2 = PointF.Empty;

            // Set Maximum and minimum points
            point1.X = -110;
            point1.Y = -110;
            point2.X = 122;
            point2.Y = 122;

            // Convert relative coordinates to absolute coordinates.
            point1 = e.ChartGraphics.GetAbsolutePoint(point1);
            point2 = e.ChartGraphics.GetAbsolutePoint(point2);

            // Draw connection line
            graph.DrawLine(new Pen(Color.Yellow, 3), point1, point2);

I would like to know if it is possible to draw a dashed (dotted) line instead of a regular solid line?

Populace answered 23/5, 2011 at 17:17 Comment(0)
R
41

It's pretty simple once you figure out the formatting that defines the dashes:

float[] dashValues = { 5, 2, 15, 4 };
Pen blackPen = new Pen(Color.Black, 5);
blackPen.DashPattern = dashValues;
e.Graphics.DrawLine(blackPen, new Point(5, 5), new Point(405, 5));

The numbers in the float array represent dash lengths of different colors. So for a simple dash of 2 pixels on (black) and two off each your aray would look like: {2,2} The pattern then repeats. If you wanted 5-wide dashes with a space of 2 pixels you would use {5,2}

In your code it would look like:

// Get Graphics object from chart
Graphics graph = e.ChartGraphics.Graphics;

PointF point1 = PointF.Empty;
PointF point2 = PointF.Empty;

// Set Maximum and minimum points
point1.X = -110;
point1.Y = -110;
point2.X = 122;
point2.Y = 122;

// Convert relative coordinates to absolute coordinates.
point1 = e.ChartGraphics.GetAbsolutePoint(point1);
point2 = e.ChartGraphics.GetAbsolutePoint(point2);

// Draw (dashed) connection line
float[] dashValues = { 4, 2 };
Pen dashPen= new Pen(Color.Yellow, 3);
dashPen.DashPattern = dashValues;
graph.DrawLine(dashPen, point1, point2);
Rufescent answered 23/5, 2011 at 17:21 Comment(2)
thanks so much so can you show me how i would incorporate this into my codePopulace
@I: plz see my edit. Note of caution though. I'm not running this through a compiler so there may be syntax and intent errors. In any case, should get you close.Rufescent
A
13

I think you can accomplish this by changing the pen you use to draw your line. So, replace the last 2 lines in your example with:

        var pen = new Pen(Color.Yellow, 3);
        pen.DashStyle = DashStyle.Dash;
        graph.DrawLine(pen, point1, point2);
Amie answered 23/5, 2011 at 17:27 Comment(0)
D
7

Pen has a public property that is defined as

public DashStyle DashStyle { get; set; }

you can set DasStyle.Dash if you want to draw a dashed line.

Daberath answered 23/5, 2011 at 17:23 Comment(0)
H
3

Pen.DashPattern will do this. Look here for an example.

Histiocyte answered 23/5, 2011 at 17:21 Comment(0)
F
2

In more modern C#:

var dottedPen = new Pen(Color.Gray, width: 1) { DashPattern = new[] { 1f, 1f } };
Fastback answered 1/10, 2016 at 21:59 Comment(0)
S
0

To answer this question regarding the generation of a dashed line using the code-behind:

        Pen dashPenTest = new(Brushes.DodgerBlue, 1);

        Line testLine = new()
        {
            Stroke = dashPenTest.Brush, //Brushes.Aqua,
            StrokeThickness = dashPenTest.Thickness,//1,
            StrokeDashArray = new DoubleCollection() { 8,4 },
            X1 = 0,
            X2 = canvas.Width,
            Y1 = 10,
            Y2 = 10
        }; 
        canvas.Children.Add(testLine);

This answer make use of the generation of a canvas in the xaml:

        <Canvas x:Name ="canvas" Background="White" Height="300" Width="300">

The important method here is the "StrokeDashArray" that generates the dashes for the line drawn. More information is given here: Shape.StrokeDashArray

Schoolfellow answered 18/2, 2023 at 6:29 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.