Wed 28 Aug 21:38:52 CEST 2024
This commit is contained in:
		
							parent
							
								
									3fabc632af
								
							
						
					
					
						commit
						30a38b6937
					
				
							
								
								
									
										135
									
								
								src/SimNDT/graphics/mplWidget.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										135
									
								
								src/SimNDT/graphics/mplWidget.py
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,135 @@ | |||
| #!/usr/bin/env python | ||||
| # encoding: utf-8 | ||||
| """ | ||||
| pltWidget.py | ||||
| 
 | ||||
| Created by Miguel Molero on 2013-09-20. | ||||
| Copyright (c) 2013 MMolero. All rights reserved. | ||||
| """ | ||||
| 
 | ||||
| from __future__ import unicode_literals | ||||
| import sys, os, random | ||||
| 
 | ||||
| os.environ['QT_API'] = 'pyside' | ||||
| 
 | ||||
| import matplotlib | ||||
| matplotlib.use('Qt4Agg') | ||||
| matplotlib.rcParams['backend.qt4']='PySide' | ||||
| from matplotlib.backends.backend_qt4agg import FigureCanvasQTAgg as FigureCanvas | ||||
| from matplotlib.backends.backend_qt4agg import NavigationToolbar2QT as NavigationToolbar | ||||
| from matplotlib.figure import Figure | ||||
| 
 | ||||
| 
 | ||||
| from PySide.QtGui	import * | ||||
| import numpy as np | ||||
| 
 | ||||
| 
 | ||||
| class NavigationToolbar(NavigationToolbar): | ||||
|     # only display the buttons we need | ||||
| 	print (sys.platform) | ||||
| 
 | ||||
| class MplCanvas(FigureCanvas): | ||||
| 	def __init__(self, parent=None, width=5, height=4, dpi=100): | ||||
| 
 | ||||
| 		self.fig  = Figure(figsize=(width, height), dpi=dpi) | ||||
| 		self.ax   = self.fig.add_subplot(111) | ||||
| 
 | ||||
| 		self.fig.patch.set_facecolor('white') | ||||
| 
 | ||||
| 		FigureCanvas.__init__(self, self.fig) | ||||
| 		self.setParent(parent) | ||||
| 		FigureCanvas.updateGeometry(self) | ||||
| 		self.setMinimumSize(250,250) | ||||
| 
 | ||||
| 
 | ||||
| class PlotDialog(QDialog): | ||||
| 	 | ||||
| 
 | ||||
| 	def __init__(self, parent=None, width=6, height=5, dpi=100): | ||||
| 		super(PlotDialog,self).__init__(parent) | ||||
| 		self.parent = parent | ||||
| 		 | ||||
| 		self.mpl = MplCanvas(self, width=width, height=height, dpi=dpi) | ||||
| 		self.mpl_toolbar = NavigationToolbar(self.mpl, self) | ||||
| 		 | ||||
| 		layout = QVBoxLayout() | ||||
| 		layout.addWidget(self.mpl) | ||||
| 		layout.addWidget(self.mpl_toolbar,0) | ||||
| 		 | ||||
| 		self.setLayout(layout) | ||||
| 		 | ||||
| 		 | ||||
| 		self.mpl.fig.patch.set_facecolor('white') | ||||
| 		 | ||||
| 		for item in ([self.mpl.ax.title, self.mpl.ax.xaxis.label, self.mpl.ax.yaxis.label] + | ||||
| 		             self.mpl.ax.get_xticklabels() + self.mpl.ax.get_yticklabels()): | ||||
| 		    item.set_fontsize(10) | ||||
| 		 | ||||
| 		 | ||||
| 		self.setWindowFlags(self.windowFlags() ) | ||||
| 		self.setWindowTitle(self.tr("Plot Inspection")) | ||||
| 		self.setMinimumSize(250,250) | ||||
| 		self.setMaximumSize(2000,1500) | ||||
| 		 | ||||
| 		 | ||||
| 		 | ||||
| class PlotInline(QDialog): | ||||
| 	 | ||||
| 	def __init__(self, parent=None): | ||||
| 		super(PlotInline, self).__init__(parent) | ||||
| 		 | ||||
| 		self.mpl = MplCanvas(self, width=6, height=2, dpi=100) | ||||
| 		layout = QVBoxLayout() | ||||
| 		layout.addWidget(self.mpl) | ||||
| 		self.setLayout(layout) | ||||
| 		 | ||||
| 	 | ||||
| 		self.mpl.fig.patch.set_facecolor('lightgray') | ||||
| 		for item in ([self.mpl.ax.title, self.mpl.ax.xaxis.label, self.mpl.ax.yaxis.label] + | ||||
| 		             self.mpl.ax.get_xticklabels() + self.mpl.ax.get_yticklabels()): | ||||
| 			item.set_fontsize(10) | ||||
| 			#item.set_color('white') | ||||
| 			 | ||||
| 			 | ||||
| 		#self.mpl.ax.spines['bottom'].set_color('white') | ||||
| 		#self.mpl.ax.spines['top'].set_color('white') | ||||
| 		#self.mpl.ax.spines['left'].set_color('white') | ||||
| 		#self.mpl.ax.spines['right'].set_color('white') | ||||
| 		 | ||||
| 		self.setWindowFlags(self.windowFlags() ) | ||||
| 		self.setWindowTitle(self.tr("Receiver Signal")) | ||||
| 		self.setMinimumSize(250,250) | ||||
| 		self.setMaximumSize(2000,1500)				 | ||||
| 		self.resize(900,350) | ||||
| 		 | ||||
| 		 | ||||
| 	def init(self, sig, SimulationTime): | ||||
| 		lenght = np.size(sig[:,0]) | ||||
| 		self.time = np.linspace(0,SimulationTime, lenght)*1e6 | ||||
| 		 | ||||
| 		self.data = list() | ||||
| 		self.plot, = self.mpl.ax.plot([], [], color='green', linewidth=2) | ||||
| 		 | ||||
| 		self.min = -0.01 | ||||
| 		self.max =  0.01		 | ||||
| 		 | ||||
| 		self.mpl.ax.patch.set_facecolor('lightgray') | ||||
| 		 | ||||
| 		self.mpl.ax.set_ylim(self.min, self.max) | ||||
| 		self.mpl.ax.set_xlim(0, self.time[-1]) | ||||
| 		 | ||||
| 		self.mpl.ax.grid(True, color='black') | ||||
| 		self.mpl.ax.set_title("Time Signal", fontsize = 10) | ||||
| 		self.mpl.ax.set_xlabel("Time ($\mu$s)") | ||||
| 		self.mpl.ax.set_ylabel("Amplitude") | ||||
| 
 | ||||
| 	def update(self, value): | ||||
| 		self.data.append(value) | ||||
| 		N = len(self.data) | ||||
| 		self.plot.set_data(self.time[0:N], self.data) | ||||
| 		vmin = np.min([np.min(self.data),self.min])  | ||||
| 		vmax = np.max([np.max(self.data), self.max]) | ||||
| 		self.mpl.ax.set_ylim(vmin,vmax) | ||||
| 		self.mpl.draw() | ||||
| 		 | ||||
| 
 | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user