Source code for lightningchart_trader.drawing_tools.trend_line

from lightningchart_trader.drawing_tools import DrawingToolBase


[docs] class TrendLine(DrawingToolBase): def __init__( self, trader, startX, startY, endX=None, endY=None, lineColor='#000000', lineWidth=1, ): super().__init__(trader) self.instance.send( self.id, 'addTrendLine', { 'traderID': trader.id, 'startX': startX, 'startY': startY, 'endX': endX, 'endY': endY, 'lineColor': lineColor, 'lineWidth': lineWidth, }, )
[docs] def set_line_color(self, color: str): """Sets the color of the Trend Line. Args: color (str): New line color as string, should be in HEX format e.g. #FFFFFF. """ self.instance.send(self.id, 'setLineColor', {'color': color}) return self
[docs] def set_line_width(self, width: int | float): """Sets the width of the Trend Line. Args: width (int | float): New line width. """ self.instance.send(self.id, 'setLineWidth', {'width': width}) return self
[docs] def set_magnetic(self, is_magnetic: bool): """Sets whether the drawing tool should automatically snap to OHLC data points. Args: is_magnetic (bool): Set true to enable snapping to data points. """ self.instance.send(self.id, 'setMagnetic', {'isMagnetic': is_magnetic}) return self
[docs] def update_position( self, startX: int | float, startY: int | float, endX: int | float, endY: int | float, ): """Updates the drawing tool based on the control points' locations. Args: startX (int | float): Starting point X location. startY (int | float): Starting point Y location. endX (int | float): End point X location. endY (int | float): End point Y location. """ self.instance.send( self.id, 'updateTrendLinePosition', {'startX': startX, 'startY': startY, 'endX': endX, 'endY': endY}, ) return self