Quantower_in
Search…
Indicator with custom painting (GDI)
Draw any graphical objects on the chart using the GDI+ library

Introduction

In this topic, we will show you how to use a really great possibility of scripts in Quantower — a custom painting on the Chart. You can draw anything you need via GDI+ — a graphical subsystem of Windows. In C# all features from GDI+ are encapsulated in class Graphics. It is a set of functions allowing to create graphical primitives and splines using brushes and pens, Images, etc. More information you can find on the Microsoft documentation site.

Access Graphics object

Let's start. To get access to Graphics object of the chart you need to override OnPaint method and use Hdc value from its parameters:
1
public override void OnPaintChart(PaintChartEventArgs args)
2
{
3
// Use args.Hdc to create Graphics which give us acces to chart canvas
4
Graphics gr = Graphics.FromHdc(args.Hdc);
5
6
// Add your custom drawings here...
7
}
Copied!
That's all - now you have full access to chart's canvas and can draw anything you want. For drawing in C# you need to call special methods with graphical parameters: coordinates, color, width, etc.:
1
public override void OnPaintChart(PaintChartEventArgs args)
2
{
3
Graphics gr = Graphics.FromHdc(args.Hdc);
4
5
// Draw a line using predefined Red pen
6
gr.DrawLine(Pens.Red, 100,100,200,200);
7
8
// Draw a rectangle using predefined Blue pen
9
gr.DrawRectangle(Pens.Blue, 250, 100, 100, 100);
10
11
// Fill a rectangle using predefined yellow brush
12
gr.FillRectangle(Brushes.Yellow, 400, 100, 100, 100);
13
14
// Create a custom pen and use it for drawing
15
Pen myPen = new Pen(Color.Green, 3);
16
gr.DrawRectangle(myPen, 50, 50, 500, 200);
17
}
Copied!
If we build this indicator - we can see the result on the chart window:
Drawing directly on the chart

Drawing a simple text

Let's try to draw a text — it is very similar. We need to specify text, font, and coordinates:
1
public override void OnPaintChart(PaintChartEventArgs args)
2
{
3
Graphics gr = Graphics.FromHdc(args.Hdc);
4
5
// Draw the text with specified font and color
6
gr.DrawString("An examle if drawing text...", new Font("Arial", 20), Brushes.Red, 100, 100);
7
}
Copied!
Build this and check your chart:
Drawing a text

Market depth levels on chart

Ok, it is interesting but quite useless. Let's do something more serious — for example, display all levels of market depth on the chart. This is source code:
1
protected override void OnInit()
2
{
3
// Subscribe for level 2 quotes
4
this.Symbol.Subscribe(SubscribeQuoteType.Level2);
5
}
6
7
public override void OnPaintChart(PaintChartEventArgs args)
8
{
9
Graphics gr = Graphics.FromHdc(args.Hdc);
10
11
// Create a font
12
Font font = new Font("Arial", 10);
13
14
// Request a current sorting bids
15
List<Level2Item> sortedBids = this.Symbol.Bids.GetSortedList();
16
17
// Draw bids
18
for (int i = 0; i < sortedBids.Count; i++)
19
gr.DrawString(sortedBids[i].Quote.Price.ToString(), font, Brushes.LightGray, 20, 23 * i + 30);
20
21
// Request a current sorting asks
22
List<Level2Item> sortedAsks = this.Symbol.Asks.GetSortedList();
23
24
// Draw asks
25
for (int i = 0; i < sortedAsks.Count; i++)
26
gr.DrawString(sortedAsks[i].Quote.Price.ToString(), font, Brushes.LightGray, 100, 23 * i + 30);
27
}
Copied!
And this is how our chart looks now. You can compare results with Market Depth panel in Quantower:
Display bids and asks on the chart
It is a great possibility of chart features extending, isn't it? You can add your own Info Window, Track Cursor or even Volume Analysis visualization. There are no limitations in our API, only your fantasy.
Last modified 2yr ago