+ def saveMetadata(self):
+ app = self.master.master
+ filepath = app.currentFilePath
+ lfa = LogFileAnalyser(filepath, mode='r+')
+ patientName = '%s\n' % self.nameEntry.get().replace('\n', ' ').strip()
+ comments = '%s\n' % self.commentsText.get(1.0, END).replace('\n', ' ').strip()
+ metadata = (('PatientName', self.nameEntry.get()),
+ ('Comments', comments))
+ lfa.setMetadata(metadata)
+
+
+class ResultsFrame(Frame) :
+
+ def layResults(self, lfa) :
+ results = lfa.analyse()
+ if results :
+ for i, kvt in enumerate(results) :
+ k, v, timeBased = kvt
+ kl = Label(self, text='%s :' % k)
+ kl.grid(row=i, column=0, sticky=E)
+
+ if not timeBased :
+ vl = Label(self, text=v)
+ vl.grid(row=i, column=1, sticky=W)
+ else :
+ maxv = max(v)
+ if maxv :
+ cw, ch = 200, 100
+ c = Canvas(self, background='#fff', width=cw, height=ch)
+ rectW = int(float(cw) / len(v))
+ unitRectH = float(ch) / maxv
+ for j, fv in enumerate(v) :
+ if not fv : continue
+ x0 = j * rectW
+ y0 = ch - int(unitRectH * fv)
+ x1 = (j + 1) * rectW
+ y1 = ch
+ c.create_rectangle(x0, y0, x1, y1, fill="#9085ba")
+ c.grid(row=i, column=1, sticky=W)
+
+ else :
+ vl = Label(self, text='—')
+ vl.grid(row=i, column=1, sticky=W)
+ else :
+ msg = Label(self, text="Pas de données exploitables.")
+ msg.grid()
+
+
+def main() :
+ app = Application()
+ app.master.title("Analyseur des sessions MINWii")
+ app.mainloop()