From 3eb81076c904e43cbe3eeb56024f7aa273869e83 Mon Sep 17 00:00:00 2001 From: James Ball <42615415+jadball@users.noreply.github.com> Date: Thu, 26 Sep 2024 11:02:12 +0200 Subject: [PATCH] Fix bug with specifying frame in frelon seg gui --- ImageD11/nbGui/segmenter_gui.py | 27 +++++++++++++-------------- 1 file changed, 13 insertions(+), 14 deletions(-) diff --git a/ImageD11/nbGui/segmenter_gui.py b/ImageD11/nbGui/segmenter_gui.py index de23b10d..01dc60d7 100644 --- a/ImageD11/nbGui/segmenter_gui.py +++ b/ImageD11/nbGui/segmenter_gui.py @@ -172,19 +172,18 @@ def chooseframe(self, counter): ds = self.dset if self.scan is None: self.scan = ds.scans[len(ds.scans)//2] - if self.idx is not None: - return - # Locate a busy image to look at - with h5py.File(ds.masterfile,'r') as hin: - ctr = ds.detector+counter - if self.scan.find("::") > -1: # 1.1::[10000:12000] etc - lo, hi = [int(v) for v in self.scan[:-1].split("[")[1].split(":")] - self.scan = self.scan.split("::")[0] - roi1 = hin[self.scan]['measurement'][ctr][lo:hi] - self.idx = np.argmax(roi1) + lo - else: # "1.1" - roi1 = hin[self.scan]['measurement'][ctr][:] - self.idx = np.argmax(roi1) + if self.idx is None: + # Locate a busy image to look at + with h5py.File(ds.masterfile,'r') as hin: + ctr = ds.detector+counter + if self.scan.find("::") > -1: # 1.1::[10000:12000] etc + lo, hi = [int(v) for v in self.scan[:-1].split("[")[1].split(":")] + self.scan = self.scan.split("::")[0] + roi1 = hin[self.scan]['measurement'][ctr][lo:hi] + self.idx = np.argmax(roi1) + lo + else: # "1.1" + roi1 = hin[self.scan]['measurement'][ctr][:] + self.idx = np.argmax(roi1) print("Using frame", self.idx, "from scan", self.scan) with h5py.File(self.dset.masterfile, 'r') as h5In: self.raw_image = h5In[self.scan + '/measurement/' + ds.detector][self.idx].astype('uint16') @@ -230,4 +229,4 @@ def update_image(self, threshold, smoothsigma, bgc, minpx, m_offset_thresh, m_ra def getopts(self): opts = { name: self.options[name] for name in ('bgfile','maskfile','threshold','smoothsigma','bgc','minpx','m_offset_thresh','m_ratio_thresh') } print("options = ",repr(opts)) - return opts \ No newline at end of file + return opts