Order Block Drawing [TradingFinder]

TFlab Обновлено   

Perhaps one of the most challenging tasks for Pine script developers (especially beginners) is properly drawing order blocks. While utilizing the latest technical analysis methods for "Price Action," beginners heavily rely on accurately plotting "Supply" and "Demand" zones, following concepts like "Smart Money Concept" and "ICT".

However, drawing "Order Blocks" may pose a challenge for developers. Therefore, to minimize bugs, increase accuracy, and speed up the process of coding order blocks, we have released the "Order Block Drawing" library.

Below, you can read more details about how to use this library.


This library has direct and indirect outputs. The indirect output includes the ranges of order blocks plotted on the chart. However, the direct output is a "Boolean" value that becomes "true" only when the price touches an order block, colloquially termed as "Mitigate." You can use this output for setting up alerts.

🔵How to Use

First, you can add the library to your code as shown in the example below.

import TFlab/OrderBlockDrawing_TradingFinder/1


OBDrawing(OBType, TriggerCondition, DistalPrice, ProximalPrice, Index, OBValidDis, Show, ColorZone) =>


• OBType (string) 
• TriggerCondition (bool) 
• DistalPrice (float) 
• ProximalPrice (float) 
• Index (int) 
• OBValidDis (int) 
• Show (bool) 
• ColorZone (color)

OBType: All order blocks are summarized into two types: "Supply" and "Demand." You should input your order block type in this parameter. Enter "Demand" for drawing demand zones and "Supply" for drawing supply zones.

TriggerCondition: Input the condition under which you want the order block to be drawn in this parameter.

DistalPrice: Generally, if each zone is formed by two lines, the farthest line from the price is termed "Distal." This input receives the price of the "Distal" line.

ProximalPrice: Generally, if each zone is formed by two lines, the nearest line to the price is termed "Proximal" line.

Index: This input receives the value of the "bar_index" at the beginning of the order block. You should store the "bar_index" value at the occurrence of the condition for the order block to be drawn and input it here.

OBValidDis: Order blocks continue to be drawn until a new order block is drawn or the order block is "Mitigate." You can specify how many candles after their initiation order blocks should continue. If you want no limitation, enter the number 4998.

Show: You may need to manage whether to display or hide order blocks. When this input is "On", order blocks are displayed, and when it's "Off", order blocks are not displayed.

ColorZone: You can input your preferred color for drawing order blocks.

🔵Function Outputs

This function has only one output. This output is of type "Boolean" and becomes "true" only when the price touches an order block. Each order block can be touched only once and then loses its validity. You can use this output for alerts.

[Demand_Zone_Alert] = Drawing.OBDrawing('Demand',  Condition,  Distal, Proximal, Index, 4998, true, Color)
Информация о релизе:

New Update: New Feature and Fixed Bug

🔵Fixed Bug

There was a bug in the mitigation process that sometimes caused an alarm not to be issued despite the proximal level being mitigated. This bug has been fixed.

🔵New Feature

Order Block Drawing Control:
From now on, you can manage the drawing Order Block. For example, if you need the drawing of the Order Block to stop before the predicted natural states, you can enter that condition in the function so that the drawing of the Order Block will stop when it happens.

Mitigation Level Management:
From now on, you can choose yourself whether the trigger will happen at the "Proximal", "Distal" or "50 % OB" level. This feature helps you to have more customization in your strategy logic.

Show All Order Block:

In the previous version, you had no control over whether or not to display the last Order Block. Using this feature, you can choose to display only the last Order Block or display all Order Block.

OBDrawing(OBType, TriggerCondition, distalPrice, proximalPrice, Index, OBValidGlobal, OBValidDis, MitigationLvL, ShowAll, Show, ColorZone)
    OBType (string)
    TriggerCondition (bool)
    distalPrice (float)
    proximalPrice (float)
    Index (int)
    OBValidGlobal (bool)
    OBValidDis (int)
    MitigationLvL (string)
    ShowAll (bool)
    Show (bool)
    ColorZone (color)

🔵New Parameters

OBValidGlobal (bool): This parameter is a boolean in which you can enter the condition that you want to execute to stop drawing the block order. If you do not have a special condition, you should set it to True.

MitigationLvL (string): This parameter is a string. Its inputs are one of "Proximal", "Distal" or "50 % OB" modes, which you can enter according to your needs. The "50 % OB" line is the middle line between distal and proximal.

ShowAll (bool): This is a boolean parameter, if it is "true" the entire order of blocks will be displayed, and if it is "false" only the last block order will be displayed.

Библиотека Pine

В истинном духе TradingView автор опубликовал этот код Pine как библиотеку с открытым исходным кодом, чтобы другие разработчики Pine из нашего сообщества могли использовать его повторно. Поблагодарим автора! Вы можете использовать эту библиотеку приватно или в других публикациях с открытым исходным кодом, но повторное использование этого кода в публикации регулируется Правилами поведения.

Отказ от ответственности

Все виды контента, которые вы можете увидеть на TradingView, не являются финансовыми, инвестиционными, торговыми или любыми другими рекомендациями. Мы не предоставляем советы по покупке и продаже активов. Подробнее — в Условиях использования TradingView.

Хотите использовать эту библиотеку?

Скопируйте текст в буфер обмена и вставьте в свой скрипт.