Search code examples
wpfcanvasbackgrounddrawingbrush

Creating a Canvas Background Dynamically


I currently have a canvas which contains a bunch of sqaures as its children. These sqaures sit on different lines. I would like to draw a background for the canvas which draws lines (like a notepad would have feint blue lines on the paper) I would like to draw this dynamically by binding it to a collection of "lines" So if there are 2 lines in the collection, 2 lines will be drawn on the background of the canvas. I was looking into using DrawingBrush, but i am not sure if this is the correct way forward

<DrawingBrush>
  <DrawingBrush.Drawing>
    <Line Name=Line1/>
    <Line Name=Line2/>
  </DrawingBrush.Drawing>
</DrawingBrush>

(BTW The above code does not work, it is just to explain the conecpt)


Solution

  • Try this approach. Use a new class for your canvas:

    internal class SpecialCanvas : Canvas
    {
        ...
    
        ObservableCollection<Line> Lines {get; set;}
    
        DrawingVisual backgroundVisual = new DrawingVisual;
    
        public SpecialCanvas()
        {
            this.Background = new VisualBrush(backgroundVisual);   
        }
    
        private void OnLinesChanged(...)
        {
           using (DrawingContext dc = this.backgroundVisual.RenderOpen())
           {
               // Draw your lines to dc here.
           }
        }
    

    }