]> SALOME platform Git repositories - tools/eficas.git/blob - Editeur/uniquecomppanel.py
Salome HOME
pour les complexes de la forme 3+1j
[tools/eficas.git] / Editeur / uniquecomppanel.py
1 # -*- coding: utf-8 -*-
2 #            CONFIGURATION MANAGEMENT OF EDF VERSION
3 # ======================================================================
4 # COPYRIGHT (C) 1991 - 2002  EDF R&D                  WWW.CODE-ASTER.ORG
5 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
6 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
7 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
8 # (AT YOUR OPTION) ANY LATER VERSION.
9 #
10 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
11 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
12 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
13 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.
14 #
15 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
16 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
17 #    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
18 #
19 #
20 # ======================================================================
21 # Modules Python
22 import string,types,os
23 from Tkinter import *
24 import Pmw
25 from copy import copy,deepcopy
26 import traceback
27
28 # Modules Eficas
29 import Objecttreeitem
30 import prefs
31 import panels
32 import images
33 from widgets import ListeChoix
34 from widgets import FenetreDeSelection
35
36 from Noyau.N_CR import justify_text
37 from utils import substract_list
38
39 # Import des panels
40 from uniquepanel import UNIQUE_Panel
41
42       
43 class UNIQUE_COMP_Panel(UNIQUE_Panel):
44   """
45   Classe servant à définir le panneau associé aux mots-clés simples
46   qui attendent une valeur de type complexe
47   """
48   def makeValeurPage(self,page):
49       """
50       Génère la page de saisie de la valeur du mot-clé simple courant qui doit être de type
51       de base cad entier, réel, string ou complexe
52       """
53       # Récupération de l'aide associée au panneau et de l'aide destinée à l'utilisateur
54       bulle_aide=self.get_bulle_aide()
55       aide=self.get_aide()
56       aide= justify_text(texte=aide)
57       # Remplissage du panneau
58       self.frame_valeur = Frame(page)
59       self.frame_valeur.pack(fill='both',expand=1)
60       self.frame_valeur.bind("<Button-3>",lambda e,s=self,a=bulle_aide : s.parent.appli.affiche_aide(e,a))
61       self.frame_valeur.bind("<ButtonRelease-3>",self.parent.appli.efface_aide)
62       self.label = Label(self.frame_valeur,text='Valeur :')
63       self.label.place(relx=0.1,rely=0.7)
64       self.typ_cplx=StringVar()
65       self.typ_cplx.set('RI')
66       rb1 = Radiobutton(self.frame_valeur, text='RI',variable=self.typ_cplx,value='RI')
67       rb2 = Radiobutton(self.frame_valeur, text='MP',variable=self.typ_cplx,value='MP')
68       rb1.place(relx=0.05,rely = 0.6)
69       rb2.place(relx=0.05,rely = 0.8)
70       self.entry1 = Pmw.EntryField(self.frame_valeur,validate='real')
71       self.entry2 = Pmw.EntryField(self.frame_valeur,validate='real')
72       self.entry3 = Pmw.EntryField(self.frame_valeur)
73       self.entry1.component('entry').bind("<Return>",lambda e,s=self:s.entry2.component('entry').focus())
74       self.entry1.component('entry').bind("<KP_Enter>",lambda e,s=self:s.entry2.component('entry').focus())
75       self.entry2.component('entry').bind("<Return>",lambda e,c=self.valid_valeur:c())
76       self.entry2.component('entry').bind("<KP_Enter>",lambda e,c=self.valid_valeur:c())
77       self.entry3.component('entry').bind("<Return>",lambda e,c=self.valid_complexe:c())
78       self.entry3.component('entry').bind("<KP_Enter>",lambda e,c=self.valid_complexe:c())
79       self.entry1.place(relx=0.27,rely = 0.7,relwidth=0.35)
80       self.entry2.place(relx=0.65,rely = 0.7,relwidth=0.35)
81       self.entry3.place(relx=0.27,rely = 0.4,relwidth=0.60)
82       self.entry1.focus()
83       self.frame_valeur.update()
84       self.aide = Label(self.frame_valeur,
85                         text = aide,
86                         wraplength=int(self.frame_valeur.winfo_width()*0.8),
87                         justify='center')
88       self.aide.place(relx=0.5,rely=0.9,anchor='n')
89       # affichage de la valeur du MCS
90       self.display_valeur()
91
92   def display_valeur(self):
93       """
94       Affiche la valeur de l'objet pointé par self
95       """
96       valeur = self.node.item.get_valeur()
97       if valeur == None or valeur == '' : return # pas de valeur à afficher ...
98       self.entry1.delete(0,END)
99       self.entry2.delete(0,END)
100       self.entry3.delete(0,END)
101       if type(valeur) not in (types.ListType,types.TupleType) :
102          self.display_complexe
103       else:
104          typ_cplx,x1,x2=valeur
105          self.typ_cplx.set(typ_cplx)
106          self.entry1.setentry(x1)
107          self.entry2.setentry(x2)
108
109   def display_complexe(self):
110       valeur = self.node.item.get_valeur()
111       self.entry3.setentry(valeur)
112
113   def get_bulle_aide(self):
114       """
115       Retourne la bulle d'aide du panneau
116       """
117       return """-Choisissez votre format de saisie du complexe :
118       \t 'RI' = parties réelle et imaginaire
119       \t 'MP' = module/phase (en degrés)
120       - Saisissez ensuite dans les deux zones de saisie les deux nombres attendus"""
121
122   def get_aide(self):
123       """
124       Retourne la phrase d'aide décrivant le type de la valeur que peut prendre
125       le mot-clé simple courant
126       """
127       commentaire='Un complexe est attendu'
128       aideval=self.node.item.aide()
129       commentaire=commentaire +"\n"+ aideval
130       return commentaire
131
132   def get_valeur(self):
133       """
134       Retourne le complexe saisi par l'utilisateur
135       """
136       l=[]
137       l.append(self.typ_cplx.get())
138       l.append(string.atof(self.entry1.get()))
139       l.append(string.atof(self.entry2.get()))
140       return `tuple(l)`
141
142   def erase_valeur(self):
143       """
144       Efface les entries de saisie
145       """
146       self.typ_cplx.set('RI')
147       self.entry1.delete(0,END)
148       self.entry2.delete(0,END)
149       
150   def valid_complexe(self):
151       valeurentree=self.entry3.get()
152       self.valid_valeur(valeurentree=valeurentree)