Merge branch 'develop' into feature/obspy_dmt_interface
This commit is contained in:
commit
10c26a8261
30
PyLoT.py
30
PyLoT.py
@ -1665,6 +1665,35 @@ class MainWindow(QMainWindow):
|
|||||||
metadata=self.metadata,
|
metadata=self.metadata,
|
||||||
obspy_dmt=obspy_dmt)
|
obspy_dmt=obspy_dmt)
|
||||||
|
|
||||||
|
def check_plot_quantity(self):
|
||||||
|
settings = QSettings()
|
||||||
|
nth_sample = settings.value("nth_sample") if settings.value("nth_sample") else 1
|
||||||
|
npts_max = 1e6
|
||||||
|
npts = self.get_npts_to_plot()
|
||||||
|
npts2plot = npts/nth_sample
|
||||||
|
if npts2plot < npts_max:
|
||||||
|
return
|
||||||
|
nth_sample_new = int(np.ceil(npts/npts_max))
|
||||||
|
message = "You are about to plot a huge dataset with {npts} datapoints. With a current setting of " \
|
||||||
|
"nth_sample = {nth_sample} a total of {npts2plot} points will be plotted which is more " \
|
||||||
|
"than the maximum setting of {npts_max}. " \
|
||||||
|
"PyLoT recommends to raise nth_sample from {nth_sample} to {nth_sample_new}. Continue?"
|
||||||
|
|
||||||
|
ans = QMessageBox.question(self, self.tr("Optimize plot performance..."),
|
||||||
|
self.tr(message.format(npts=npts,
|
||||||
|
nth_sample=nth_sample,
|
||||||
|
npts_max=npts_max,
|
||||||
|
nth_sample_new=nth_sample_new,
|
||||||
|
npts2plot=npts2plot)),
|
||||||
|
QMessageBox.Yes | QMessageBox.No,
|
||||||
|
QMessageBox.Yes)
|
||||||
|
if ans == QMessageBox.Yes:
|
||||||
|
settings.setValue("nth_sample", nth_sample_new)
|
||||||
|
settings.sync()
|
||||||
|
|
||||||
|
def get_npts_to_plot(self):
|
||||||
|
return sum(trace.stats.npts for trace in self.data.getWFData())
|
||||||
|
|
||||||
def connectWFplotEvents(self):
|
def connectWFplotEvents(self):
|
||||||
'''
|
'''
|
||||||
Connect signals refering to WF-Dataplot (select station, tutor_user, scrolling)
|
Connect signals refering to WF-Dataplot (select station, tutor_user, scrolling)
|
||||||
@ -1831,6 +1860,7 @@ class MainWindow(QMainWindow):
|
|||||||
'''
|
'''
|
||||||
Open a modal thread to plot current waveform data.
|
Open a modal thread to plot current waveform data.
|
||||||
'''
|
'''
|
||||||
|
self.check_plot_quantity()
|
||||||
self.clearWaveformDataPlot()
|
self.clearWaveformDataPlot()
|
||||||
self.wfp_thread = Thread(self, self.plotWaveformData,
|
self.wfp_thread = Thread(self, self.plotWaveformData,
|
||||||
arg=filter,
|
arg=filter,
|
||||||
|
Loading…
Reference in New Issue
Block a user