-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathECoG Analyzer.py
148 lines (120 loc) · 5.08 KB
/
ECoG Analyzer.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
from chartView import *
from dialogs import *
from PySide2.QtWidgets import (QApplication, QMainWindow, QScrollArea,
QSizePolicy, QToolBar)
from PySide2.QtGui import QPalette
import gc
##import pandas as pd
from data import *
from chartWidgets import *
from algorithms import *
from fileHandlers import FileManager
'''
MAIN WINDOW CLASS
'''
class ApplicationWindow(QMainWindow):
def __init__(self):
# Main window - Properties
QMainWindow.__init__(self)
self.setAttribute(Qt.WA_DeleteOnClose)
self.setWindowTitle("ECoG Analyzer")
self.dm = DataManager(250)
self.chm = MyChartManager(self.dm)
self.algManager = AlgorithmsManager(self.dm, self.chm)
self.fileManager = FileManager()
chartArea = ChartArea(self.chm)
self.setCentralWidget(chartArea)
self.setupMenu()
self.setupToolbar()
self.setupDockWidgets()
def setupMenu(self):
# Menu - File
self.file_menu = QtWidgets.QMenu('&File', self)
self.file_menu.addAction('&Open...', self.fileOpen,
QtCore.Qt.CTRL + QtCore.Qt.Key_O)
self.file_menu.addAction('&Quit', self.fileQuit,
QtCore.Qt.CTRL + QtCore.Qt.Key_Q)
self.menuBar().addMenu(self.file_menu)
# Menu - Chart
self.chart_menu = QtWidgets.QMenu('&Chart', self)
a = self.chart_menu.addAction('&ON/OFF Autoscale')
a.triggered.connect(self.changeChartAutoscale)
a.setCheckable(True)
a = self.chart_menu.addAction('Show Legend')
a.setCheckable(True)
a.toggled.connect(self.chm.getChart().setLegendVisible)
self.gridChooser = self.chart_menu.addMenu('Grid')
gridOptions = ('&20 x 1', '&5 x 4')
for option in gridOptions:
a = self.gridChooser.addAction(option)
a.setCheckable(True)
if option == '&20 x 1':
a.setChecked(True)
a = self.chart_menu.addAction('Show Map')
a.triggered.connect(self.chm.showMap)
self.gridChooser.triggered.connect(self.setChartGrid)
self.menuBar().addMenu(self.chart_menu)
# Menu - Window
self.window_menu = QtWidgets.QMenu('&Window', self)
self.toolWigtedVisible = self.window_menu.addAction('&Show Tool Widget',
shortcut=QtCore.Qt.CTRL + QtCore.Qt.Key_L)
self.toolWigtedVisible.triggered.connect(self.changeDockWidgetVisible)
self.toolWigtedVisible.setCheckable(True)
self.toolWigtedVisible.setChecked(True)
self.menuBar().addMenu(self.window_menu)
def setupToolbar(self):
self.toolBar = QToolBar()
self.toolBar.addAction('&Data processing', self.showDataProcessingDialog)
self.toolBar.addAction('&Algorithms', self.showAlgorithmsDialog)
self.addToolBar(self.toolBar)
def setupDockWidgets(self):
self.chTools = ChartTools(self.chm, self.algManager, self)
self.chTools.setFixedWidth(0.3*self.size().width())
self.toolWidget = QDockWidget(self)
self.toolWidget.setAllowedAreas(Qt.LeftDockWidgetArea | Qt.RightDockWidgetArea)
self.toolWidget.setWidget(self.chTools)
self.addDockWidget(Qt.LeftDockWidgetArea, self.toolWidget, Qt.Vertical)
self.toolWidget.visibilityChanged.connect(self.toolWigtedVisible.setChecked)
self.toolWidget.setFloating(False)
def showDataProcessingDialog(self):
dialog = DataProcessingDialog(self.dm, self)
dialog.show()
dialog.exec()
def showAlgorithmsDialog(self):
print('type(self.chm)', type(self.chm))
dialog = FirstAlgorithm(self.dm, self.chm, self)
dialog.show()
dialog.exec()
def changeDockWidgetVisible(self):
self.toolWidget.setVisible(not self.toolWidget.isVisible())
def changeChartAutoscale(self, state):
self.chm.getChart().setAutoscaleY(state)
def setChartGrid(self, action):
for a in self.gridChooser.actions():
a.setChecked(False)
plotsPerAxes = int(action.text()[1:3])
action.setChecked(True)
self.chm.getChart().setPlotsPerAxes(plotsPerAxes)
def fileOpen(self):
wsName = 'Sandbox'
try:
filePath, ecog, chNames = self.fileManager.openFile()
except:
return
if ecog is not None:
self.dm.removeAll()
self.dm.createDataGroup(wsName)
fileName = filePath.split('/')[-1].split('.')[-2]
print('ecog len', len(ecog))
if chNames is None:
chNames = ['CH'+str(n) for n in range(1,len(ecog)+1)]
self.dm.addChannels(wsName, chNames)
self.dm.addSignal(wsName, 'Original Signal ({})'.format(fileName), ecog, chNames)
## self.dm.addSignal(wsName, 'Original Signal ({})+Offset'.format(fileName), ecog+2000, chNames)
def fileQuit(self):
self.close()
if __name__ == "__main__":
app = QApplication(sys.argv)
aw = ApplicationWindow()
aw.show()
sys.exit(app.exec_())