web export
[iramuteq] / guifunct.py
1 # -*- coding: utf-8 -*-
2 #Author: Pierre Ratinaud
3 #Copyright (c) 2008-2011 Pierre Ratinaud
4 #License: GNU/GPL
5
6 import wx
7 import os
8 import sys
9 from copy import copy
10 import dialog
11 from listlex import *
12 from functions import treat_var_mod
13
14
15 def OnOpen(self, type):
16         if type == "Data":
17             wildcard = u"Fichiers supportés|*.ods;*.xls;*.csv;*.txt|Openoffice Calc|*.ods|Excel 97/2000/XP/2003|*.xls|Fichier csv|*.csv|Fichier texte|*.txt|Tous les fichiers|*"
18         elif type == "Texte":
19             wildcard = "Fichier texte|*.txt|Tous les fichiers|*"
20         elif type == "Analyse":
21             wildcard = "Fichier analyse/Corpus|*.ira;*.cira"
22         defaultDir = self.PathPath.get('PATHS', 'lastpath')
23         if defaultDir.strip() == '':
24             defaultDir = self.UserConfigPath.replace('.iramuteq','')
25         dlg = wx.FileDialog(
26         self, message=_(u"Choose a file").decode('utf8'), defaultDir=defaultDir,
27         defaultFile="", wildcard=wildcard, style=wx.OPEN | wx.CHANGE_DIR)
28         dlg.CenterOnParent()
29         if dlg.ShowModal() == wx.ID_OK :
30             fileName = dlg.GetFilename()
31             path = dlg.GetPaths()
32             dlg.Destroy()
33             self.PathPath.set('PATHS', 'lastpath', os.path.dirname(path[0]))
34             self.type = type
35             return fileName, path
36         else:
37             dlg.Destroy()
38             if type == "Data":
39                 return False, [False]
40             elif type == "Texte":
41                 return False, [False]
42             elif type == "Analyse":
43                 return [False]
44
45 def getfileextension(file) :
46     return os.path.splitext(file)[1]
47
48 def get_table_param(self, filename) :
49     if getfileextension(filename) == '.csv':
50         dlg = dialog.FileOptionDialog(self, -1, _(u"File format").decode('utf8'), sep=True, size=(350, 200),
51                      style=wx.DEFAULT_DIALOG_STYLE)
52         dlg.CenterOnParent()
53         val = dlg.ShowModal()
54         if val == wx.ID_OK:
55             self.tableau.parametre['colsep'] = dlg.colsep[dlg.choice3.GetSelection()]
56             self.tableau.parametre['txtsep'] = dlg.txtsep[dlg.choice4.GetSelection()]
57             if self.tableau.parametre['colsep'] == 'tabulation' :
58                 self.tableau.parametre['colsep'] = '\t'
59             self.tableau.parametre['filetype'] = 'csv'
60         else :
61             dlg.Destroy()
62     elif  getfileextension(filename) == '.xls' :
63         dlg = dialog.FileOptionDialog(self, -1, _(u"File format").decode('utf8'), sep=False, sheet = True, size=(350, 200),
64                      style=wx.DEFAULT_DIALOG_STYLE)
65         dlg.CenterOnParent()
66         val = dlg.ShowModal()
67         if val == wx.ID_OK:    
68             self.tableau.parametre['colsep'] = ';'
69             self.tableau.parametre['txtsep'] = '\"'
70             self.tableau.parametre['encodage'] = sys.getdefaultencoding()
71             self.tableau.parametre['sheetnb'] = dlg.spin1.GetValue()
72             self.tableau.parametre['filetype'] = 'xls'
73         else :
74             dlg.Destroy()
75     elif getfileextension(filename) == '.ods':
76         dlg = dialog.FileOptionDialog(self, -1, _(u"File format").decode('utf8'), sep=False, size=(350, 200),
77                      style=wx.DEFAULT_DIALOG_STYLE)
78         dlg.CenterOnParent()
79         val = dlg.ShowModal()
80         if val == wx.ID_OK:          
81             self.tableau.parametre['colsep'] = ';'
82             self.tableau.parametre['txtsep'] = '\"'
83             self.tableau.parametre['filetype'] = 'ods'
84         else :
85             dlg.Destroy()
86     else :
87         val = False
88     if val == wx.ID_OK:       
89         if dlg.radio_box_1.GetSelection() == 0:
90             self.tableau.firstrowiscolnames = True
91         else:
92             self.tableau.firstrowiscolnames = False
93         if dlg.radio_box_2.GetSelection() == 0:
94             self.tableau.firstcolisrownames = True
95         else:
96             self.tableau.firstcolisrownames = False
97         dlg.Destroy()
98
99 def getPage(ira) :
100     if '_mgr' in dir(ira) :
101         if not ira._mgr.GetPane('Text').IsShown() :
102             if ira.nb.GetPageCount() >= 1:
103                 return ira.nb.GetPage(ira.nb.GetSelection())
104             else :
105                 return None
106         else :
107             return None
108     else :
109         return None
110
111 def getCorpus(page) :
112     if 'corpus' in page.__dict__:
113         return copy(page.corpus)
114     else :
115         return None
116             
117 class SelectColumn :
118     def __init__(self, parent, dictcol, actives, pathout, selected = None, dlg = False) :
119         self.ira = parent
120         if dlg :
121             dial = dialog.SelectColDial(self.ira)
122             listcol = ListForSpec(dial, self, dictcol, ['forme', 'eff'])
123             dial.bSizer2.Add( listcol, 2, wx.ALL|wx.EXPAND, 5 )
124             dial.m_sdbSizer2.AddButton( dial.m_sdbSizer2OK )
125             dial.m_sdbSizer2.AddButton( dial.butok)
126             dial.m_sdbSizer2.Realize()
127             dial.bSizer2.Add( dial.m_sdbSizer2, 0, wx.EXPAND, 5 )
128             dial.Layout()
129             if selected is None :
130                 for row in xrange(listcol.GetItemCount()):
131                     listcol.Select(row)
132             else :
133                 orderlex = dict([[listcol.getColumnText(i,0),i] for i in range(0,listcol.GetItemCount())])
134                 for row in selected :
135                     listcol.Select(orderlex[actives[row]])
136             dial.CenterOnParent()
137             val = dial.ShowModal()        
138             if val == wx.ID_OK :
139                 last = listcol.GetFirstSelected()
140                 lastl = [listcol.GetFirstSelected()]
141                 indexes = [listcol.getColumnText(listcol.GetFirstSelected(),0)]
142                 while listcol.GetNextSelected(last) != -1:
143                     last = listcol.GetNextSelected(last)
144                     lastl.append(last)
145                     indexes.append(listcol.getColumnText(last,0))
146                 dial.Destroy()
147                 column = [actives.index(val) for val in indexes]
148                 column.sort()
149                 with open(pathout, 'w') as f :
150                     f.write('\n'.join([`val` for val in column]))
151                 self.ok = True
152             else :
153                 self.ok = False
154         else :
155             if selected is None :
156                 selected = [i for i in range(0, len(actives))]
157             with open(pathout, 'w') as f :
158                 f.write('\n'.join([`i` for i in selected]))
159
160
161 class PrefSimi ( wx.Dialog ):
162     
163     def __init__( self, parent, ID, paramsimi, indices, wordlist = None, selected = None, actives = None):
164         wx.Dialog.__init__ ( self, None, id = wx.ID_ANY, title = _(u"Settings").decode('utf8'), pos = wx.DefaultPosition, size = wx.Size( -1,-1 ), style = wx.DEFAULT_DIALOG_STYLE )
165         self.parent = parent
166         self.ira = parent
167         self.paramsimi=paramsimi
168         self.indices = indices
169
170         self.SetSizeHintsSz( wx.DefaultSize, wx.DefaultSize )
171         
172         bSizer16 = wx.BoxSizer( wx.HORIZONTAL )
173         if wordlist is not None :
174             self.listcol = ListForSpec(self, self, wordlist, ['forme', 'eff'])
175             self.listcol.SetMinSize( wx.Size( 270,-1 ) )
176             bSizer16.Add( self.listcol, 0, wx.ALL|wx.EXPAND, 5 )
177             if selected is None :
178                 for row in xrange(self.listcol.GetItemCount()):
179                     self.listcol.Select(row)
180             else :
181                 self.orderlex = dict([[self.listcol.getColumnText(i,0),i] for i in range(0,self.listcol.GetItemCount())])
182                 for row in selected :
183                     self.listcol.Select(self.orderlex[actives[row]])
184         
185
186         fgSizer10 = wx.FlexGridSizer( 2, 1, 0, 0 )
187         fgSizer10.SetFlexibleDirection( wx.BOTH )
188         fgSizer10.SetNonFlexibleGrowMode( wx.FLEX_GROWMODE_SPECIFIED )
189         
190         self.m_notebook1 = wx.Notebook( self, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, 0 )
191         self.m_panel2 = wx.Panel( self.m_notebook1, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.TAB_TRAVERSAL )
192         bSizer18 = wx.BoxSizer( wx.VERTICAL )
193         
194         fgSizer3 = wx.FlexGridSizer( 0, 2, 0, 0 )
195         fgSizer3.SetFlexibleDirection( wx.BOTH )
196         fgSizer3.SetNonFlexibleGrowMode( wx.FLEX_GROWMODE_SPECIFIED )
197         
198         if not self.paramsimi['first'] :
199
200             self.m_staticText271 = wx.StaticText( self.m_panel2, wx.ID_ANY, _(u"Use previous coordinates").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
201             self.m_staticText271.Wrap( -1 )
202             fgSizer3.Add( self.m_staticText271, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
203             
204             self.check_coord = wx.CheckBox( self.m_panel2, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, 0 )
205             fgSizer3.Add( self.check_coord, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
206             
207             self.m_staticline36 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
208             fgSizer3.Add( self.m_staticline36, 0, wx.EXPAND, 5 )
209             
210             self.m_staticline37 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
211             fgSizer3.Add( self.m_staticline37, 0, wx.EXPAND, 5 )
212         
213         self.m_staticText3 = wx.StaticText( self.m_panel2, wx.ID_ANY, _(u"Score").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
214         self.m_staticText3.Wrap( -1 )
215         fgSizer3.Add( self.m_staticText3, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
216         
217         choice1Choices = []
218         self.choice1 = wx.Choice( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, self.indices, 0 )
219         self.choice1.SetSelection( 0 )
220         fgSizer3.Add( self.choice1, 0, wx.ALL, 5 )
221         
222         self.m_staticline293 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
223         fgSizer3.Add( self.m_staticline293, 0, wx.EXPAND, 5 )
224         
225         self.m_staticline292 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
226         fgSizer3.Add( self.m_staticline292, 0, wx.EXPAND, 5 )
227         
228         self.m_staticText4 = wx.StaticText( self.m_panel2, wx.ID_ANY, _(u"Layout").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
229         self.m_staticText4.Wrap( -1 )
230         fgSizer3.Add( self.m_staticText4, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
231         
232         choice2Choices = [ u"random", u"cercle", u"fruchterman reingold", u"kamada kawai", u"graphopt" ]
233         self.choice2 = wx.Choice( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, choice2Choices, 0 )
234         self.choice2.SetSelection( 0 )
235         fgSizer3.Add( self.choice2, 0, wx.ALL, 5 )
236         
237         self.m_staticline294 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
238         fgSizer3.Add( self.m_staticline294, 0, wx.EXPAND, 5 )
239         
240         self.m_staticline295 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
241         fgSizer3.Add( self.m_staticline295, 0, wx.EXPAND, 5 )
242         
243         self.m_staticText5 = wx.StaticText( self.m_panel2, wx.ID_ANY, _(u"Graphical type").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
244         self.m_staticText5.Wrap( -1 )
245         fgSizer3.Add( self.m_staticText5, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
246         
247         choice3Choices = [ u"dynamique", u"statique", u"3D", u'web2D', u"web3D" ]
248         self.choice3 = wx.Choice( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, choice3Choices, 0 )
249         self.choice3.SetSelection( 0 )
250
251         label_format = wx.StaticText(self.m_panel2, -1, _(u"Picture format").decode('utf8'))
252         self.choix_format =  wx.Choice(self.m_panel2, -1, (100,50), choices = ['png', 'svg'])
253         self.choix_format.SetSelection( 0 )
254         hsizer = wx.BoxSizer(wx.HORIZONTAL)
255         hsizer.Add(self.choice3, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
256         hsizer.Add(label_format, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
257         hsizer.Add(self.choix_format, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
258         fgSizer3.Add( hsizer, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
259         
260         self.m_staticline296 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
261         fgSizer3.Add( self.m_staticline296, 0, wx.EXPAND, 5 )
262         
263         self.m_staticline297 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
264         fgSizer3.Add( self.m_staticline297, 0, wx.EXPAND, 5 )
265         
266         self.m_staticText8 = wx.StaticText( self.m_panel2, wx.ID_ANY, _(u"Maximum tree").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
267         self.m_staticText8.Wrap( -1 )
268         fgSizer3.Add( self.m_staticText8, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
269         
270         self.check1 = wx.CheckBox( self.m_panel2, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, 0 )
271         fgSizer3.Add( self.check1, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
272         
273         self.m_staticline298 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
274         fgSizer3.Add( self.m_staticline298, 0, wx.EXPAND, 5 )
275         
276         self.m_staticline299 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
277         fgSizer3.Add( self.m_staticline299, 0, wx.EXPAND, 5 )
278         
279         self.m_staticText91 = wx.StaticText( self.m_panel2, wx.ID_ANY, _(u"Edges threshold").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
280         self.m_staticText91.Wrap( -1 )
281         fgSizer3.Add( self.m_staticText91, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
282         
283         bSizer21 = wx.BoxSizer( wx.HORIZONTAL )
284         
285         self.check_seuil = wx.CheckBox( self.m_panel2, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, 0 )
286         bSizer21.Add( self.check_seuil, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
287         
288         self.spin_seuil = wx.SpinCtrl( self.m_panel2, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, wx.SP_ARROW_KEYS, 1, 10000, 1 )
289         bSizer21.Add( self.spin_seuil, 0, wx.ALL, 5 )
290         
291         
292         fgSizer3.Add( bSizer21, 1, wx.EXPAND, 5 )
293         
294         self.m_staticline2910 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
295         fgSizer3.Add( self.m_staticline2910, 0, wx.EXPAND, 5 )
296         
297         self.m_staticline2911 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
298         fgSizer3.Add( self.m_staticline2911, 0, wx.EXPAND, 5 )
299         
300         self.m_staticText19 = wx.StaticText( self.m_panel2, wx.ID_ANY, _(u"Text on vertex").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
301         self.m_staticText19.Wrap( -1 )
302         fgSizer3.Add( self.m_staticText19, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
303         
304         self.check_vlab = wx.CheckBox( self.m_panel2, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, 0 )
305         fgSizer3.Add( self.check_vlab, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
306         
307         self.m_staticline2912 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
308         fgSizer3.Add( self.m_staticline2912, 0, wx.EXPAND, 5 )
309         
310         self.m_staticline2913 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
311         fgSizer3.Add( self.m_staticline2913, 0, wx.EXPAND, 5 )
312         
313         self.m_staticText20 = wx.StaticText( self.m_panel2, wx.ID_ANY, _(u"Score on edges").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
314         self.m_staticText20.Wrap( -1 )
315         fgSizer3.Add( self.m_staticText20, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
316         
317         self.check_elab = wx.CheckBox( self.m_panel2, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, 0 )
318         fgSizer3.Add( self.check_elab, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
319         
320         self.m_staticline2914 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
321         fgSizer3.Add( self.m_staticline2914, 0, wx.EXPAND, 5 )
322         
323         self.m_staticline2915 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
324         fgSizer3.Add( self.m_staticline2915, 0, wx.EXPAND, 5 )
325         
326         self.m_staticText27 = wx.StaticText( self.m_panel2, wx.ID_ANY, _(u"Text size").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
327         self.m_staticText27.Wrap( -1 )
328         fgSizer3.Add( self.m_staticText27, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
329         
330         self.spin_cex = wx.SpinCtrl( self.m_panel2, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, wx.SP_ARROW_KEYS, 0, 100, 10 )
331         fgSizer3.Add( self.spin_cex, 0, wx.ALL, 5 )
332         
333         self.m_staticline2916 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
334         fgSizer3.Add( self.m_staticline2916, 0, wx.EXPAND, 5 )
335         
336         self.m_staticline2917 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
337         fgSizer3.Add( self.m_staticline2917, 0, wx.EXPAND, 5 )
338         
339         bsizer34 = wx.BoxSizer(wx.HORIZONTAL)
340         
341         comtext =  wx.StaticText( self.m_panel2, wx.ID_ANY, _(u"Communities").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
342         comtext.Wrap( -1 )
343         bsizer34.Add(comtext, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
344
345         self.comcheck = wx.CheckBox(self.m_panel2, -1)
346         bsizer34.Add(self.comcheck, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
347
348         fgSizer3.Add(bsizer34 , 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
349
350         sizer54 = wx.BoxSizer(wx.HORIZONTAL)
351         self.comlist = ['edge.betweenness.community','fastgreedy.community','label.propagation.community','leading.eigenvector.community','multilevel.community','optimal.community', 'spinglass.community', 'walktrap.community']
352         self.choix_com = wx.Choice( self.m_panel2, wx.ID_ANY, choices = self.comlist)
353         self.choix_com.SetSelection( 0 )
354         self.halo = wx.CheckBox(self.m_panel2, wx.ID_ANY, u'halo')
355         sizer54.Add(self.choix_com , 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
356         sizer54.Add(self.halo , 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
357         fgSizer3.Add( sizer54, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
358
359         if 'bystar' in self.paramsimi :
360             self.m_staticText40 = wx.StaticText( self.m_panel2, wx.ID_ANY, _(u"Select a variable").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
361             self.m_staticText40.Wrap( -1 )
362             fgSizer3.Add( self.m_staticText40, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
363             
364             self.check_bystar = wx.CheckBox( self.m_panel2, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, 0 )
365             fgSizer3.Add( self.check_bystar, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
366             
367             self.m_staticline3200 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
368             fgSizer3.Add( self.m_staticline3200, 0, wx.EXPAND, 5 )
369             self.m_staticline3201 = wx.StaticLine( self.m_panel2, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
370             fgSizer3.Add( self.m_staticline3201, 0, wx.EXPAND, 5 )
371
372         
373         bSizer18.Add( fgSizer3, 0, wx.EXPAND, 5 )
374         
375         
376         self.m_panel2.SetSizer( bSizer18 )
377         self.m_panel2.Layout()
378         bSizer18.Fit( self.m_panel2 )
379         self.m_notebook1.AddPage( self.m_panel2, _(u"Graphic settings").decode('utf8'), True )
380         self.m_panel3 = wx.Panel( self.m_notebook1, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.TAB_TRAVERSAL )
381         fgSizer5 = wx.FlexGridSizer( 0, 3, 0, 0 )
382         fgSizer5.SetFlexibleDirection( wx.BOTH )
383         fgSizer5.SetNonFlexibleGrowMode( wx.FLEX_GROWMODE_SPECIFIED )
384         
385         fgSizer51 = wx.FlexGridSizer( 0, 2, 0, 0 )
386         fgSizer51.SetFlexibleDirection( wx.BOTH )
387         fgSizer51.SetNonFlexibleGrowMode( wx.FLEX_GROWMODE_SPECIFIED )
388         
389         self.m_staticText6 = wx.StaticText( self.m_panel3, wx.ID_ANY, _(u"Picture size").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
390         self.m_staticText6.Wrap( -1 )
391         fgSizer51.Add( self.m_staticText6, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
392         
393         fgSizer31 = wx.FlexGridSizer( 0, 2, 0, 0 )
394         fgSizer31.SetFlexibleDirection( wx.BOTH )
395         fgSizer31.SetNonFlexibleGrowMode( wx.FLEX_GROWMODE_SPECIFIED )
396         
397         self.m_staticText9 = wx.StaticText( self.m_panel3, wx.ID_ANY, _(u"height").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
398         self.m_staticText9.Wrap( -1 )
399         fgSizer31.Add( self.m_staticText9, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
400         
401         self.spin_height = wx.SpinCtrl( self.m_panel3, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, wx.SP_ARROW_KEYS, 10, 100000, 800 )
402         fgSizer31.Add( self.spin_height, 0, wx.ALL, 5 )
403         
404         self.m_staticText10 = wx.StaticText( self.m_panel3, wx.ID_ANY, _(u"width").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
405         self.m_staticText10.Wrap( -1 )
406         fgSizer31.Add( self.m_staticText10, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
407         
408         self.spin_width = wx.SpinCtrl( self.m_panel3, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, wx.SP_ARROW_KEYS, 10, 100000, 800 )
409         fgSizer31.Add( self.spin_width, 0, wx.ALL, 5 )
410         
411         
412         fgSizer51.Add( fgSizer31, 1, wx.EXPAND, 5 )
413         
414         self.m_staticline3 = wx.StaticLine( self.m_panel3, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
415         fgSizer51.Add( self.m_staticline3, 0, wx.EXPAND, 5 )
416         
417         self.m_staticline4 = wx.StaticLine( self.m_panel3, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
418         fgSizer51.Add( self.m_staticline4, 0, wx.EXPAND, 5 )
419         
420         self.m_staticText101 = wx.StaticText( self.m_panel3, wx.ID_ANY, _(u"Vertex size proportional to frequency").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
421         self.m_staticText101.Wrap( -1 )
422         fgSizer51.Add( self.m_staticText101, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
423         
424         bSizer7 = wx.BoxSizer( wx.HORIZONTAL )
425         
426         bSizer9 = wx.BoxSizer( wx.VERTICAL )
427         
428         self.check2 = wx.CheckBox( self.m_panel3, wx.ID_ANY, u"eff.", wx.DefaultPosition, wx.DefaultSize, 0 )
429         bSizer9.Add( self.check2, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
430         
431         self.checki = wx.CheckBox( self.m_panel3, wx.ID_ANY, u"chi2", wx.DefaultPosition, wx.DefaultSize, 0 )
432         bSizer9.Add( self.checki, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
433         
434         
435         bSizer7.Add( bSizer9, 0, wx.ALIGN_CENTER_VERTICAL, 5 )
436         
437         fgSizer7 = wx.FlexGridSizer( 0, 2, 0, 0 )
438         fgSizer7.SetFlexibleDirection( wx.BOTH )
439         fgSizer7.SetNonFlexibleGrowMode( wx.FLEX_GROWMODE_SPECIFIED )
440         
441         self.m_staticText11 = wx.StaticText( self.m_panel3, wx.ID_ANY, u"min", wx.DefaultPosition, wx.DefaultSize, 0 )
442         self.m_staticText11.Wrap( -1 )
443         fgSizer7.Add( self.m_staticText11, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
444         
445         self.spin_tvmin = wx.SpinCtrl( self.m_panel3, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, wx.SP_ARROW_KEYS, 0, 100, 0 )
446         fgSizer7.Add( self.spin_tvmin, 0, wx.ALL, 5 )
447         
448         self.m_staticText12 = wx.StaticText( self.m_panel3, wx.ID_ANY, u"max", wx.DefaultPosition, wx.DefaultSize, 0 )
449         self.m_staticText12.Wrap( -1 )
450         fgSizer7.Add( self.m_staticText12, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
451         
452         self.spin_tvmax = wx.SpinCtrl( self.m_panel3, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, wx.SP_ARROW_KEYS, 0, 100, 0 )
453         fgSizer7.Add( self.spin_tvmax, 0, wx.ALL, 5 )
454         
455         
456         bSizer7.Add( fgSizer7, 1, wx.EXPAND, 5 )
457         
458         
459         fgSizer51.Add( bSizer7, 1, wx.EXPAND, 5 )
460         
461         self.m_staticline31 = wx.StaticLine( self.m_panel3, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
462         fgSizer51.Add( self.m_staticline31, 0, wx.EXPAND, 5 )
463         
464         self.m_staticline32 = wx.StaticLine( self.m_panel3, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
465         fgSizer51.Add( self.m_staticline32, 0, wx.EXPAND, 5 )
466         
467         self.m_staticText1011 = wx.StaticText( self.m_panel3, wx.ID_ANY, _(u"Vertex text size proportional to frequency").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
468         self.m_staticText1011.Wrap( -1 )
469         fgSizer51.Add( self.m_staticText1011, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
470         
471         bSizer71 = wx.BoxSizer( wx.HORIZONTAL )
472         
473         bSizer8 = wx.BoxSizer( wx.VERTICAL )
474         
475         self.check_vcex = wx.CheckBox( self.m_panel3, wx.ID_ANY, u"eff.", wx.DefaultPosition, wx.DefaultSize, 0 )
476         bSizer8.Add( self.check_vcex, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
477         
478         self.checkit = wx.CheckBox( self.m_panel3, wx.ID_ANY, u"chi2", wx.DefaultPosition, wx.DefaultSize, 0 )
479         bSizer8.Add( self.checkit, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
480         
481         
482         bSizer71.Add( bSizer8, 0, wx.ALIGN_CENTER_VERTICAL, 5 )
483         
484         fgSizer71 = wx.FlexGridSizer( 0, 2, 0, 0 )
485         fgSizer71.SetFlexibleDirection( wx.BOTH )
486         fgSizer71.SetNonFlexibleGrowMode( wx.FLEX_GROWMODE_SPECIFIED )
487         
488         self.m_staticText111 = wx.StaticText( self.m_panel3, wx.ID_ANY, u"min", wx.DefaultPosition, wx.DefaultSize, 0 )
489         self.m_staticText111.Wrap( -1 )
490         fgSizer71.Add( self.m_staticText111, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
491         
492         self.spin_vcexmin = wx.SpinCtrl( self.m_panel3, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, wx.SP_ARROW_KEYS, 0, 100, 0 )
493         fgSizer71.Add( self.spin_vcexmin, 0, wx.ALL, 5 )
494         
495         self.m_staticText121 = wx.StaticText( self.m_panel3, wx.ID_ANY, u"max", wx.DefaultPosition, wx.DefaultSize, 0 )
496         self.m_staticText121.Wrap( -1 )
497         fgSizer71.Add( self.m_staticText121, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
498         
499         self.spin_vcexmax = wx.SpinCtrl( self.m_panel3, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, wx.SP_ARROW_KEYS, 0, 100, 0 )
500         fgSizer71.Add( self.spin_vcexmax, 0, wx.ALL, 5 )
501         
502         
503         bSizer71.Add( fgSizer71, 1, wx.EXPAND, 5 )
504         
505         
506         fgSizer51.Add( bSizer71, 1, wx.EXPAND, 5 )
507         
508         self.m_staticline321 = wx.StaticLine( self.m_panel3, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
509         fgSizer51.Add( self.m_staticline321, 0, wx.EXPAND, 5 )
510         
511         self.m_staticline322 = wx.StaticLine( self.m_panel3, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
512         fgSizer51.Add( self.m_staticline322, 0, wx.EXPAND, 5 )
513         
514         self.m_staticText10111 = wx.StaticText( self.m_panel3, wx.ID_ANY, _(u"Edges width proportional to score").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
515         self.m_staticText10111.Wrap( -1 )
516         fgSizer51.Add( self.m_staticText10111, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
517         
518         bSizer711 = wx.BoxSizer( wx.HORIZONTAL )
519         
520         self.check3 = wx.CheckBox( self.m_panel3, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, 0 )
521         bSizer711.Add( self.check3, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
522         
523         fgSizer711 = wx.FlexGridSizer( 0, 2, 0, 0 )
524         fgSizer711.SetFlexibleDirection( wx.BOTH )
525         fgSizer711.SetNonFlexibleGrowMode( wx.FLEX_GROWMODE_SPECIFIED )
526         
527         self.m_staticText1111 = wx.StaticText( self.m_panel3, wx.ID_ANY, u"min", wx.DefaultPosition, wx.DefaultSize, 0 )
528         self.m_staticText1111.Wrap( -1 )
529         fgSizer711.Add( self.m_staticText1111, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
530         
531         self.spin_temin = wx.SpinCtrl( self.m_panel3, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, wx.SP_ARROW_KEYS, 0, 100, 0 )
532         fgSizer711.Add( self.spin_temin, 0, wx.ALL, 5 )
533         
534         self.m_staticText1211 = wx.StaticText( self.m_panel3, wx.ID_ANY, u"max", wx.DefaultPosition, wx.DefaultSize, 0 )
535         self.m_staticText1211.Wrap( -1 )
536         fgSizer711.Add( self.m_staticText1211, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
537         
538         self.spin_temax = wx.SpinCtrl( self.m_panel3, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, wx.SP_ARROW_KEYS, 0, 100, 0 )
539         fgSizer711.Add( self.spin_temax, 0, wx.ALL, 5 )
540         
541         
542         bSizer711.Add( fgSizer711, 1, wx.EXPAND, 5 )
543         
544         
545         fgSizer51.Add( bSizer711, 1, wx.EXPAND, 5 )
546         
547         self.m_staticline33 = wx.StaticLine( self.m_panel3, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
548         fgSizer51.Add( self.m_staticline33, 0, wx.EXPAND, 5 )
549         
550         self.m_staticline34 = wx.StaticLine( self.m_panel3, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
551         fgSizer51.Add( self.m_staticline34, 0, wx.EXPAND, 5 )
552         
553         self.m_staticText28 = wx.StaticText( self.m_panel3, wx.ID_ANY, _(u"Gray scale on text proportional to frequency (0=black, 1=white)").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
554         self.m_staticText28.Wrap( -1 )
555         fgSizer51.Add( self.m_staticText28, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
556         
557         bSizer10 = wx.BoxSizer( wx.HORIZONTAL )
558         
559         self.m_checkBox14 = wx.CheckBox( self.m_panel3, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, 0 )
560         bSizer10.Add( self.m_checkBox14, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
561         
562         bSizer11 = wx.BoxSizer( wx.VERTICAL )
563         
564         bSizer12 = wx.BoxSizer( wx.HORIZONTAL )
565         
566         self.m_staticText31 = wx.StaticText( self.m_panel3, wx.ID_ANY, u"min", wx.DefaultPosition, wx.DefaultSize, 0 )
567         self.m_staticText31.Wrap( -1 )
568         bSizer12.Add( self.m_staticText31, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
569         
570         self.m_spinCtrl14 = wx.SpinCtrl( self.m_panel3, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, wx.SP_ARROW_KEYS, 0, 100, 0 )
571         bSizer12.Add( self.m_spinCtrl14, 0, wx.ALL, 5 )
572         
573         
574         bSizer11.Add( bSizer12, 1, wx.EXPAND, 5 )
575         
576         bSizer13 = wx.BoxSizer( wx.HORIZONTAL )
577         
578         self.m_staticText32 = wx.StaticText( self.m_panel3, wx.ID_ANY, u"max", wx.DefaultPosition, wx.DefaultSize, 0 )
579         self.m_staticText32.Wrap( -1 )
580         bSizer13.Add( self.m_staticText32, 0, wx.ALIGN_CENTER_VERTICAL|wx.ALL, 5 )
581         
582         self.m_spinCtrl15 = wx.SpinCtrl( self.m_panel3, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, wx.SP_ARROW_KEYS, 0, 100, 10 )
583         bSizer13.Add( self.m_spinCtrl15, 0, wx.ALL, 5 )
584         
585         
586         bSizer11.Add( bSizer13, 1, wx.EXPAND, 5 )
587         
588         
589         bSizer10.Add( bSizer11, 1, wx.EXPAND, 5 )
590         
591         
592         fgSizer51.Add( bSizer10, 1, wx.ALIGN_CENTER_VERTICAL|wx.EXPAND, 5 )
593         
594         self.m_staticline3311 = wx.StaticLine( self.m_panel3, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
595         fgSizer51.Add( self.m_staticline3311, 0, wx.EXPAND |wx.ALL, 5 )
596         
597         self.m_staticline33111 = wx.StaticLine( self.m_panel3, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
598         fgSizer51.Add( self.m_staticline33111, 0, wx.EXPAND |wx.ALL, 5 )
599         
600         bSizer5 = wx.BoxSizer( wx.HORIZONTAL )
601         
602         self.m_staticText21 = wx.StaticText( self.m_panel3, wx.ID_ANY, _(u"Vertex color").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
603         self.m_staticText21.Wrap( -1 )
604         bSizer5.Add( self.m_staticText21, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
605         
606         self.cols = wx.ColourPickerCtrl( self.m_panel3, wx.ID_ANY, wx.Colour( 255, 0, 0 ), wx.DefaultPosition, wx.Size( 10,10 ), wx.CLRP_DEFAULT_STYLE )
607         bSizer5.Add( self.cols, 0, wx.ALL, 5 )
608         
609         
610         fgSizer51.Add( bSizer5, 1, wx.EXPAND, 5 )
611         
612         bSizer6 = wx.BoxSizer( wx.HORIZONTAL )
613         
614         self.m_staticText22 = wx.StaticText( self.m_panel3, wx.ID_ANY, _(u"Edges color").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
615         self.m_staticText22.Wrap( -1 )
616         bSizer6.Add( self.m_staticText22, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
617         
618         self.cola = wx.ColourPickerCtrl( self.m_panel3, wx.ID_ANY, wx.Colour( 208, 208, 208 ), wx.DefaultPosition, wx.DefaultSize, wx.CLRP_DEFAULT_STYLE )
619         bSizer6.Add( self.cola, 0, wx.ALL, 5 )
620         
621         
622         fgSizer51.Add( bSizer6, 1, wx.EXPAND, 5 )
623         
624         self.m_staticline331 = wx.StaticLine( self.m_panel3, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
625         fgSizer51.Add( self.m_staticline331, 0, wx.EXPAND, 5 )
626         
627         self.m_staticline332 = wx.StaticLine( self.m_panel3, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
628         fgSizer51.Add( self.m_staticline332, 0, wx.EXPAND, 5 )
629         
630         self.m_staticText23 = wx.StaticText( self.m_panel3, wx.ID_ANY, _(u"Vertex size").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
631         self.m_staticText23.Wrap( -1 )
632         fgSizer51.Add( self.m_staticText23, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
633         
634         bSizer72 = wx.BoxSizer( wx.HORIZONTAL )
635         
636         self.check_s_size = wx.CheckBox( self.m_panel3, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, 0 )
637         bSizer72.Add( self.check_s_size, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
638         
639         self.spin_tv = wx.SpinCtrl( self.m_panel3, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, wx.SP_ARROW_KEYS, 0, 100, 10 )
640         bSizer72.Add( self.spin_tv, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
641         
642         
643         fgSizer51.Add( bSizer72, 1, wx.EXPAND, 5 )
644         
645         self.m_staticline333 = wx.StaticLine( self.m_panel3, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
646         fgSizer51.Add( self.m_staticline333, 0, wx.EXPAND, 5 )
647         
648         self.m_staticline334 = wx.StaticLine( self.m_panel3, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
649         fgSizer51.Add( self.m_staticline334, 0, wx.EXPAND, 5 )
650         
651         self.m_staticText24 = wx.StaticText( self.m_panel3, wx.ID_ANY, _(u"Spheres transparency").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
652         self.m_staticText24.Wrap( -1 )
653         fgSizer51.Add( self.m_staticText24, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
654         
655         self.slider_sphere = wx.Slider( self.m_panel3, wx.ID_ANY, 10, 0, 100, wx.DefaultPosition, wx.DefaultSize, wx.SL_HORIZONTAL|wx.SL_LABELS )
656         fgSizer51.Add( self.slider_sphere, 0, wx.ALL|wx.EXPAND|wx.ALIGN_CENTER_VERTICAL, 5 )
657         
658         self.m_staticline335 = wx.StaticLine( self.m_panel3, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
659         fgSizer51.Add( self.m_staticline335, 0, wx.EXPAND, 5 )
660         
661         self.m_staticline336 = wx.StaticLine( self.m_panel3, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
662         fgSizer51.Add( self.m_staticline336, 0, wx.EXPAND, 5 )
663         
664         self.m_staticText25 = wx.StaticText( self.m_panel3, wx.ID_ANY, _(u"Make a movie").decode('utf8'), wx.DefaultPosition, wx.DefaultSize, 0 )
665         self.m_staticText25.Wrap( -1 )
666         fgSizer51.Add( self.m_staticText25, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
667         
668         self.film = wx.CheckBox( self.m_panel3, wx.ID_ANY, wx.EmptyString, wx.DefaultPosition, wx.DefaultSize, 0 )
669         fgSizer51.Add( self.film, 0, wx.ALL|wx.ALIGN_CENTER_VERTICAL, 5 )
670         
671         self.m_staticline2918 = wx.StaticLine( self.m_panel3, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
672         fgSizer51.Add( self.m_staticline2918, 0, wx.EXPAND, 5 )
673         
674         self.m_staticline2919 = wx.StaticLine( self.m_panel3, wx.ID_ANY, wx.DefaultPosition, wx.DefaultSize, wx.LI_HORIZONTAL )
675         fgSizer51.Add( self.m_staticline2919, 0, wx.EXPAND, 5 )
676         
677         
678         fgSizer51.AddSpacer( ( 0, 0), 1, wx.EXPAND, 5 )
679         
680         
681         fgSizer5.Add( fgSizer51, 1, wx.EXPAND, 5 )
682         
683         
684         self.m_panel3.SetSizer( fgSizer5 )
685         self.m_panel3.Layout()
686         fgSizer5.Fit( self.m_panel3 )
687         self.m_notebook1.AddPage( self.m_panel3, _(u"Graphical settings").decode('utf8'), False )
688         
689         fgSizer10.Add( self.m_notebook1, 1, wx.EXPAND |wx.ALL, 5 )
690         
691         m_sdbSizer2 = wx.StdDialogButtonSizer()
692         self.m_sdbSizer2OK = wx.Button( self, wx.ID_OK )
693         m_sdbSizer2.AddButton( self.m_sdbSizer2OK )
694         self.m_sdbSizer2Cancel = wx.Button( self, wx.ID_CANCEL )
695         m_sdbSizer2.AddButton( self.m_sdbSizer2Cancel )
696         m_sdbSizer2.Realize();
697         
698         fgSizer10.Add( m_sdbSizer2, 1, wx.EXPAND, 5 )
699         
700         
701         bSizer16.Add( fgSizer10, 1, wx.EXPAND, 5 )
702         
703         
704         self.SetSizer( bSizer16 )
705         self.Layout()
706         bSizer16.Fit( self )
707         
708         self.Centre( wx.BOTH )
709         self.__set_properties()
710  
711         # Connect Events
712        # if not self.paramsimi['first'] :
713        #     self.check_coord.Bind( wx.EVT_CHECKBOX, self.OnKeepCoords )
714        # self.choice3.Bind( wx.EVT_CHOICE, self.OnChangeType )
715        # self.check2.Bind( wx.EVT_CHECKBOX, self.OnCheck2 )
716        # self.checki.Bind( wx.EVT_CHECKBOX, self.OnChecki )
717        # self.check_vcex.Bind( wx.EVT_CHECKBOX, self.OnCheck_vcex )
718        # self.checkit.Bind( wx.EVT_CHECKBOX, self.OnCheckit )
719        # self.check_s_size.Bind( wx.EVT_CHECKBOX, self.OnCheck_s_size )
720         
721         # Connect Events
722         if not self.paramsimi['first'] :
723             self.check_coord.Bind( wx.EVT_CHECKBOX, self.OnKeepCoords )
724         self.choice3.Bind( wx.EVT_CHOICE, self.OnChangeType )
725         self.check2.Bind( wx.EVT_CHECKBOX, self.OnCheck2 )
726         if 'cexfromchi' in self.paramsimi :
727             self.checkit.Bind( wx.EVT_CHECKBOX, self.OnCheckit )
728         if 'sfromchi' in self.paramsimi :
729             self.checki.Bind( wx.EVT_CHECKBOX, self.OnChecki )
730         self.check_vcex.Bind( wx.EVT_CHECKBOX, self.OnCheck_vcex )
731         self.check_s_size.Bind( wx.EVT_CHECKBOX, self.OnCheck_s_size )
732
733     def __set_properties(self):
734         self.choice1.SetSelection(self.paramsimi['coeff'])
735         self.choice2.SetSelection(self.paramsimi['layout'])
736         self.choice3.SetSelection(self.paramsimi['type_graph'])
737         if self.paramsimi['type_graph'] not in  [2,3] :
738             self.film.Enable(False)
739             self.slider_sphere.Enable(False)
740         else :
741             self.film.Enable(True)
742             self.slider_sphere.Enable(True)
743         self.check1.SetValue(self.paramsimi['arbremax'])
744         self.check_vlab.SetValue(self.paramsimi['label_v'])
745         self.check_elab.SetValue(self.paramsimi['label_e'])
746         self.check2.SetValue(self.paramsimi['tvprop'])
747         self.spin_tv.SetValue(self.paramsimi['coeff_tv_nb'])
748         self.check_s_size.SetValue(self.paramsimi['coeff_tv'])
749         self.spin_tvmin.SetValue(self.paramsimi['tvmin'])
750         self.spin_tvmax.SetValue(self.paramsimi['tvmax'])
751         self.check3.SetValue(self.paramsimi['coeff_te'])
752         self.spin_temin.SetValue(self.paramsimi['coeff_temin'])
753         self.spin_temax.SetValue(self.paramsimi['coeff_temax'])
754         self.check_vcex.SetValue(self.paramsimi['vcex'])
755         self.spin_vcexmin.SetValue(self.paramsimi['vcexmin'])
756         self.spin_vcexmax.SetValue(self.paramsimi['vcexmax'])
757         self.spin_cex.SetValue(self.paramsimi['cex'])
758         self.check_seuil.SetValue(self.paramsimi['seuil_ok'])
759         self.spin_seuil.SetValue(self.paramsimi['seuil'])
760         self.cols.SetColour(self.paramsimi['cols'])
761         self.cola.SetColour(self.paramsimi['cola'])
762         self.spin_width.SetValue(self.paramsimi['width'])
763         self.spin_height.SetValue(self.paramsimi['height'])
764         if 'cexfromchi' in self.paramsimi :
765             self.checkit.SetValue(self.paramsimi['cexfromchi'])
766         if 'sfromchi' in self.paramsimi :
767             self.checki.SetValue(self.paramsimi['sfromchi'])
768         if not self.paramsimi['first'] :
769             self.check_coord.SetValue(self.paramsimi['keep_coord'])
770             self.OnKeepCoords(wx.EVT_CHECKBOX)
771         if self.paramsimi.get('bystar', False) :
772             self.check_bystar.SetValue(True)
773             self.stars = self.paramsimi['stars']
774         self.slider_sphere.SetValue(self.paramsimi['alpha'])
775         self.film.SetValue(self.paramsimi['film'])
776         self.comcheck.SetValue(self.paramsimi['com'])
777         self.choix_com.SetSelection(self.paramsimi['communities'])
778         self.halo.SetValue(self.paramsimi['halo'])
779
780     def OnCheck_s_size(self, evt):
781         if self.check_s_size.GetValue() :
782             if 'cexfromchi' in self.paramsimi :
783                 self.checki.SetValue(False)
784             self.check2.SetValue(False)
785             self.spin_tvmin.Enable(False)
786             self.spin_tvmax.Enable(False)
787             self.spin_tv.Enable(True)
788         else :
789             self.check2.SetValue(True)
790             self.spin_tvmin.Enable(True)
791             self.spin_tvmax.Enable(True)
792             self.spin_tv.Enable(False)
793
794     def OnCheck2(self, evt):
795         if self.check2.GetValue():
796             self.check_s_size.SetValue(False)
797             if 'cexfromchi' in self.paramsimi :
798                 self.checki.SetValue(False)
799             self.spin_tvmin.Enable(True)
800             self.spin_tvmax.Enable(True)
801             self.spin_tv.Enable(False)
802         else :
803             self.check_s_size.SetValue(True)
804             self.spin_tvmin.Enable(False)
805             self.spin_tvmax.Enable(False)
806             self.spin_tv.Enable(True)
807
808     def OnChecki(self, evt):
809         if 'sfromchi' in self.paramsimi :
810             if self.checki.GetValue() :
811                 self.check_s_size.SetValue(False)
812                 self.check2.SetValue(False)
813                 self.spin_tvmin.Enable(True)
814                 self.spin_tvmax.Enable(True)
815                 self.spin_tv.Enable(False)
816             else :
817                 self.check_s_size.SetValue(True)
818                 #self.check2.SetValue(True)
819                 self.spin_tvmin.Enable(False)
820                 self.spin_tvmax.Enable(False)
821                 self.spin_tv.Enable(True)
822
823     def OnCheckit(self,evt) :
824         if 'cexfromchi' in self.paramsimi :
825             if self.checkit.GetValue() :
826                 if self.check_vcex.GetValue() :
827                     self.check_vcex.SetValue(False)
828
829     def OnCheck_vcex(self, evt):
830         if self.check_vcex.GetValue() :
831             if 'checkit' in dir(self) :
832                 if self.checkit.GetValue() :
833                     self.checkit.SetValue(False)
834     
835     def OnChangeType(self, event) :
836         if event.GetInt() != 1 :
837             self.spin_width.Enable(False)
838             self.spin_height.Enable(False)
839         else :
840             self.spin_width.Enable(True)
841             self.spin_height.Enable(True)
842         if event.GetInt() not in [2,3] :
843             self.film.Enable(False)
844             self.slider_sphere.Enable(False)
845         else :
846             self.film.Enable(True)
847             self.slider_sphere.Enable(True)
848
849     def OnKeepCoords(self, event):
850         if self.check_coord.GetValue() :
851             self.choice1.SetSelection(self.paramsimi['coeff'])
852             self.choice2.SetSelection(self.paramsimi['layout'])
853             self.check_seuil.SetValue(self.paramsimi['seuil_ok'])
854             self.spin_seuil.SetValue(self.paramsimi['seuil'])
855             self.choice1.Disable()
856             self.choice2.Disable()
857             self.check_seuil.Disable()
858             self.spin_seuil.Disable()
859             #self.check_colch.SetValue(False)
860             #self.check_colch.Disable()
861         else :
862             self.choice1.Enable(True)
863             self.choice2.Enable(True)
864             self.check_seuil.Enable(True)
865             self.spin_seuil.Enable(True)
866             #self.check_colch.Enable(True)
867
868
869 class PrepSimi :
870     def __init__(self, parent, source, parametres, pathout, actives, indices_simi, wordlist = None, selected = None) :    
871         self.parametres = parametres
872         self.etline = []
873         self.dial = PrefSimi(parent, -1, self.parametres, indices_simi, wordlist = wordlist, selected = selected, actives = actives) 
874         self.dial.CenterOnParent()
875         self.val = self.dial.ShowModal()
876         if self.val == wx.ID_OK :
877             if 'bystar' in self.parametres :
878                 if self.dial.check_bystar.GetValue() :
879                     variables = treat_var_mod(self.parametres['stars'])
880                     vardial = dialog.OptLexi(parent, force_chi = True) 
881                     vardial.listet = self.parametres['stars']
882                     vardial.variables = [v for v in variables]
883                     for et in vardial.variables :
884                         vardial.list_box_1.Append(et)
885                     nval = vardial.ShowModal()
886                     if nval == wx.ID_OK :
887                         if vardial.choice.GetSelection() == 1 :
888                             listet = [vardial.listet[i] for i in vardial.list_box_1.GetSelections()]
889                         else :
890                             listet = variables[vardial.variables[vardial.list_box_1.GetSelections()[0]]]
891                         self.dial.Destroy()
892                         vardial.Destroy()
893                         self.etline = source.corpus.make_etline(listet)
894                         self.parametres['selectedstars'] = listet
895                         self.parametres['listet'] = self.etline
896                     else:
897                         vardial.Destroy()
898             last = self.dial.listcol.GetFirstSelected()
899             lastl = [self.dial.listcol.GetFirstSelected()]
900             indexes = [self.dial.listcol.getColumnText(self.dial.listcol.GetFirstSelected(),0)]
901             while self.dial.listcol.GetNextSelected(last) != -1:
902                 last = self.dial.listcol.GetNextSelected(last)
903                 lastl.append(last)
904                 indexes.append(self.dial.listcol.getColumnText(last,0))
905             column = [actives.index(val) for val in indexes]
906             column.sort()
907             with open(pathout, 'w') as f :
908                 f.write('\n'.join([`val` for val in column]))
909             self.make_param()
910             self.dial.Destroy()
911         else :
912             self.dial.Destroy()
913
914     def make_param(self) :
915         #self.select = self.dial.check_colch.GetValue()
916         if self.parametres.get('first', True) :
917             keep_coord = False
918         else :
919             keep_coord = self.dial.check_coord.GetValue()
920         param = {'coeff' : self.dial.choice1.GetSelection(),
921                           'layout' : self.dial.choice2.GetSelection(),
922                           'type_graph' : self.dial.choice3.GetSelection(),
923                           'arbremax' : self.dial.check1.GetValue(),
924                           'coeff_tv' : self.dial.check_s_size.GetValue(),
925                           'coeff_tv_nb' : self.dial.spin_tv.GetValue(),
926                           'tvprop' : self.dial.check2.GetValue(),
927                           'tvmin' : self.dial.spin_tvmin.GetValue(),
928                           'tvmax' : self.dial.spin_tvmax.GetValue(),
929                           'coeff_te' : self.dial.check3.GetValue(),
930                           'coeff_temin' : self.dial.spin_temin.GetValue(),
931                           'coeff_temax' : self.dial.spin_temax.GetValue(),
932                           'label_e' : self.dial.check_elab.GetValue(),
933                           'label_v' : self.dial.check_vlab.GetValue(),
934                           'vcex' : self.dial.check_vcex.GetValue(),
935                           'vcexmin' : self.dial.spin_vcexmin.GetValue(),
936                           'vcexmax' : self.dial.spin_vcexmax.GetValue(),
937                           'cex' : self.dial.spin_cex.GetValue(),
938                           'seuil_ok' : self.dial.check_seuil.GetValue(),
939                           'seuil' : self.dial.spin_seuil.GetValue(),
940                           'cols' : self.dial.cols.GetColour(),
941                           'cola' : self.dial.cola.GetColour(),
942                           'width' : self.dial.spin_width.GetValue(),
943                           'height' : self.dial.spin_height.GetValue(),
944                           'first' : False,
945                           'keep_coord' : keep_coord,
946                           'alpha' : self.dial.slider_sphere.GetValue(),
947                           'film' : self.dial.film.GetValue(),
948                           'svg' : self.dial.choix_format.GetSelection(),
949                           'com'  :self.dial.comcheck.GetValue(),
950                           'communities' : self.dial.choix_com.GetSelection(),
951                           'halo' : self.dial.halo.GetValue(),
952                           }
953         if 'cexfromchi' in self.parametres :
954             param['cexfromchi'] = self.dial.checkit.GetValue()
955         if 'sfromchi' in self.parametres :
956             param['sfromchi'] = self.dial.checki.GetValue()
957             print param
958         if 'vlabcolor' in self.parametres :
959             param['vlabcolor'] = self.parametres['vlabcolor']
960         if 'check_bystar' in dir(self.dial) :
961             param['bystar'] = self.dial.check_bystar.GetValue()
962             param['stars'] = self.parametres['stars']
963         self.parametres.update(param)
964