From e82286c33d78904c6b6f69b3983b79f943da9f74 Mon Sep 17 00:00:00 2001 From: Marko Toplak Date: Wed, 24 Aug 2022 22:37:18 +0200 Subject: [PATCH] owhyper: consolidate duplicated vector plot drawing code --- orangecontrib/spectroscopy/widgets/owhyper.py | 68 ++++++++----------- 1 file changed, 30 insertions(+), 38 deletions(-) diff --git a/orangecontrib/spectroscopy/widgets/owhyper.py b/orangecontrib/spectroscopy/widgets/owhyper.py index 7b89e677d..7754b0a28 100644 --- a/orangecontrib/spectroscopy/widgets/owhyper.py +++ b/orangecontrib/spectroscopy/widgets/owhyper.py @@ -624,6 +624,9 @@ def __init__(self, parent): self.data_values = None self.data_imagepixels = None self.data_valid_positions = None + self.vector_data = None + self.xindex = None + self.yindex = None self.plotview = pg.GraphicsLayoutWidget() self.plot = pg.PlotItem(background="w", viewBox=InteractiveViewBox(self)) @@ -846,6 +849,9 @@ def update_view(self): self.data_values = None self.data_imagepixels = None self.data_valid_positions = None + self.vector_data = None + self.xindex = None + self.yindex = None if self.data and self.attr_x and self.attr_y: self.start(self.compute_image, self.data, self.attr_x, self.attr_y, @@ -873,19 +879,25 @@ def set_visible_image_opacity(self, opacity: int): def set_visible_image_comp_mode(self, comp_mode: QPainter.CompositionMode): self.vis_img.setCompositionMode(comp_mode) - def set_vector_colour(self, pen): + def update_vector_colour(self): if hasattr(self, 'c'): + pen = self.parent.get_vector_colour() self.c.setPen(pen) - def set_vector_scale(self, scale): - if self.v is not None: - th = self.v[:,0] - v_mag = self.v[:,1] - amp = v_mag / max(v_mag) * (scale/100) # TODO, new setting: range - wy = self.shifty*2 - wx = self.shiftx*2 - y = np.linspace(*self.lsy)[self.yindex[self.valid]] - x = np.linspace(*self.lsx)[self.xindex[self.valid]] + def update_vectors(self): + v = self.vector_data + if v is not None: + valid = self.data_valid_positions + lsx, lsy = self.lsx, self.lsy + xindex, yindex = self.xindex, self.yindex + scale = self.parent.vector_scale + th = v[:,0] + v_mag = v[:,1] + amp = v_mag / max(v_mag) * (scale/100) + wy = _shift(lsx)*2 + wx = _shift(lsx)*2 + y = np.linspace(*lsy)[yindex[valid]] + x = np.linspace(*lsx)[xindex[valid]] dispx = amp*wx/2*np.cos(np.radians(th)) dispy = amp*wy/2*np.sin(np.radians(th)) xcurve = np.empty((dispx.shape[0]*2)) @@ -994,36 +1006,17 @@ def on_done(self, res): height = (lsy[1]-lsy[0]) + 2*shifty self.img.setRect(QRectF(left, bottom, width, height)) - vector_scale = self.parent.vector_scale - vector_colour = self.parent.get_vector_colour() + self.vector_data = v + self.yindex = yindex + self.xindex = xindex if self.data and v is not None: - th = v[:,0] - v_mag = v[:,1] - amp = v_mag / max(v_mag) * (vector_scale/100) - wy = shifty*2 - wx = shiftx*2 - y = np.linspace(*lsy)[yindex[valid]] - x = np.linspace(*lsx)[xindex[valid]] - dispx = amp*wx/2*np.cos(np.radians(th)) - dispy = amp*wy/2*np.sin(np.radians(th)) - xcurve = np.empty((dispx.shape[0]*2)) - ycurve = np.empty((dispy.shape[0]*2)) - xcurve[0::2], xcurve[1::2] = x - dispx, x + dispx - ycurve[0::2], ycurve[1::2] = y - dispy, y + dispy - connect = np.ones((dispx.shape[0]*2)) - connect[1::2] = 0 - self.c = pg.PlotCurveItem(x=xcurve, y=ycurve, connect=connect, pen=vector_colour) + self.c = pg.PlotCurveItem() + self.update_vectors() + self.update_vector_colour() self.p_markings.append(self.c) self.plot.addItem(self.c) - self.v = v - self.shifty = shifty - self.shiftx = shiftx - self.valid = valid - self.yindex = yindex - self.xindex = xindex - self.refresh_img_selection() self.image_updated.emit() @@ -1289,11 +1282,10 @@ def get_vector_colour(self): return vector_colour[self.vector_colour_index][1][0] + (self.vector_opacity,) def update_vector_colour(self): - vc = self.get_vector_colour() - self.imageplot.set_vector_colour(vc) + self.imageplot.update_vector_colour() def update_vector_scale(self): - self.imageplot.set_vector_scale(self.vector_scale) + self.imageplot.update_vectors() def init_vector_plot(self, data): domain = data.domain if data is not None else None