dm.py 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539
  1. #from __future__ import unicode_literals
  2. # -*- coding: utf-8 -*-
  3. """ensemble des widgets surchargés"""
  4. from PyQt4.QtCore import QString, SIGNAL, QVariant, QSize, pyqtSignal, \
  5. QPersistentModelIndex, Qt, QEvent, QModelIndex
  6. from PyQt4.QtGui import QLabel, QPixmap, QTextEdit, QLineEdit, QGraphicsView, \
  7. QComboBox, QSpinBox, QTabWidget, QTableWidget, QTableWidgetItem, \
  8. QItemSelectionModel, QIcon, QColor, QBrush, QGroupBox, QFrame
  9. class Biblio():
  10. """cette classe fournit une liste spreciale"""
  11. def __init__(self):
  12. self.dico = {}
  13. self.ordre = []
  14. def trierPar(self, param):
  15. """trie en fonction du parametre des objets"""
  16. ordre = []
  17. return ordre
  18. def elt(self, index):
  19. return self.dict[index]
  20. class DmLabel(QLabel):
  21. """surcharge de QLabel"""
  22. def __init__(self, parent = None):
  23. super(DmLabel, self).__init__(parent)
  24. self._image = None
  25. def majTexte(self, txt):
  26. self.clear()
  27. self.setText(QString.fromUtf8(txt))
  28. def chargerImage(self, img = None):
  29. """prend une RImage en parametre"""
  30. self.clear()
  31. if img:
  32. self._image = img
  33. pix = img.pix(self.width(), self.height())
  34. else:
  35. pix = QPixmap()
  36. self.setPixmap(pix)
  37. def texte(self):
  38. return str(self.text().toUtf8())
  39. def image(self):
  40. return self._image
  41. def mousePressEvent(self, event):
  42. if event.button() == 1:
  43. self.emit(SIGNAL("clicked()"))
  44. def mouseDoubleClickEvent(self, event):
  45. if event.button() == 1:
  46. self.emit(SIGNAL("doubleClicked()"))
  47. class DmTextEdit(QTextEdit):
  48. def __init__(self, parent = None):
  49. super(DmTextEdit, self).__init__(parent)
  50. def majTexte(self, txt):
  51. self.clear()
  52. self.setText(QString.fromUtf8(str(txt)))
  53. def texte(self):
  54. return str(self.toPlainText().toUtf8())
  55. class DmLineEdit(QLineEdit):
  56. def __init__(self, parent = None):
  57. super(DmLineEdit, self).__init__(parent)
  58. def majTexte(self, txt):
  59. self.clear()
  60. self.setText(QString.fromUtf8(str(txt)))
  61. def texte(self):
  62. return str(self.text().toUtf8())
  63. class DmGraphicsView(QGraphicsView):
  64. """surcharge de QGraphicsView"""
  65. def __init__(self, parent = None):
  66. super(DmGraphicsView, self).__init__(parent)
  67. self.nbZoomActuel = 0
  68. def resizeEvent(self, event):
  69. super(DmGraphicsView, self).resizeEvent(event)
  70. self.emit(SIGNAL("resizeEvent()"))
  71. def wheelEvent(self, event):
  72. """zoom/dezoom avec la molette de la souris"""
  73. #on zoom/dezoom et on recentre sur la position du curseur
  74. zoom = 1.00
  75. if event.delta() > 0:
  76. if self.nbZoomActuel <= 10:
  77. self.nbZoomActuel += 1
  78. zoom = 1.25
  79. elif event.delta() < 0:
  80. if self.nbZoomActuel >= -10:
  81. zoom = 0.8
  82. self.nbZoomActuel -= 1
  83. if zoom != 0.00:
  84. self.scale(zoom, zoom)
  85. self.centerOn(self.mapToScene(event.pos()))
  86. self.emit(SIGNAL("zoomChange(int)"), self.nbZoomActuel)
  87. event.accept() #pour considerer l'evenement comme resolu, sans ca les barres de defilement reagissent aussi
  88. class DmComboBox(QComboBox):
  89. """surcharge de QComboBox"""
  90. def __init__(self, parent = None):
  91. super(DmComboBox, self).__init__(parent)
  92. def allerA(self, donnee):
  93. """cherche la donnee demandee et affiche la ligne"""
  94. index = self.findData(QVariant(donnee))
  95. self.setCurrentIndex(index)
  96. def valeurActuelle(self):
  97. """renvoie sous forme de QVariant la valeur en cours"""
  98. return self.itemData(self.currentIndex())
  99. class DmSpinBox(QSpinBox):
  100. """surcharge de QSpinBox"""
  101. def __init__(self, parent = None):
  102. super(DmSpinBox, self).__init__(parent)
  103. def focusInEvent(self, event):
  104. super(DmSpinBox, self).focusInEvent(event)
  105. self.selectAll()
  106. class DmTabInventaire(QTabWidget):
  107. """surcharge de QTabWidget stylisee et
  108. utilisee pour filtrer les types d'objets affiches"""
  109. def __init__(self, parent = None):
  110. super(DmTabInventaire, self).__init__(parent)
  111. # self.setStyleSheet(QString.fromUtf8("""
  112. # QTabWidget::pane { border-top: 2px solid #C2C7CB; }
  113. # QTabWidget::tab-bar { alignment: right; }
  114. # QTabBar::tab {
  115. # background: qlineargradient(x1: 0, y1: 0, x2: 0, y2: 1,
  116. # stop: 0 #E1E1E1, stop: 0.4 #DDDDDD,
  117. # stop: 0.5 #D8D8D8, stop: 1.0 #D3D3D3);
  118. # border: 2px solid #C4C4C3;
  119. # border-bottom-color: #C2C7CB; border-top-left-radius: 4px;
  120. # border-top-right-radius: 8px;
  121. # border-top-left-radius: 8px;
  122. # padding-left: 15px; }
  123. # QTabBar::tab:selected, QTabBar::tab:hover {
  124. # background: qlineargradient(x1: 0, y1: 0, x2: 0, y2: 1,
  125. # stop: 0 #fafafa, stop: 0.4 #f4f4f4,
  126. # stop: 0.5 #e7e7e7, stop: 1.0 #fafafa); }
  127. # QTabBar::tab:selected { border-color: #9B9B9B;
  128. # border-bottom-color: #C2C7CB; }
  129. # """))
  130. class DmTableWidget(QTableWidget):
  131. """surcharge de QTableWidget"""
  132. def __init__(self, parent = None):
  133. super(DmTableWidget, self).__init__(parent)
  134. self.majEnCours = False
  135. def vider(self):
  136. """supprime toutes les lignes"""
  137. self.majEnCours = True
  138. while self.rowCount() > 0:
  139. self.removeRow(0)
  140. self.majEnCours = False
  141. def nouvelleLigneFin(self):
  142. """ajoute une ligne en derniere position"""
  143. pos = self.rowCount()
  144. self.insertRow(pos)
  145. return pos
  146. def lignes(self):
  147. """retourne la liste des index de lignes de la table"""
  148. return range(0, self.rowCount())
  149. def colonnes(self):
  150. """retourne la liste des index de lignes de la table"""
  151. return range(0, self.columnCount())
  152. def masquerColonneId(self):
  153. """masque la colonne en position 0 qui contient les identifiants"""
  154. self.setColumnWidth(0, 0)
  155. def majData(self, ligne, colonne, var):
  156. """met a jour la cellule avec une donnee de type QVariant"""
  157. var = QVariant(var)
  158. if not self.item(ligne, colonne):
  159. item = QTableWidgetItem()
  160. item.setData(0, var)
  161. self.setItem(ligne, colonne, item)
  162. else:
  163. self.item(ligne, colonne).setData(0, var)
  164. return True
  165. def majTexte(self, ligne, colonne, texte):
  166. """met a jour la cellule avec du texte"""
  167. if not self.item(ligne, colonne):
  168. self.setItem(ligne, colonne, QTableWidgetItem(QString.fromUtf8(str(texte))))
  169. else:
  170. self.item(ligne, colonne).setText(QString.fromUtf8(str(texte)))
  171. return True
  172. def majEnt(self, ligne, colonne, valeur):
  173. """met a jour la cellule avec une valeur numerique entiere
  174. si valeur ne peut etre converti en numerique, on retourne Faux"""
  175. retour = False
  176. try:
  177. entier = QVariant(long(valeur))
  178. self.item(ligne, colonne).setData(0, entier)
  179. retour = True
  180. except:
  181. pass
  182. return retour
  183. def entier(self, ligne, colonne):
  184. """recupere une valeur entiere de la case, None sinon"""
  185. try:
  186. entier = int(self.item(ligne, colonne).data(0))
  187. except:
  188. entier = None
  189. return entier
  190. def chercherLigne(self, colonne, valeur):
  191. """cherche la valeur dans la colonne demandee
  192. renvoie la ligne correspondante """
  193. ligne = None
  194. for i in range(0, self.rowCount()):
  195. if str(self.item(i, colonne).text().toUtf8()) == str(valeur):
  196. ligne = i
  197. break
  198. return ligne
  199. def majLigne(self, ligne, dico, flags = []):
  200. """rempli la ligne avec les donnees trouvees dans le dictionnaire"""
  201. for colonne in range(0, self.columnCount()):
  202. nomChamp = ""
  203. item = self.horizontalHeaderItem(colonne)
  204. if item:
  205. nomChamp = str(item.text())
  206. if nomChamp in dico:
  207. item = QTableWidgetItem()
  208. for f in flags:
  209. item.setFlag(f)
  210. var = QVariant(dico[nomChamp])
  211. item.setData(0, var)
  212. self.setItem(ligne, colonne, item)
  213. def texte(self, ligne, colonne):
  214. return str(self.item(ligne, colonne).text().toUtf8())
  215. def data(self, ligne, colonne):
  216. retour = None
  217. item = self.item(ligne, colonne)
  218. if item:
  219. retour = item.data(0)
  220. return retour
  221. def ligneSelectionnee(self):
  222. """renvoie la ligne selectionnee (la premiere si plusieurs le sont)"""
  223. return self.currentRow()
  224. def selectionner(self, ligne, colonne):
  225. self.setCurrentCell(ligne, colonne, QItemSelectionModel.ClearAndSelect)
  226. class DmTableMat(DmTableWidget):
  227. """table utilisee pour afficher les bibliotheques d'objets:
  228. terrains, decors, creatures"""
  229. def __init__(self, parent = None):
  230. super(DmTableMat, self).__init__(parent)
  231. self._init = False
  232. def charger(self, listeMat):
  233. """remplit la table avec les donnees contenues dans les fichiers de materiel
  234. (filtre selon le prefixe)"""
  235. if not self._init:
  236. self.setIconSize(QSize(30,20))
  237. self.horizontalHeader().setStretchLastSection(True)
  238. self.masquerColonneId()
  239. self._init = True
  240. self.majEnCours = True
  241. self.setSortingEnabled(False)
  242. for mat in listeMat:
  243. ligne = self.nouvelleLigneFin()
  244. self.majTexte(ligne, 0, mat.idM())
  245. icon = QIcon() if not mat.icone() else QIcon(mat.icone().fichier())
  246. item = QTableWidgetItem(icon, QString.fromUtf8(mat.nom()))
  247. self.setItem(ligne, 1, item)
  248. self.sizeHintForColumn(1)
  249. self.sortItems(1)
  250. self.setSortingEnabled(True)
  251. self.majEnCours = False
  252. def maj(self):
  253. self.vider()
  254. self.remplir()
  255. def selection(self):
  256. """renvoie l'idM du materiel actuellement selectionne"""
  257. return self.texte(self.currentRow(), 0)
  258. # class DmTableAttributsPi(DmTableWidget):
  259. # """table utilisee pour afficher les attributs d'un pion dans le panneau Pi"""
  260. # def __init__(self, parent = None):
  261. # super(DmTableMat, self).__init__(parent)
  262. # self.masquerColonneId()
  263. #
  264. # def initAffichage(self):
  265. # """fait les differents reglages relatifs a l'apparence"""
  266. # self.setColumnWidth(0, 0)
  267. # self.setIconSize(QSize(30,20))
  268. # self.horizontalHeader().setStretchLastSection(True)
  269. #
  270. # def remplir(self, attributs):
  271. # """remplit la table avec les donnees du pion"""
  272. # self.majEnCours = True
  273. # self.setSortingEnabled(False)
  274. # index = 0
  275. # for elt in dico:
  276. # objet = dico[elt]
  277. # self.insertRow(int(index))
  278. #
  279. # #code de l'objet
  280. # self.setItem(int(index),0,QTableWidgetItem(QString.fromUtf8(elt)))
  281. # #icone et nom
  282. # icon = QIcon("img\\"+objet.icone())
  283. # item = QTableWidgetItem(icon,QString.fromUtf8(objet.nom))
  284. # self.setItem(int(index),1,item)
  285. #
  286. # index += 1
  287. # self.sizeHintForColumn(1)
  288. # self.setSortingEnabled(True)
  289. # self.sortItems(1)
  290. # self.majEnCours = False
  291. #
  292. # def maj(self):
  293. # self.vider()
  294. # self.remplir()
  295. # def actuel(self):
  296. # """renvoie l'objet actuellement selectionne"""
  297. # objet = None
  298. # index = self.item(self.currentRow(), 0)
  299. # if index > 0:
  300. # objet = charger(self.fichier, str(index.text().toUtf8()))
  301. # return objet
  302. class DmTableInventaire(DmTableWidget):
  303. """table utilisee pour afficher l'inventaire d'un combattant"""
  304. itemExited = pyqtSignal(QTableWidgetItem)
  305. def __init__(self, parent = None):
  306. super(DmTableInventaire, self).__init__(parent)
  307. self._inventaire = []
  308. #pour la gestion des survols
  309. self.setMouseTracking(True)
  310. self._last_index = QPersistentModelIndex()
  311. self.viewport().installEventFilter(self)
  312. self.connect(self, SIGNAL("itemEntered(QTableWidgetItem*)"), self.itemSurvole)
  313. self.connect(self, SIGNAL("itemExited(QTableWidgetItem*)"), self.itemSurvoleFin)
  314. self.connect(self, SIGNAL("itemClicked(QTableWidgetItem*)"), self.itemClique)
  315. def construire(self):
  316. self.setColumnWidth(0, 20);self.setColumnWidth(1, 70)
  317. self.setColumnWidth(2, 241);self.setColumnWidth(4, 60)
  318. self.setColumnWidth(6, 20)
  319. def ajouterObjet(self, objet):
  320. ligne = self.rowCount() - 1 #avant la ligne 'ajouter'
  321. self.insertRow(ligne)
  322. self.remplirLigne(ligne, objet)
  323. self._inventaire.append(objet)
  324. def charger(self, inventaire):
  325. """charge l'inventaire en parametre"""
  326. for objet in inventaire:
  327. self.ajouterObjet(objet)
  328. def majObjet(self, ancien, nouveau):
  329. """maj la ligne correspondant a l'objet"""
  330. index = self._inventaire.index(ancien)
  331. self._inventaire[index] = nouveau
  332. self.remplirLigne(index, nouveau)
  333. def supprimerObjet(self, objet):
  334. """ajoute la ligne correspondant a l'objet"""
  335. index = self._inventaire.index(objet)
  336. self._inventaire.remove(objet)
  337. self.removeRow(index)
  338. def remplirLigne(self, ligne, objet):
  339. """remplit les cellules de la ligne avec les donnees de l'objet"""
  340. imgType = ["pieces.png", "btn_ModeCombat.png", "chimie.png", "diamant.png", "boite_outils.png"]
  341. self.creerItem(ligne, 0, "", imgType[objet.typeObjet])
  342. self.creerItem(ligne, 1, objet.quantite)
  343. self.creerItem(ligne, 2, objet.nom)
  344. self.creerItem(ligne, 3, objet.poidsTotal())
  345. self.creerItem(ligne, 4, "")
  346. def inventaire(self):
  347. """cree un inventaire a partir des donnees de la table"""
  348. return self._inventaire
  349. def itemSurvole(self, item):
  350. ligne = item.row()
  351. self.majCouleurLigne(ligne, QColor(150, 50, 50, 150))
  352. def itemSurvoleFin(self, item):
  353. ligne = item.row()
  354. self.majCouleurLigne(ligne, QColor(248, 248, 248, 150))
  355. def itemClique(self, item):
  356. ligne = item.row()
  357. self.emit(SIGNAL("objetClique(int)"), ligne)
  358. def majCouleurLigne(self, ligne, couleur):
  359. """modifie la couleur de fond des items de la lignes"""
  360. for col in self.colonnes():
  361. item = self.item(ligne, col)
  362. if item:
  363. item.setBackground(QBrush(couleur))
  364. def creerItem(self, ligne, colonne, txt, img = None):
  365. item = QTableWidgetItem()
  366. item.setFlags(Qt.NoItemFlags)
  367. item.setText(QString().fromUtf8(" {}".format(txt)))
  368. if img:
  369. pix = QPixmap("img\\{}".format(img))
  370. item.setIcon(QIcon(pix))
  371. self.setItem(ligne, colonne, item)
  372. def filtrer(self, typeObjet):
  373. """filtre l'affichage des lignes par type d'objet"""
  374. for ligne in range(0, self.rowCount() - 1):
  375. self.setRowHidden(ligne, typeObjet >= 0 and typeObjet != self._inventaire[ligne].typeObjet )
  376. def eventFilter(self, widget, event):
  377. if widget is self.viewport():
  378. index = self._last_index
  379. if event.type() == QEvent.MouseMove:
  380. index = self.indexAt(event.pos())
  381. elif event.type() == QEvent.Leave:
  382. index = QModelIndex()
  383. if index != self._last_index:
  384. row = self._last_index.row()
  385. column = self._last_index.column()
  386. item = self.item(row, column)
  387. if item is not None:
  388. self.itemExited.emit(item)
  389. self._last_index = QPersistentModelIndex(index)
  390. return QTableWidget.eventFilter(self, widget, event)
  391. class DmTableInventaireCombat(DmTableInventaire):
  392. """inventaire affiche dans le panneau de combat"""
  393. def __init__(self, parent = None):
  394. super(DmTableInventaireCombat, self).__init__(parent)
  395. class DmTableMenu(QTableWidget):
  396. """table utilisee comme barre d'onglets verticale"""
  397. def __init__(self, parent = None):
  398. super(DmTableMenu, self).__init__(parent)
  399. def setItem(self, ligne, colonne, item):
  400. super(DmTableMenu, self).setItem(ligne, colonne, item)
  401. if ligne == 0:
  402. self.setItemSelected(item, True)
  403. class DmFrameInf_Combattant(QGroupBox):
  404. """frame d'information (combattant)"""
  405. def __init__(self, parent = None):
  406. super(DmFrameInf_Combattant, self).__init__(parent)
  407. def maj(self, combattant):
  408. self.setVisible((combattant != None))
  409. if combattant:
  410. self.findChild(DmLabel, "inf_pionNom").majTexte(combattant.nom())
  411. self.findChild(DmLabel, "inf_pionImage").chargerImage(combattant.img.rimage)
  412. self.findChild(DmLabel, "inf_pionEffet").setVisible(False)
  413. class DmFrameInf_Decor(QGroupBox):
  414. """frame d'information (decor)"""
  415. def __init__(self, parent = None):
  416. super(DmFrameInf_Decor, self).__init__(parent)
  417. def maj(self, decor):
  418. self.setVisible((decor != None))
  419. if decor:
  420. self.findChild(DmLabel, "inf_decorNom").majTexte(decor.nom())
  421. self.findChild(DmLabel, "inf_decorImage").chargerImage(decor.img.rimage)
  422. class DmFrameInf_Case(QGroupBox):
  423. """frame d'information (case)"""
  424. def __init__(self, parent = None):
  425. super(DmFrameInf_Case, self).__init__(parent)
  426. def maj(self, case):
  427. self.setVisible((case != None))
  428. if len(case.terrain.nom()) > 0:
  429. self.findChild(DmLabel, "inf_caseTerrain").majTexte(case.terrain.nom())
  430. else:
  431. self.findChild(DmLabel, "inf_caseTerrain").majTexte("Case")
  432. self.findChild(DmLabel, "inf_caseCoord").majTexte("X: {} Y: {}".format(case.x, case.y))
  433. self.findChild(DmLabel, "inf_caseAltitude").majTexte("Altitude: {}".format(case.altitude))
  434. if case.effetActif not in ["", "aucun"]:
  435. imgEffet = {"brule": "feu_16.png", "eau": "eau_16.png","glace": "glace_16.png","poison": "poison_16.png"}
  436. pix = QPixmap(":/interface/16/ressource/{}".format(imgEffet[case.effetActif]))
  437. self.findChild(DmLabel, "inf_caseEffet").setPixmap(pix)
  438. else:
  439. self.findChild(DmLabel, "inf_caseEffet").clear()
  440. class DmFrame(QFrame):
  441. """surcharge de QFrame"""
  442. def __init__(self, parent = None):
  443. super(DmFrame, self).__init__(parent)