dm.py 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630
  1. #from __future__ import unicode_literals
  2. # -*- coding: utf-8 -*-
  3. """ensemble des widgets surchargés"""
  4. from PyQt4.QtCore import *
  5. from PyQt4.QtGui import *
  6. try:
  7. from lib.outilsSvg import *
  8. import lib.regles as regles
  9. from lib.Actions import *
  10. except:
  11. try:
  12. from outilsSvg import *
  13. import regles as regles
  14. from Actions import *
  15. except:
  16. pass
  17. class DmLabel(QLabel):
  18. """surcharge de QLabel"""
  19. def __init__(self, parent = None):
  20. super(DmLabel, self).__init__(parent)
  21. def majTexte(self, txt):
  22. self.clear()
  23. self.setText(QString.fromUtf8(txt))
  24. def chargerImage(self, chemin):
  25. self.clear()
  26. if len(chemin) > 0:
  27. pix = QPixmap(QString.fromUtf8(chemin))
  28. pix = pix.scaled(self.width(), self.height(), Qt.KeepAspectRatio, Qt.SmoothTransformation)
  29. else:
  30. pix = QPixmap()
  31. self.setPixmap(pix)
  32. def texte(self):
  33. return str(self.text().toUtf8())
  34. class DmLabelChoixImage(DmLabel):
  35. """surcharge de DmLabel,
  36. affiche une fenetre de selection de fichier, recupere une image,
  37. et l'affiche."""
  38. def __init__(self, parent = None):
  39. super(DmLabelChoixImage, self).__init__(parent)
  40. self.setStyleSheet("QLabel { padding: 3px; }")
  41. self._sourceImage = ""
  42. def mousePressEvent(self, event):
  43. if event.button() == 1:
  44. self.selectionImage()
  45. def selectionImage(self):
  46. fichier = QFileDialog.getOpenFileName(self,
  47. "Selectionnez une image",
  48. "\\img",
  49. "Images (*.png *.jpg)")
  50. if len(fichier) > 0:
  51. pix = QPixmap(fichier)
  52. if not pix.isNull():
  53. self._sourceImage = fichier
  54. self.clear()
  55. pix = pix.scaled(self.width(), self.height(), Qt.KeepAspectRatio, Qt.SmoothTransformation)
  56. self.setPixmap(pix)
  57. self.emit(SIGNAL("imageModifiee()"))
  58. else:
  59. dial = QMessageBox(self)
  60. dial.setText("Format non reconnu")
  61. dial.setWindowTitle("Erreur")
  62. dial.setStandardButtons(QMessageBox.Ok)
  63. dial.exec_()
  64. def image(self):
  65. """retourne le chemin de l'image chargee"""
  66. return self._sourceImage
  67. def chargerImage(self, chemin):
  68. self._sourceImage = chemin
  69. super(DmLabelChoixImage, self).chargerImage(chemin)
  70. class DmTextEdit(QTextEdit):
  71. def __init__(self, parent = None):
  72. super(DmTextEdit, self).__init__(parent)
  73. def majTexte(self, txt):
  74. self.clear()
  75. self.setText(QString.fromUtf8(str(txt)))
  76. def texte(self):
  77. return str(self.toPlainText().toUtf8())
  78. class DmLineEdit(QLineEdit):
  79. def __init__(self, parent = None):
  80. super(DmLineEdit, self).__init__(parent)
  81. def majTexte(self, txt):
  82. self.clear()
  83. self.setText(QString.fromUtf8(str(txt)))
  84. def texte(self):
  85. return str(self.text().toUtf8())
  86. class DmGraphicsView(QGraphicsView):
  87. """surcharge de QGraphicsView"""
  88. def __init__(self, parent = None):
  89. super(DmGraphicsView, self).__init__(parent)
  90. self.nbZoomActuel = 0
  91. def resizeEvent(self, event):
  92. super(DmGraphicsView, self).resizeEvent(event)
  93. self.emit(SIGNAL("resizeEvent()"))
  94. def wheelEvent(self, event):
  95. """zoom/dezoom avec la molette de la souris"""
  96. #on zoom/dezoom et on recentre sur la position du curseur
  97. zoom = 1.00
  98. if event.delta() > 0:
  99. if self.nbZoomActuel <= 10:
  100. self.nbZoomActuel += 1
  101. zoom = 1.25
  102. elif event.delta() < 0:
  103. if self.nbZoomActuel >= -10:
  104. zoom = 0.8
  105. self.nbZoomActuel -= 1
  106. if zoom != 0.00:
  107. self.scale(zoom, zoom)
  108. self.centerOn(self.mapToScene(event.pos()))
  109. event.accept() #pour considerer l'evenement comme resolu, sans ca les barres de defilement reagissent aussi
  110. class DmComboBox(QComboBox):
  111. """surcharge de QComboBox"""
  112. def __init__(self, parent = None):
  113. super(DmComboBox, self).__init__(parent)
  114. def allerA(self, donnee):
  115. """cherche la donnee demandee et affiche la ligne"""
  116. index = self.findData(QVariant(donnee))
  117. self.setCurrentIndex(index)
  118. def valeurActuelle(self):
  119. """renvoie sous forme de QVariant la valeur en cours"""
  120. return self.itemData(self.currentIndex())
  121. class DmTableWidget(QTableWidget):
  122. """surcharge de QTableWidget"""
  123. def __init__(self, parent = None):
  124. super(DmTableWidget, self).__init__(parent)
  125. self.majEnCours = False
  126. def vider(self):
  127. """supprime toutes les lignes"""
  128. self.majEnCours = True
  129. while self.rowCount() > 0:
  130. self.removeRow(0)
  131. self.majEnCours = False
  132. def nouvelleLigneFin(self):
  133. """ajoute une ligne en derniere position"""
  134. pos = self.rowCount()
  135. self.insertRow(pos)
  136. return pos
  137. def lignes(self):
  138. """retourne la liste des index de lignes de la table"""
  139. return range(0, self.rowCount())
  140. def colonnes(self):
  141. """retourne la liste des index de lignes de la table"""
  142. return range(0, self.columnCount())
  143. def masquerColonneId(self):
  144. """masque la colonne en position 0 qui contient les identifiants"""
  145. self.setColumnWidth(0, 0)
  146. def majData(self, ligne, colonne, var):
  147. """met a jour la cellule avec une donnee de type QVariant"""
  148. var = QVariant(var)
  149. self.item(ligne, colonne).setData(0, var)
  150. return True
  151. def majTexte(self, ligne, colonne, texte):
  152. """met a jour la cellule avec du texte"""
  153. if not self.item(ligne, colonne):
  154. self.setItem(ligne, colonne, QTableWidgetItem(QString.fromUtf8(str(texte))))
  155. else:
  156. self.item(ligne, colonne).setText(QString.fromUtf8(str(texte)))
  157. return True
  158. def majEnt(self, ligne, colonne, valeur):
  159. """met a jour la cellule avec une valeur numerique entiere
  160. si valeur ne peut etre converti en numerique, on retourne Faux"""
  161. retour = False
  162. try:
  163. entier = QVariant(long(valeur))
  164. self.item(ligne, colonne).setData(0, entier)
  165. retour = True
  166. except:
  167. pass
  168. return retour
  169. def chercherLigne(self, colonne, valeur):
  170. """cherche la valeur dans la colonne demandee
  171. renvoie la ligne correspondante """
  172. ligne = None
  173. for i in range(0, self.rowCount()):
  174. if str(self.item(i, colonne).text().toUtf8()) == str(valeur):
  175. ligne = i
  176. break
  177. return ligne
  178. def majLigne(self, ligne, dico, flags = []):
  179. """rempli la ligne avec les donnees trouvees dans le dictionnaire"""
  180. for colonne in range(0, self.columnCount()):
  181. nomChamp = ""
  182. item = self.horizontalHeaderItem(colonne)
  183. if item:
  184. nomChamp = str(item.text())
  185. if nomChamp in dico:
  186. item = QTableWidgetItem()
  187. for f in flags:
  188. item.setFlag(f)
  189. var = QVariant(dico[nomChamp])
  190. item.setData(0, var)
  191. self.setItem(ligne, colonne, item)
  192. def texte(self, ligne, colonne):
  193. return str(self.item(ligne, colonne).text().toUtf8())
  194. def data(self, ligne, colonne):
  195. retour = None
  196. item = self.item(ligne, colonne)
  197. if item:
  198. retour = item.data(0)
  199. return retour
  200. def ligneSelectionnee(self):
  201. """renvoie la ligne selectionnee (la premiere si plusieurs le sont)"""
  202. return self.currentRow()
  203. def selectionner(self, ligne, colonne):
  204. self.setCurrentCell(ligne, colonne, QItemSelectionModel.Select)
  205. class DmTableBiblio(DmTableWidget):
  206. """table utilisee pour afficher les bibliotheques d'objets:
  207. terrains, decors, creatures"""
  208. def __init__(self, parent = None):
  209. super(DmTableBiblio, self).__init__(parent)
  210. self.fichier = ""
  211. self.masquerColonneId()
  212. def defFichier(self, fichier):
  213. """definit le fichier de sauvegarde qui la source des donnees de la table"""
  214. self.fichier = fichier
  215. def initAffichage(self):
  216. """fait les differents reglages relatifs a l'apparence"""
  217. self.setColumnWidth(0, 0)
  218. self.setIconSize(QSize(30,20))
  219. self.horizontalHeader().setStretchLastSection(True)
  220. def remplir(self):
  221. """remplit la table avec les donnees contenues dans le dictionnaire de la savuvegarde"""
  222. dico = afficheSvg(self.fichier)
  223. self.majEnCours = True
  224. self.setSortingEnabled(False)
  225. index = 0
  226. for elt in dico:
  227. objet = dico[elt]
  228. self.insertRow(int(index))
  229. #code de l'objet
  230. self.setItem(int(index),0,QTableWidgetItem(QString.fromUtf8(elt)))
  231. #icone et nom
  232. icon = QIcon(objet.icone())
  233. item = QTableWidgetItem(icon,QString.fromUtf8(objet.nom))
  234. self.setItem(int(index),1,item)
  235. index += 1
  236. self.sizeHintForColumn(1)
  237. self.setSortingEnabled(True)
  238. self.sortItems(1)
  239. self.majEnCours = False
  240. def maj(self):
  241. self.vider()
  242. self.remplir()
  243. def actuel(self):
  244. """renvoie l'objet actuellement selectionne"""
  245. objet = None
  246. index = self.item(self.currentRow(), 0)
  247. if index > 0:
  248. objet = charger(self.fichier, str(index.text().toUtf8()))
  249. return objet
  250. class DmTableAttributsPi(DmTableWidget):
  251. """table utilisee pour afficher les attributs d'un pion dans le panneau Pi"""
  252. def __init__(self, parent = None):
  253. super(DmTableBiblio, self).__init__(parent)
  254. self.fichier = ""
  255. self.masquerColonneId()
  256. def defFichier(self, fichier):
  257. """definit le fichier de sauvegarde qui la source des donnees de la table"""
  258. self.fichier = fichier
  259. def initAffichage(self):
  260. """fait les differents reglages relatifs a l'apparence"""
  261. self.setColumnWidth(0, 0)
  262. self.setIconSize(QSize(30,20))
  263. self.horizontalHeader().setStretchLastSection(True)
  264. def remplir(self):
  265. """remplit la table avec les donnees contenues dans le dictionnaire de la savuvegarde"""
  266. dico = afficheSvg(self.fichier)
  267. self.majEnCours = True
  268. self.setSortingEnabled(False)
  269. index = 0
  270. for elt in dico:
  271. objet = dico[elt]
  272. self.insertRow(int(index))
  273. #code de l'objet
  274. self.setItem(int(index),0,QTableWidgetItem(QString.fromUtf8(elt)))
  275. #icone et nom
  276. icon = QIcon("img\\"+objet.icone())
  277. item = QTableWidgetItem(icon,QString.fromUtf8(objet.nom))
  278. self.setItem(int(index),1,item)
  279. index += 1
  280. self.sizeHintForColumn(1)
  281. self.setSortingEnabled(True)
  282. self.sortItems(1)
  283. self.majEnCours = False
  284. def maj(self):
  285. self.vider()
  286. self.remplir()
  287. def actuel(self):
  288. """renvoie l'objet actuellement selectionne"""
  289. objet = None
  290. index = self.item(self.currentRow(), 0)
  291. if index > 0:
  292. objet = charger(self.fichier, str(index.text().toUtf8()))
  293. return objet
  294. class DmTableInventaire(DmTableWidget):
  295. """table utilisee pour afficher l'inventaire d'un combattant"""
  296. itemExited = pyqtSignal(QTableWidgetItem)
  297. def __init__(self, parent = None):
  298. super(DmTableInventaire, self).__init__(parent)
  299. self._inventaire = []
  300. self._ligneSurvolee = None
  301. #pour la gestion des survols
  302. self.setMouseTracking(True)
  303. self._last_index = QPersistentModelIndex()
  304. self.viewport().installEventFilter(self)
  305. self.connect(self, SIGNAL("itemEntered(QTableWidgetItem*)"), self.itemSurvole)
  306. self.connect(self, SIGNAL("itemExited(QTableWidgetItem*)"), self.itemSurvoleFin)
  307. self.connect(self, SIGNAL("itemClicked(QTableWidgetItem*)"), self.itemClique)
  308. def construire(self):
  309. self.setColumnWidth(0, 40)
  310. self.setColumnWidth(1, 311)
  311. self.setColumnWidth(2, 60)
  312. self.setColumnWidth(3, 60)
  313. self.setColumnWidth(4, 20)
  314. ## for col in self.colonnes():
  315. ## item = QTableWidgetItem()
  316. ## item.setFlags(Qt.NoItemFlags)
  317. ## if col == 1:
  318. ## item.setText(0, " ")
  319. ## item.setData(0, " ")
  320. ## self.setItem(ligne, col, item)
  321. ## self._inventaire.append(objet)
  322. def ajouterObjet(self, objet):
  323. ligne = self.rowCount() - 1 #avant la ligne 'ajouter'
  324. self.insertRow(ligne)
  325. donnees = [objet.quantite, objet.nom, objet.valeurTotale(), objet.poidsTotal(), ""]
  326. for col in self.colonnes():
  327. item = QTableWidgetItem()
  328. item.setFlags(Qt.NoItemFlags)
  329. item.setData(0, donnees[col])
  330. self.setItem(ligne, col, item)
  331. self._inventaire.append(objet)
  332. def charger(self, inventaire):
  333. """charge l'inventaire en parametre"""
  334. self._inventaire = inventaire
  335. for objet in inventaire:
  336. self.ajouterObjet(objet)
  337. def majObjet(self, objet):
  338. """maj la ligne correspondant a l'objet"""
  339. pass
  340. def supprimerObjet(self, objet):
  341. """ajoute la ligne correspondant a l'objet"""
  342. pass
  343. def inventaire(self):
  344. """cree un inventaire a partir des donnees de la table"""
  345. return self._inventaire
  346. def itemSurvole(self, item):
  347. ligne = item.row()
  348. self.majCouleurLigne(ligne, QColor(150, 50, 50, 150))
  349. def itemSurvoleFin(self, item):
  350. ligne = item.row()
  351. self.majCouleurLigne(ligne, QColor(248, 248, 248, 150))
  352. def itemClique(self, item):
  353. ligne = item.row()
  354. self.emit(SIGNAL("objetClique(int)"), ligne)
  355. def majCouleurLigne(self, ligne, couleur):
  356. """modifie la couleur de fond des items de la lignes"""
  357. for col in self.colonnes():
  358. item = self.item(ligne, col)
  359. if item:
  360. item.setBackground(QBrush(couleur))
  361. def eventFilter(self, widget, event):
  362. if widget is self.viewport():
  363. index = self._last_index
  364. if event.type() == QEvent.MouseMove:
  365. index = self.indexAt(event.pos())
  366. elif event.type() == QEvent.Leave:
  367. index = QModelIndex()
  368. if index != self._last_index:
  369. row = self._last_index.row()
  370. column = self._last_index.column()
  371. item = self.item(row, column)
  372. if item is not None:
  373. self.itemExited.emit(item)
  374. self._last_index = QPersistentModelIndex(index)
  375. return QTableWidget.eventFilter(self, widget, event)
  376. ##class DmTableListeAttaques(DmTableWidget):
  377. ## """liste des attaques du combattant"""
  378. ## def __init__(self, parent = None):
  379. ## super(DmTableListeAttaques, self).__init__(parent)
  380. ## self.panneau = None
  381. ## self._listeAttaques = []
  382. ## self.connect(self, SIGNAL("currentCellChanged(int, int, int, int)"), self.selectionChangee)
  383. ##
  384. ## def listeAttaques(self):
  385. ## #on recupere les donnees de l'attaque en cours avant d'exporter la liste
  386. ## self.enregistrerPanneau(self.ligneSelectionnee())
  387. ## return self._listeAttaques
  388. ##
  389. ## def attaqueSelectionnee(self):
  390. ## """renvoie l'attaque selectionnee"""
  391. ## retour = None
  392. ## if len(self._listeAttaques) > 0 and self.ligneSelectionnee() != None:
  393. ## retour = self._listeAttaques[self.ligneSelectionnee()]
  394. ## return retour
  395. ##
  396. ## def majAttaque(self, index, nouvelle):
  397. ## """met a jour les donnees de l'attaque en position x"""
  398. ## self._listeAttaques[index] = nouvelle
  399. ##
  400. ## def charger(self, fenetre, listeAttaques):
  401. ## self.panneau = fenetre.ui.edc_attaque_panneau
  402. ## self._listeAttaques = listeAttaques
  403. ## self.peupler()
  404. ## self.selectionner(0, 0)
  405. ## self.majPanneau()
  406. ##
  407. ## def peupler(self):
  408. ## self.vider()
  409. ## for attaque in self._listeAttaques:
  410. ## ligne = self.nouvelleLigneFin()
  411. ## self.setItem(ligne, 0, QTableWidgetItem(attaque.icone(), QString.fromUtf8(attaque.nom())))
  412. ##
  413. ## def majPanneau(self):
  414. ## """met a jour les donnees du panneau"""
  415. ## self.panneau.chargerAttaque(self.attaqueSelectionnee())
  416. ##
  417. ## def enregistrerPanneau(self, ligne):
  418. ## """enregistre les donnees du panneau sur l'attaque de la ligne"""
  419. ## attaque = self.panneau.attaque()
  420. ## if attaque:
  421. ## self._listeAttaques[ligne] = attaque
  422. ## self.peupler()
  423. ##
  424. ## def nouvelle(self):
  425. ## attaque = Cac()
  426. ## self._listeAttaques.append(attaque)
  427. ## self.peupler()
  428. ## self.selectionner(self.rowCount(), 0)
  429. ##
  430. ## def supprimer(self):
  431. ## """supprime l'attaque actuellement selectionnee"""
  432. #### ligne = self.ligneSelectionnee()
  433. ## self._listeAttaques.remove(self.attaqueSelectionnee())
  434. ## self.peupler()
  435. #### self.selectionner(ligne, 0)
  436. #### self.removeRow(self.ligneSelectionnee())
  437. ##
  438. ## def selectionChangee(self, ancienneLigne, ancienneColonne, ligne, colonne):
  439. ## self.enregistrerPanneau(ancienneLigne)
  440. ## self.panneau.chargerAttaque(None)
  441. ## self.majPanneau()
  442. #### self.emit(SIGNAL("selectionChangee(int, int)"), ancienneLigne, ligne)
  443. ##
  444. ##
  445. ##
  446. ##class DmTableAttributsAttaque(DmTableWidget):
  447. ## """table contenant les attributs (selon regles) d'une attaque"""
  448. ## def __init__(self, parent = None):
  449. ## super(DmTableAttributsAttaque, self).__init__(parent)
  450. ## self._constr = False
  451. ##
  452. ## def attributs(self):
  453. ## """retourne un dictionnaire contenant les attributs"""
  454. ## dico = {}
  455. ## for ligne in self.lignes():
  456. ## nomAttr = regles.ordreAttributsAttaques()[ligne]
  457. ## dico[nomAttr] = regles.attributAttaque(nomAttr).controler(self.texte(ligne, 1))
  458. ## return dico
  459. ##
  460. ## def construire(self):
  461. ## """cree les lignes et remplit la colonne des noms d'attributs"""
  462. ## for nomAttribut in regles.ordreAttributsAttaques():
  463. ## attribut = regles.attributAttaque(nomAttribut)
  464. ## ligne = self.nouvelleLigneFin()
  465. ## self.majTexte(ligne, 0, attribut.nom)
  466. ## self.majTexte(ligne, 1, "")
  467. ## self._constr = True
  468. ##
  469. ## def charger(self, attributs):
  470. ## """charge les attributs d'une attaque"""
  471. ## self.decharger()
  472. ## for ligne in self.lignes():
  473. ## attr = regles.ordreAttributsAttaques()[ligne]
  474. ## valeur = attributs[attr]
  475. ## self.majTexte(ligne, 1, valeur)
  476. ##
  477. ## def decharger(self):
  478. ## """efface les valeurs de la colonne des valeurs,
  479. ## mais laisse intacte la colonne des noms d'attributs"""
  480. ## if not self._constr:
  481. ## self.contruire()
  482. ## else:
  483. ## for ligne in self.lignes():
  484. ## self.majTexte(ligne, 1, "")
  485. ##
  486. class DmTableMenu(QTableWidget):
  487. """table utilisee comme barre d'onglets verticale"""
  488. def __init__(self, parent = None):
  489. super(DmTableMenu, self).__init__(parent)
  490. def setItem(self, ligne, colonne, item):
  491. super(DmTableMenu, self).setItem(ligne, colonne, item)
  492. if ligne == 0:
  493. self.setItemSelected(item, True)
  494. class DmFrameInf_Combattant(QGroupBox):
  495. """frame d'information (combattant)"""
  496. def __init__(self, parent = None):
  497. super(DmFrameInf_Combattant, self).__init__(parent)
  498. def maj(self, combattant):
  499. self.setVisible((combattant != None))
  500. if combattant:
  501. self.findChild(DmLabel, "inf_pionNom").majTexte(combattant.nom)
  502. self.findChild(DmLabel, "inf_pionImage").chargerImage("img\\"+combattant.img.nomFichier)
  503. self.findChild(DmLabel, "inf_pionEffet").setVisible(False)
  504. class DmFrameInf_Decor(QGroupBox):
  505. """frame d'information (decor)"""
  506. def __init__(self, parent = None):
  507. super(DmFrameInf_Decor, self).__init__(parent)
  508. def maj(self, decor):
  509. self.setVisible((decor != None))
  510. if decor:
  511. self.findChild(DmLabel, "inf_decorNom").majTexte(decor.nom)
  512. self.findChild(DmLabel, "inf_decorImage").chargerImage("img\\"+decor.img.nomFichier)
  513. class DmFrameInf_Case(QGroupBox):
  514. """frame d'information (case)"""
  515. def __init__(self, parent = None):
  516. super(DmFrameInf_Case, self).__init__(parent)
  517. def maj(self, case):
  518. self.setVisible((case != None))
  519. if len(case.terrain.nom) > 0:
  520. self.findChild(DmLabel, "inf_caseTerrain").majTexte(case.terrain.nom)
  521. else:
  522. self.findChild(DmLabel, "inf_caseTerrain").majTexte("Case")
  523. self.findChild(DmLabel, "inf_caseCoord").majTexte("X: {} Y: {}".format(case.x, case.y))
  524. self.findChild(DmLabel, "inf_caseAltitude").majTexte("Alt.: {}".format(case.altitude))
  525. if case.effetActif != "":
  526. self.findChild(DmLabel, "inf_caseEffet").chargerImage("img\\"+case.imgEffet[case.effetActif])
  527. else:
  528. self.findChild(DmLabel, "inf_caseEffet").clear()
  529. class DmFrame(QFrame):
  530. """surcharge de QFrame"""
  531. def __init__(self, parent = None):
  532. super(DmFrame, self).__init__(parent)