X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=InterfaceQT4%2FmonChoixCommande.py;h=09a0913f955481628f6db3efeffd633e39e308ef;hb=0dd3754f2c6ebee6f61a7aa505ed8711dd9ba79e;hp=aa84ce6750a07e30b37df6885a22707548822e1a;hpb=9bca5f3f83b5a320d37f6893df7dab4e451d2a66;p=tools%2Feficas.git diff --git a/InterfaceQT4/monChoixCommande.py b/InterfaceQT4/monChoixCommande.py index aa84ce67..09a0913f 100644 --- a/InterfaceQT4/monChoixCommande.py +++ b/InterfaceQT4/monChoixCommande.py @@ -19,29 +19,34 @@ # Modules Python # Modules Eficas +from __future__ import absolute_import +try : + from builtins import str +except : pass + from desChoixCommandes import Ui_ChoixCommandes -from PyQt4 import * -from PyQt4.QtCore import * -from PyQt4.QtGui import * -from PyQt4.QtCore import * +from PyQt5.QtWidgets import QWidget, QAction ,QButtonGroup, QRadioButton, QLabel , QPushButton, QSpacerItem, QSizePolicy, QGridLayout +from PyQt5.QtGui import QIcon, QPixmap +from PyQt5.QtCore import QSize, QRect + from Extensions.i18n import tr import os # Import des panels -class MonChoixCommande(Ui_ChoixCommandes,QtGui.QWidget): +class MonChoixCommande(Ui_ChoixCommandes,QWidget): """ """ def __init__(self,node, jdc_item, editor): - QtGui.QWidget.__init__(self,None) + QWidget.__init__(self,None) self.setupUi(self) self.repIcon=os.path.join( os.path.dirname(os.path.abspath(__file__)),'..','Editeur','icons') iconeFile=os.path.join(self.repIcon,'lettreRblanc30.png') icon = QIcon(iconeFile) self.RBRegle.setIcon(icon) - self.RBRegle.setIconSize(QtCore.QSize(21, 31)) + self.RBRegle.setIconSize(QSize(21, 31)) self.item = jdc_item self.node = node @@ -56,27 +61,29 @@ class MonChoixCommande(Ui_ChoixCommandes,QtGui.QWidget): nouveauTitre=debutTitre self.editor.appliEficas.setWindowTitle(nouveauTitre) - #print self.node.tree - self.connect(self.RBalpha,SIGNAL("clicked()"),self.afficheAlpha) - self.connect(self.RBGroupe,SIGNAL("clicked()"),self.afficheGroupe) - self.connect(self.RBOrdre,SIGNAL("clicked()"),self.afficheOrdre) - self.connect(self.RBClear,SIGNAL("clicked()"),self.clearFiltre) - self.connect(self.RBCasse,SIGNAL("toggled(bool)"),self.ajouteRadioButtons) + self.RBalpha.clicked.connect(self.afficheAlpha) + self.RBGroupe.clicked.connect(self.afficheGroupe) + self.RBOrdre.clicked.connect(self.afficheOrdre) + self.RBClear.clicked.connect(self.clearFiltre) + self.RBCasse.toggled.connect(self.ajouteRadioButtons) + self.LEFiltre.returnPressed.connect(self.ajouteRadioButtons) + self.LEFiltre.textChanged.connect(self.ajouteRadioButtons) + if self.node.tree.item.get_regles() == () : self.RBRegle.close() self.labelRegle.close() - else : self.connect(self.RBRegle,SIGNAL("clicked()"),self.afficheRegle) + else : + self.RBRegle.clicked.connect(self.afficheRegle) if self.editor.Ordre_Des_Commandes == None : self.RBOrdre.close() #self.editor.labelCommentaire.setText("") if self.editor.widgetOptionnel!= None : - self.editor.widgetOptionnel.close() + self.editor.fermeOptionnel() self.editor.widgetOptionnel=None self.name=None - self.connect(self.LEFiltre,SIGNAL("returnPressed()"),self.ajouteRadioButtons) self.affiche_alpha=0 self.affiche_groupe=0 @@ -93,7 +100,10 @@ class MonChoixCommande(Ui_ChoixCommandes,QtGui.QWidget): self.affiche_ordre==1; self.RBOrdre.setChecked(True); self.afficheOrdre() - if self.editor.code == "Adao" : self.frameAffichage.close() + if self.editor.closeFrameRechercheCommande == True : self.frameAffichage.close() + + if self.editor.widgetTree != None : self.editor.restoreSplitterSizes(2) + else: self.editor.restoreSplitterSizes(3) def afficheRegle(self): self.node.tree.AppelleBuildLBRegles() @@ -116,7 +126,10 @@ class MonChoixCommande(Ui_ChoixCommandes,QtGui.QWidget): self.affiche_ordre=1 self.ajouteRadioButtons() - def mouseDoubleClickEvent(self,event): + def insereNoeudApresClick(self,event): + #print self.editor.Classement_Commandes_Ds_Arbre + #if self.editor.Classement_Commandes_Ds_Arbre!= () : self.chercheOu() + #print ('dans insereNoeudApresClick') nodeCourrant=self.node.tree.currentItem() if nodeCourrant==None: nodeCourrant=self.node.tree.racine if self.name != None : @@ -138,13 +151,14 @@ class MonChoixCommande(Ui_ChoixCommandes,QtGui.QWidget): self.node.setSelected(False) nouveau.setSelected(True) self.node.tree.setCurrentItem(nouveau) - event.accept() + if event != None : event.accept() + def creeListeCommande(self,filtre): listeGroupes,dictGroupes=self.jdc.get_groups() sensibleALaCasse=self.RBCasse.isChecked() - if "CACHE" in dictGroupes.keys(): + if "CACHE" in dictGroupes: aExclure=dictGroupes["CACHE"] else: aExclure=() @@ -157,15 +171,21 @@ class MonChoixCommande(Ui_ChoixCommandes,QtGui.QWidget): return listeACreer def ajouteRadioButtons(self): + if self.editor.nombreDeBoutonParLigne != 0 : + self.ajoutePushButtons() + return + #print 'ds ajouteRadioButtons' filtre=str(self.LEFiltre.text()) if filtre==str("") : filtre=None if hasattr(self,'buttonGroup') : for b in self.buttonGroup.buttons(): self.buttonGroup.removeButton(b) + b.setParent(None) b.close() else : self.buttonGroup = QButtonGroup() for w in self.listeWidget : + w.setParent(None) w.close() self.listeWidget=[] if self.affiche_alpha==1 : @@ -175,14 +195,15 @@ class MonChoixCommande(Ui_ChoixCommandes,QtGui.QWidget): rbcmd=(QRadioButton(tr(cmd))) self.buttonGroup.addButton(rbcmd) self.commandesLayout.addWidget(rbcmd) - rbcmd.mouseDoubleClickEvent=self.mouseDoubleClickEvent - self.connect(self.buttonGroup, SIGNAL("buttonClicked(QAbstractButton*)"),self.rbClique) + if self.editor.simpleClic : rbcmd.mouseReleaseEvent=self.insereNoeudApresClick + else : rbcmd.mouseDoubleClickEvent=self.insereNoeudApresClick + self.buttonGroup.buttonClicked.connect(self.rbClique) elif self.affiche_groupe==1 : listeGroupes,dictGroupes=self.jdc.get_groups() for grp in listeGroupes: if grp == "CACHE" : continue label=QLabel(self) - text=QString.fromUtf8('

Groupe : '+tr(grp)+'

') + text=tr('

Groupe : '+tr(grp)+'

') label.setText(text) self.listeWidget.append(label) aAjouter=1 @@ -197,8 +218,9 @@ class MonChoixCommande(Ui_ChoixCommandes,QtGui.QWidget): rbcmd=(QRadioButton(tr(cmd))) self.buttonGroup.addButton(rbcmd) self.commandesLayout.addWidget(rbcmd) - rbcmd.mouseDoubleClickEvent=self.mouseDoubleClickEvent - self.connect(self.buttonGroup, SIGNAL("buttonClicked(QAbstractButton*)"),self.rbClique) + if self.editor.simpleClic : rbcmd.mouseReleaseEvent=self.insereNoeudApresClick + else : rbcmd.mouseDoubleClickEvent=self.insereNoeudApresClick + self.buttonGroup.buttonClicked.connect(self.rbClique) label2=QLabel(self) label2.setText(" ") self.listeWidget.append(label2) @@ -216,17 +238,69 @@ class MonChoixCommande(Ui_ChoixCommandes,QtGui.QWidget): rbcmd=(QRadioButton(tr(cmd))) self.buttonGroup.addButton(rbcmd) self.commandesLayout.addWidget(rbcmd) - rbcmd.mouseDoubleClickEvent=self.mouseDoubleClickEvent - self.connect(self.buttonGroup, SIGNAL("buttonClicked(QAbstractButton*)"),self.rbClique) + if self.editor.simpleClic : rbcmd.mouseReleaseEvent=self.insereNoeudApresClick + else : rbcmd.mouseDoubleClickEvent=self.insereNoeudApresClick + self.buttonGroup.buttonClicked.connect(self.rbClique) + def ajoutePushButtons(self): + if hasattr(self,'buttonGroup') : + for b in self.buttonGroup.buttons(): + self.buttonGroup.removeButton(b) + b.setParent(None) + b.close() + else : + self.buttonGroup = QButtonGroup() + self.buttonGroup.buttonClicked.connect(self.rbCliqueEtInsere) + for w in self.listeWidget : + w.setParent(None) + w.close() + self.listeWidget=[] + + if not hasattr(self,'maGrilleBouton') : + #self.commandesLayout.close() + self.maGrilleBouton=QGridLayout() + self.maGrilleBouton.setSpacing(20) + self.verticalLayout.addLayout(self.maGrilleBouton) + col=-1 + ligne = 0 + if self.affiche_alpha==1 : + liste=self.creeListeCommande(None) + for cmd in liste : + col=col+1 + if col == self.editor.nombreDeBoutonParLigne : + col=0 + ligne=ligne+1 + self.dicoCmd[tr(cmd)]=cmd + rbcmd=QPushButton(tr(cmd)) + rbcmd.setGeometry(QRect(40, 20, 211, 71)) + rbcmd.setMaximumSize(QSize(250, 81)) + rbcmd.setStyleSheet("background-color : rgb(66, 165, 238);\n" +"/*border-style : outset;*/\n" +"border-radius : 20px;\n" +"border-width : 30 px;\n" +"border-color : beige;\n" +"text-align : center") + if cmd in self.editor.dicoImages : + fichier=self.editor.dicoImages[cmd] + icon = QIcon() + icon.addPixmap(QPixmap(fichier), QIcon.Normal, QIcon.Off) + rbcmd.setIcon(icon) + rbcmd.setIconSize(QSize(48, 48)) + + self.buttonGroup.addButton(rbcmd) + self.maGrilleBouton.addWidget(rbcmd,ligne,col) def clearFiltre(self): self.LEFiltre.setText("") self.ajouteRadioButtons() + def rbCliqueEtInsere(self,id): + self.rbClique(id) + self.insereNoeudApresClick(None) + def rbClique(self,id): - self.name=self.dicoCmd[str(id.text().toLatin1())] + self.name=self.dicoCmd[str(id.text())] definitionEtape=getattr(self.jdc.cata[0],self.name) commentaire=getattr(definitionEtape,self.jdc.lang) try :