本文整理匯總了Python中pyqtgraph.ArrowItem方法的典型用法代碼示例。如果您正苦於以下問題:Python pyqtgraph.ArrowItem方法的具體用法?Python pyqtgraph.ArrowItem怎麽用?Python pyqtgraph.ArrowItem使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類pyqtgraph
的用法示例。
在下文中一共展示了pyqtgraph.ArrowItem方法的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: plotMark
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import ArrowItem [as 別名]
def plotMark(self):
"""顯示開平倉信號"""
# 檢查是否有數據
if len(self.datas)==0:
return
for arrow in self.arrows:
self.pwKL.removeItem(arrow)
# 畫買賣信號
for i in range(len(self.listSig)):
# 無信號
if self.listSig[i] == 0:
continue
# 買信號
elif self.listSig[i] > 0:
arrow = pg.ArrowItem(pos=(i, self.datas[i]['low']), angle=90, brush=(255, 0, 0))
# 賣信號
elif self.listSig[i] < 0:
arrow = pg.ArrowItem(pos=(i, self.datas[i]['high']), angle=-90, brush=(0, 255, 0))
self.pwKL.addItem(arrow)
self.arrows.append(arrow)
#----------------------------------------------------------------------
示例2: initplotKline
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import ArrowItem [as 別名]
def initplotKline(self):
"""Kline"""
self.pw2 = pg.PlotWidget(name='Plot2') # K線圖
self.vbl_2.addWidget(self.pw2)
self.pw2.setDownsampling(mode='peak')
self.pw2.setClipToView(True)
self.curve5 = self.pw2.plot()
self.curve6 = self.pw2.plot()
self.candle = self.CandlestickItem(self.listBar)
self.pw2.addItem(self.candle)
## Draw an arrowhead next to the text box
# self.arrow = pg.ArrowItem()
# self.pw2.addItem(self.arrow)
#----------------------------------------------------------------------
示例3: plotText
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import ArrowItem [as 別名]
def plotText(self):
lenClose = len(self.listClose)
if lenClose >= 5: # Fractal Signal
if self.listClose[-1] > self.listClose[-2] and self.listClose[-3] > self.listClose[-2] and self.listClose[-4] > self.listClose[-2] and self.listClose[-5] > self.listClose[-2] and self.listfastEMA[-1] > self.listslowEMA[-1]:
## Draw an arrowhead next to the text box
# self.pw2.removeItem(self.arrow)
self.arrow = pg.ArrowItem(pos=(lenClose-1, self.listLow[-1]), angle=90, brush=(255, 0, 0))
self.pw2.addItem(self.arrow)
elif self.listClose[-1] < self.listClose[-2] and self.listClose[-3] < self.listClose[-2] and self.listClose[-4] < self.listClose[-2] and self.listClose[-5] < self.listClose[-2] and self.listfastEMA[-1] < self.listslowEMA[-1]:
## Draw an arrowhead next to the text box
# self.pw2.removeItem(self.arrow)
self.arrow = pg.ArrowItem(pos=(lenClose-1, self.listHigh[-1]), angle=-90, brush=(0, 255, 0))
self.pw2.addItem(self.arrow)
#----------------------------------------------------------------------
示例4: plotText
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import ArrowItem [as 別名]
def plotText(self):
"""開平倉信號"""
lenClose = len(self.listClose)
if lenClose >= 5: # Fractal Signal
if self.listClose[-1] > self.listClose[-2] and self.listClose[-3] > self.listClose[-2] and self.listClose[-4] > self.listClose[-2] and self.listClose[-5] > self.listClose[-2] and self.listfastEMA[-1] > self.listslowEMA[-1]:
## Draw an arrowhead next to the text box
# self.pw2.removeItem(self.arrow)
self.arrow = pg.ArrowItem(pos=(lenClose-1, self.listLow[-1]), angle=90, brush=(255, 0, 0))
self.pw2.addItem(self.arrow)
elif self.listClose[-1] < self.listClose[-2] and self.listClose[-3] < self.listClose[-2] and self.listClose[-4] < self.listClose[-2] and self.listClose[-5] < self.listClose[-2] and self.listfastEMA[-1] < self.listslowEMA[-1]:
## Draw an arrowhead next to the text box
# self.pw2.removeItem(self.arrow)
self.arrow = pg.ArrowItem(pos=(lenClose-1, self.listHigh[-1]), angle=-90, brush=(0, 255, 0))
self.pw2.addItem(self.arrow)
#----------------------------------------------------------------------
示例5: plotIndex_LIMIT
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import ArrowItem [as 別名]
def plotIndex_LIMIT (self):
"""畫指標"""
# 檢查是否有數據
if len(self.KLINE_SHORT_TERM_LIST_LIMIT)==0 :
self.refresh()
return
for arrow in self.KLINE_SHORT_TERM_LIST_LIMIT_arrows:
self.pwKL.removeItem(arrow)
for curves in self.KLINE_SHORT_TERM_LIST_LIMIT_curves:
self.pwKL.removeItem(curves)
for i in range(len(self.KLINE_SHORT_TERM_LIST_LIMIT)):
if self.KLINE_SHORT_TERM_LIST_LIMIT[i] == 1:
arrow = pg.ArrowItem(pos=(i, self.datas[i]['low']), size=7,tipAngle=55,tailLen=3,tailWidth=4, angle=90, brush=(34, 139, 34),pen=({'color': "228B22", 'width': 1}))
self.pwKL.addItem(arrow)
self.KLINE_SHORT_TERM_LIST_LIMIT_arrows.append(arrow)
if self.KLINE_SHORT_TERM_LIST_LIMIT[i] == 2:
arrow = pg.ArrowItem(pos=(i, self.datas[i]['high']),size=7,tipAngle=55,tailLen=3,tailWidth=4 ,angle=-90, brush=(34, 139, 34),pen=({'color': "228B22", 'width': 1}))
self.pwKL.addItem(arrow)
self.KLINE_SHORT_TERM_LIST_LIMIT_arrows.append(arrow)
last_x=-1 #上一個x
last_y=-1 #上一個y
last_v=-1
for i in range(len(self.KLINE_SHORT_TERM_LIST_LIMIT)):
if self.KLINE_SHORT_TERM_LIST_LIMIT[i] != 0 :
if last_x!=-1 and last_y!=-1 and last_v!=self.KLINE_SHORT_TERM_LIST_LIMIT[i] and\
((last_v == 1 and self.KLINE_SHORT_TERM_LIST_LIMIT[i] == 2) and self.KLINE_LOW[last_x]<self.KLINE_HIGH[i]) or\
((last_v == 2 and self.KLINE_SHORT_TERM_LIST_LIMIT[i] == 1) and self.KLINE_HIGH[last_x]>self.KLINE_LOW[i]):
curve = pg.PlotCurveItem(x=np.array([last_x,i]),y=np.array([last_y,self.datas[i]['low'] if self.KLINE_SHORT_TERM_LIST_LIMIT[i]==1 else self.datas[i]['high']]),name='duo',pen=({'color': "228B22", 'width': 1}))
self.pwKL.addItem(curve)
self.KLINE_SHORT_TERM_LIST_LIMIT_curves.append(curve)
last_x =i
if self.KLINE_SHORT_TERM_LIST_LIMIT[i] ==1 :
last_y=self.datas[i]['low']
elif self.KLINE_SHORT_TERM_LIST_LIMIT[i] ==2 :
last_y=self.datas[i]['high']
last_v=self.KLINE_SHORT_TERM_LIST_LIMIT[i]
#----------------------------------------------------------------------
示例6: plotIndex_ALL
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import ArrowItem [as 別名]
def plotIndex_ALL (self):
"""畫指標"""
# 檢查是否有數據
if len(self.KLINE_SHORT_TERM_LIST_ALL)==0 :
self.refresh()
return
for arrow in self.KLINE_SHORT_TERM_LIST_ALL_arrows:
self.pwKL.removeItem(arrow)
for curves in self.KLINE_SHORT_TERM_LIST_ALL_curves:
self.pwKL.removeItem(curves)
for i in range(len(self.KLINE_SHORT_TERM_LIST_ALL)):
if self.KLINE_SHORT_TERM_LIST_ALL[i] == 1:
arrow = pg.ArrowItem(pos=(i, self.datas[i]['low']), size=7,tipAngle=55,tailLen=3,tailWidth=4, angle=90, brush=(225, 0, 225),pen=({'color': "FF00FF", 'width': 1}))
self.pwKL.addItem(arrow)
self.KLINE_SHORT_TERM_LIST_ALL_arrows.append(arrow)
if self.KLINE_SHORT_TERM_LIST_ALL[i] == 2:
arrow = pg.ArrowItem(pos=(i, self.datas[i]['high']),size=7,tipAngle=55,tailLen=3,tailWidth=4 ,angle=-90, brush=(225, 0, 225),pen=({'color': "FF00FF", 'width': 1}))
self.pwKL.addItem(arrow)
self.KLINE_SHORT_TERM_LIST_ALL_arrows.append(arrow)
last_x=-1 #上一個x
last_y=-1 #上一個y
last_v=-1
for i in range(len(self.KLINE_SHORT_TERM_LIST_ALL)):
if self.KLINE_SHORT_TERM_LIST_ALL[i] != 0 :
if last_x!=- 1 and last_y!=-1 and \
((last_v == 1 and self.KLINE_SHORT_TERM_LIST_ALL[i] == 2) and self.KLINE_LOW[last_x]<self.KLINE_HIGH[i]) or \
((last_v == 2 and self.KLINE_SHORT_TERM_LIST_ALL[i] == 1) and self.KLINE_HIGH[last_x]>self.KLINE_LOW[i]) or \
((last_v == 1 and self.KLINE_SHORT_TERM_LIST_ALL[i] == 1)) or \
((last_v == 2 and self.KLINE_SHORT_TERM_LIST_ALL[i] == 2)) :
curve = pg.PlotCurveItem(x=np.array([last_x,i]),y=np.array([last_y,self.datas[i]['low'] if self.KLINE_SHORT_TERM_LIST_ALL[i]==1 else self.datas[i]['high']]),name='duo',pen=({'color': "FF00FF", 'width': 1}))
self.pwKL.addItem(curve)
self.KLINE_SHORT_TERM_LIST_ALL_curves.append(curve)
last_x =i
if self.KLINE_SHORT_TERM_LIST_ALL[i] ==1 :
last_y=self.datas[i]['low']
elif self.KLINE_SHORT_TERM_LIST_ALL[i] ==2 :
last_y=self.datas[i]['high']
last_v=self.KLINE_SHORT_TERM_LIST_ALL[i]
#----------------------------------------------------------------------
示例7: plotIndex_FIRST
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import ArrowItem [as 別名]
def plotIndex_FIRST (self):
"""畫指標"""
# 檢查是否有數據
if len(self.KLINE_SHORT_TERM_LIST_FIRST)==0 :
self.refresh()
return
for arrow in self.KLINE_SHORT_TERM_LIST_FIRST_arrows:
self.pwKL.removeItem(arrow)
for curves in self.KLINE_SHORT_TERM_LIST_FIRST_curves:
self.pwKL.removeItem(curves)
for i in range(len(self.KLINE_SHORT_TERM_LIST_FIRST)):
if self.KLINE_SHORT_TERM_LIST_FIRST[i] == 1:
arrow = pg.ArrowItem(pos=(i, self.datas[i]['low']), size=7,tipAngle=55,tailLen=3,tailWidth=4, angle=90, brush=(225, 255, 0),pen=({'color': "FFFF00", 'width': 1}))
self.pwKL.addItem(arrow)
self.KLINE_SHORT_TERM_LIST_FIRST_arrows.append(arrow)
if self.KLINE_SHORT_TERM_LIST_FIRST[i] == 2:
arrow = pg.ArrowItem(pos=(i, self.datas[i]['high']),size=7,tipAngle=55,tailLen=3,tailWidth=4 ,angle=-90, brush=(225, 255, 0),pen=({'color': "FFFF00", 'width': 1}))
self.pwKL.addItem(arrow)
self.KLINE_SHORT_TERM_LIST_FIRST_arrows.append(arrow)
last_x=-1 #上一個x
last_y=-1 #上一個y
last_v=-1
for i in range(len(self.KLINE_SHORT_TERM_LIST_FIRST)):
if self.KLINE_SHORT_TERM_LIST_FIRST[i] != 0 :
if last_x!=-1 and last_y!=-1 and last_v!=self.KLINE_SHORT_TERM_LIST_FIRST[i] and\
((last_v == 1 and self.KLINE_SHORT_TERM_LIST_FIRST[i] == 2) and self.KLINE_LOW[last_x]<self.KLINE_HIGH[i]) or\
((last_v == 2 and self.KLINE_SHORT_TERM_LIST_FIRST[i] == 1) and self.KLINE_HIGH[last_x]>self.KLINE_LOW[i]):
curve = pg.PlotCurveItem(x=np.array([last_x,i]),y=np.array([last_y,self.datas[i]['low'] if self.KLINE_SHORT_TERM_LIST_FIRST[i]==1 else self.datas[i]['high']]),name='duo',pen=({'color': "FFFF00", 'width': 1}))
self.pwKL.addItem(curve)
self.KLINE_SHORT_TERM_LIST_FIRST_curves.append(curve)
last_x =i
if self.KLINE_SHORT_TERM_LIST_FIRST[i] ==1 :
last_y=self.datas[i]['low']
elif self.KLINE_SHORT_TERM_LIST_FIRST[i] ==2 :
last_y=self.datas[i]['high']
last_v=self.KLINE_SHORT_TERM_LIST_FIRST[i]
#----------------------------------------------------------------------
示例8: plot_WAIBAORI
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import ArrowItem [as 別名]
def plot_WAIBAORI(self):
"""畫外包日箭頭"""
# 檢查是否有數據
if len(self.KLINE_WAIBAORI)==0 :
self.refresh()
return
for arrow in self.KLINE_WAI_BAO_RI_arrows:
self.pwKL.removeItem(arrow)
for i in range(len(self.KLINE_WAIBAORI)):
if self.KLINE_WAIBAORI[i] == 1:
arrow = pg.ArrowItem(pos=(i, self.datas[i]['low']-100), size=7,tipAngle=55,tailLen=3,tailWidth=4, angle=90, brush=(255, 255, 0),pen=({'color': "FF0000", 'width': 1}))
self.pwKL.addItem(arrow)
self.KLINE_WAI_BAO_RI_arrows.append(arrow)
#----------------------------------------------------------------------
示例9: plot_GJR_SELL
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import ArrowItem [as 別名]
def plot_GJR_SELL(self):
"""畫攻擊日賣出箭頭"""
# 檢查是否有數據
if len(self.KLINE_GJR_SELL)==0 :
self.refresh()
return
for arrow in self.KLINE_GJR_SELL_arrows:
self.pwKL.removeItem(arrow)
for i in range(len(self.KLINE_GJR_SELL)):
if self.KLINE_GJR_SELL[i] == 1:
arrow = pg.ArrowItem(pos=(i, self.datas[i]['high']+50), size=7,tipAngle=55,tailLen=3,tailWidth=4, angle=-90, brush=("C0FF3E"),pen=({'color': "C0FF3E", 'width': 1}))
self.pwKL.addItem(arrow)
self.KLINE_GJR_SELL_arrows.append(arrow)
#----------------------------------------------------------------------
示例10: __init__
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import ArrowItem [as 別名]
def __init__(self, model):
pg.GraphicsWidget.__init__(self)
pg.GraphicsWidgetAnchor.__init__(self)
self.model = model
self.arrow = pg.ArrowItem(
parent=self,
angle=0.,
brush=(0, 0, 0, 180),
pen=(255, 255, 255),
pxMode=True)
self.label = pg.LabelItem(
'Towards Sat.',
justify='right', size='8pt',
parent=self)
self.label.anchor(
itemPos=(1., -1.),
parentPos=(1., 0.))
# self.label.setBrush(pg.mkBrush(255, 255, 255, 180))
# self.label.setFont(QtGui.QFont(
# "Helvetica", weight=QtGui.QFont.DemiBold))
self.orientArrow()
self.model.sigSceneChanged.connect(self.orientArrow)
self.setFlag(self.ItemIgnoresTransformations)
示例11: initplotKline
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import ArrowItem [as 別名]
def initplotKline(self):
"""Kline"""
s = self.data.index #橫坐標值
print "numbers of KLine: ", len(s)
xdict = dict(enumerate(s))
self.__axisTime = MyStringAxis(xdict, orientation='bottom')
self.pw2 = pg.PlotWidget(axisItems={'bottom': self.__axisTime}) # K線圖
pw2x = self.pw2.getAxis('bottom')
pw2x.setGrid(150) # 設置默認x軸網格
pw2y = self.pw2.getAxis('left')
pw2y.setGrid(150) # 設置默認y軸網格
self.vbl_1.addWidget(self.pw2)
self.pw2.setMinimumWidth(1500)
self.pw2.setMaximumWidth(1800)
self.pw2.setDownsampling(mode='peak')
self.pw2.setClipToView(True)
self.curve5 = self.pw2.plot()
self.curve6 = self.pw2.plot()
self.candle = self.CandlestickItem(self.listBar)
self.pw2.addItem(self.candle)
## Draw an arrowhead next to the text box
# self.arrow = pg.ArrowItem()
# self.pw2.addItem(self.arrow)
# 從數據庫讀取一分鍾數據畫分鍾線
示例12: plotMark
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import ArrowItem [as 別名]
def plotMark(self):
"""顯示開平倉信號"""
# 檢查是否有數據
if len(self.datas)==0:
return
for arrow in self.arrows:
self.pwKL.removeItem(arrow)
for curve in self.curves:
self.pwKL.removeItem(curve)
# 畫買賣信號
lastbk_x=-1 #上一個買開的x
lastbk_y=-1 #上一個買開的y
lastsk_x=-1 #上一個賣開的x
lastsk_y=-1 #上一個賣開的y
for i in range(len(self.listSig_deal_DIRECTION)):
# 無信號
if cmp(self.listSig_deal_DIRECTION[i] , '-')== 0 or cmp(self.listSig_deal_OFFSET[i] , '-') == 0:
continue
# 買開信號
elif cmp(self.listSig_deal_DIRECTION[i] , '多')==0 and cmp(self.listSig_deal_OFFSET[i] , '開倉')==0 :
arrow = pg.ArrowItem(pos=(i, self.datas[i]['low']), size=7,tipAngle=55,tailLen=3,tailWidth=4, angle=90, brush=(255, 0, 0),pen=({'color': "r", 'width': 1}))
lastbk_x = i
lastbk_y = self.datas[i]['close']
# 賣平信號
elif cmp(self.listSig_deal_DIRECTION[i] , '空')==0 and cmp(self.listSig_deal_OFFSET[i] , '平倉')==0 :
arrow = pg.ArrowItem(pos=(i, self.datas[i]['high']),size=7,tipAngle=55,tailLen=3,tailWidth=4 ,angle=-90, brush=(0, 0, 0),pen=({'color': "g", 'width': 1}))
if lastbk_x !=-1:
curve = pg.PlotCurveItem(x=np.array([lastbk_x,i]),y=np.array([lastbk_y,self.datas[i][self.SP_signal]]),name='duo',pen=({'color': "r", 'width': 3}))
self.pwKL.addItem(curve)
self.curves.append(curve)
lastbk_x = -1
# 賣開信號
elif cmp(self.listSig_deal_DIRECTION[i] , '空')==0 and cmp(self.listSig_deal_OFFSET[i] , '開倉')==0 :
arrow = pg.ArrowItem(pos=(i, self.datas[i]['high']),size=7,tipAngle=55,tailLen=3,tailWidth=4,angle=-90, brush=(0, 255, 0),pen=({'color': "g", 'width': 1}))
lastsk_x = i
lastsk_y = self.datas[i]['close']
# 買平信號
elif cmp(self.listSig_deal_DIRECTION[i] , '多')==0 and cmp(self.listSig_deal_OFFSET[i] , '平倉')==0 :
arrow = pg.ArrowItem(pos=(i, self.datas[i]['low']),size=7,tipAngle=55,tailLen=3,tailWidth=4 ,angle=90, brush=(0, 0, 0),pen=({'color': "r", 'width': 1}))
if lastsk_x !=-1:
curve = pg.PlotCurveItem(x=np.array([lastsk_x,i]),y=np.array([lastsk_y,self.datas[i][self.BP_signal]]),pen=({'color': "g", 'width': 3}))
self.pwKL.addItem(curve)
self.curves.append(curve)
lastsk_x = -1
self.pwKL.addItem(arrow)
self.arrows.append(arrow)
#----------------------------------------------------------------------
示例13: add_signal
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import ArrowItem [as 別名]
def add_signal(self, t_value, direction, offset, price, volume):
"""
增加信號
:param t_value:
:param direction:
:param offset:
:param price:
:param volume:
:return:
"""
# 找到信號時間最貼近的bar x軸
x = self.axisTime.get_x_by_time(t_value)
need_plot_arrow = False
# 修正一下 信號時間,改為bar的時間
if x not in self.x_t_trade_map:
bar_time = self.axisTime.xdict.get(x, t_value)
else:
# 如果存在映射,就更新
bar_time = self.x_t_trade_map[x]
trade_node = self.t_trade_dict.get(bar_time, None)
if trade_node is None:
# 當前時間無交易信號
self.t_trade_dict[bar_time] = {'x': x, 'signals': [{'direction': direction, 'offset':offset,'price': price,'volume': volume}]}
self.x_t_trade_map[x] = bar_time
need_plot_arrow = True
else:
#match_signals = [t for t in trade_node['signals'] if t['direction'] == direction and t['offset'] == offset]
#if len(match_signals) == 0:
need_plot_arrow = True
trade_node['signals'].append({'direction': direction, 'offset':offset, 'price': price, 'volume': volume})
self.x_t_trade_map[x] = bar_time
# 需要顯示圖標
if need_plot_arrow:
arrow = None
# 多信號
if direction == DIRECTION_LONG:
if offset == OFFSET_OPEN:
# buy
arrow = pg.ArrowItem(pos=(x, price), angle=135, brush=None, pen={'color':'r','width':1}, tipAngle=30, baseAngle=20, tailLen=10, tailWidth=2)
else:
# cover
arrow = pg.ArrowItem(pos=(x, price), angle=0, brush=(255, 0, 0),pen=None, headLen=20, headWidth=20, tailLen=10, tailWidth=2)
# 空信號
elif direction == DIRECTION_SHORT:
if offset == OFFSET_CLOSE:
# sell
arrow = pg.ArrowItem(pos=(x, price), angle=0, brush=(0, 255, 0),pen=None ,headLen=20, headWidth=20, tailLen=10, tailWidth=2)
else:
# short
arrow = pg.ArrowItem(pos=(x, price), angle=-135, brush=None, pen={'color':'g','width':1},tipAngle=30, baseAngle=20, tailLen=10, tailWidth=2)
if arrow:
self.pi_main.addItem(arrow)
self.list_trade_arrow.append(arrow)
示例14: add_signals
# 需要導入模塊: import pyqtgraph [as 別名]
# 或者: from pyqtgraph import ArrowItem [as 別名]
def add_signals(self):
self.signals_group_text = QtGui.QGraphicsItemGroup()
self.signals_group_arrow = QtGui.QGraphicsItemGroup()
self.signals_text_items = np.empty(len(Quotes), dtype=object)
for p in Portfolio.positions:
x, price = p.id_bar_open, p.open_price
if p.type == Order.BUY:
y = Quotes[x].low * 0.99
pg.ArrowItem(
parent=self.signals_group_arrow,
pos=(x, y),
pen=self.long_pen,
brush=self.long_brush,
angle=90,
headLen=12,
tipAngle=50,
)
text_sig = CenteredTextItem(
parent=self.signals_group_text,
pos=(x, y),
pen=self.long_pen,
brush=self.long_brush,
text=('Buy at {:.%df}' % self.digits).format(price),
valign=QtCore.Qt.AlignBottom,
)
text_sig.hide()
else:
y = Quotes[x].high * 1.01
pg.ArrowItem(
parent=self.signals_group_arrow,
pos=(x, y),
pen=self.short_pen,
brush=self.short_brush,
angle=-90,
headLen=12,
tipAngle=50,
)
text_sig = CenteredTextItem(
parent=self.signals_group_text,
pos=(x, y),
pen=self.short_pen,
brush=self.short_brush,
text=('Sell at {:.%df}' % self.digits).format(price),
valign=QtCore.Qt.AlignTop,
)
text_sig.hide()
self.signals_text_items[x] = text_sig
self.chart.addItem(self.signals_group_arrow)
self.chart.addItem(self.signals_group_text)
self.signals_visible = True