DbmsAlgorithmDialog.py 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  1. """
  2. ***************************************************************************
  3. DbmsAlgorithmDialog.py
  4. ---------------------
  5. Date : May 2015
  6. Copyright : (C) 2015 by Victor Olaya
  7. Email : volayaf at gmail dot com
  8. ***************************************************************************
  9. * *
  10. * This program is free software; you can redistribute it and/or modify *
  11. * it under the terms of the GNU General Public License as published by *
  12. * the Free Software Foundation; either version 2 of the License, or *
  13. * (at your option) any later version. *
  14. * *
  15. ***************************************************************************
  16. """
  17. __author__ = 'Victor Olaya'
  18. __date__ = 'May 2015'
  19. __copyright__ = '(C) 2015, Victor Olaya'
  20. import json
  21. import os
  22. from PyQt5.QtWidgets import QFileDialog
  23. from qgis.PyQt.QtCore import QCoreApplication
  24. from qgis.PyQt.QtWidgets import (QWidget,
  25. QVBoxLayout,
  26. QPushButton,
  27. QLabel,
  28. QPlainTextEdit,
  29. QLineEdit,
  30. QComboBox,
  31. QCheckBox,
  32. QTreeView,
  33. QTreeWidget,
  34. QTreeWidgetItem,
  35. QSizePolicy,
  36. QDialogButtonBox)
  37. from qgis.core import (
  38. QgsProcessingException,
  39. QgsProcessingFeedback,
  40. QgsProcessingParameterDefinition
  41. )
  42. from qgis.gui import (QgsMessageBar,
  43. QgsProjectionSelectionWidget,
  44. QgsProcessingAlgorithmDialogBase,
  45. QgsProcessingLayerOutputDestinationWidget)
  46. from processing.gui.AlgorithmDialog import AlgorithmDialog
  47. from processing.gui.AlgorithmDialogBase import AlgorithmDialogBase
  48. from processing.gui.ParametersPanel import ParametersPanel
  49. from processing.gui.MultipleInputPanel import MultipleInputPanel
  50. from processing.gui.NumberInputPanel import NumberInputPanel
  51. from processing.gui.wrappers import WidgetWrapper
  52. from processing.tools.dataobjects import createContext
  53. from processing.tools.Widget.TreeWidget import Tree
  54. from processing.tools.FileListPrintUtils import printStr
  55. class DbmsAlgorithmDialog(AlgorithmDialog):
  56. def __init__(self, alg, parent=None):
  57. super().__init__(alg, parent=parent)
  58. self.mainWidget().parametersHaveChanged()
  59. def getParametersPanel(self, alg, parent):
  60. return DbmsParametersPanel(parent, alg)
  61. class DbmsParametersPanel(ParametersPanel):
  62. def __init__(self, parent, alg):
  63. super().__init__(parent, alg)
  64. self.dialog = parent
  65. algname = alg.name()
  66. w = QWidget()
  67. layout = QVBoxLayout()
  68. layout.setMargin(0)
  69. layout.setSpacing(6)
  70. gdalHidden = False
  71. if algname == "postgistogeoserver":
  72. # 资源目录
  73. label = QLabel()
  74. label.setText(self.tr("资源目录树(必选)"))
  75. layout.addWidget(label)
  76. tree = Tree("zyml")
  77. self.curTree = tree.initTreeWidget()
  78. layout.addWidget(self.curTree)
  79. self.curTree.itemSelectionChanged.connect(self.parametersHaveChanged)
  80. gdalHidden = True
  81. elif algname == "importvectorintopostgisdatabaseavailableconnections" or algname == "importrasterintopostgisdatabase":
  82. # 行政区划
  83. label = QLabel()
  84. label.setText(self.tr("行政区划(必选)"))
  85. layout.addWidget(label)
  86. tree = Tree("xzqh")
  87. self.curTree = tree.initTreeWidget()
  88. layout.addWidget(self.curTree)
  89. self.curTree.itemSelectionChanged.connect(self.parametersHaveChanged)
  90. # 上传附件
  91. pushBtn = QPushButton()
  92. pushBtn.setText("选择附件")
  93. pushBtn.clicked.connect(self.uploadChange)
  94. layout.addWidget(pushBtn)
  95. self.filelist = QPlainTextEdit()
  96. self.filelist.setReadOnly(True)
  97. layout.addWidget(self.filelist)
  98. gdalHidden = True
  99. label = QLabel()
  100. label.setText(self.tr("GDAL/OGR console call"))
  101. label.setHidden(gdalHidden)
  102. layout.addWidget(label)
  103. self.text = QPlainTextEdit()
  104. self.text.setReadOnly(True)
  105. self.text.setHidden(gdalHidden)
  106. layout.addWidget(self.text)
  107. w.setLayout(layout)
  108. self.addExtraWidget(w)
  109. self.connectParameterSignals()
  110. self.parametersHaveChanged()
  111. def uploadChange(self):
  112. file_paths, _ = QFileDialog.getOpenFileNames(self, '选择文件', '', 'All Files (*)')
  113. fileliststr = ",".join(file_paths)
  114. self.filelist.setPlainText(fileliststr)
  115. printStr(fileliststr)
  116. def connectParameterSignals(self):
  117. for wrapper in list(self.wrappers.values()):
  118. wrapper.widgetValueHasChanged.connect(self.parametersHaveChanged)
  119. # TODO - remove when all wrappers correctly emit widgetValueHasChanged!
  120. # For compatibility with 3.x API, we need to check whether the wrapper is
  121. # the deprecated WidgetWrapper class. If not, it's the newer
  122. # QgsAbstractProcessingParameterWidgetWrapper class
  123. # TODO QGIS 4.0 - remove
  124. if issubclass(wrapper.__class__, WidgetWrapper):
  125. w = wrapper.widget
  126. else:
  127. w = wrapper.wrappedWidget()
  128. self.connectWidgetChangedSignals(w)
  129. for c in w.findChildren(QWidget):
  130. self.connectWidgetChangedSignals(c)
  131. def connectWidgetChangedSignals(self, w):
  132. if isinstance(w, QLineEdit):
  133. w.textChanged.connect(self.parametersHaveChanged)
  134. elif isinstance(w, QComboBox):
  135. w.currentIndexChanged.connect(self.parametersHaveChanged)
  136. elif isinstance(w, QgsProjectionSelectionWidget):
  137. w.crsChanged.connect(self.parametersHaveChanged)
  138. elif isinstance(w, QCheckBox):
  139. w.stateChanged.connect(self.parametersHaveChanged)
  140. elif isinstance(w, MultipleInputPanel):
  141. w.selectionChanged.connect(self.parametersHaveChanged)
  142. elif isinstance(w, NumberInputPanel):
  143. w.hasChanged.connect(self.parametersHaveChanged)
  144. elif isinstance(w, QgsProcessingLayerOutputDestinationWidget):
  145. w.destinationChanged.connect(self.parametersHaveChanged)
  146. elif isinstance(w, QTreeWidget):
  147. w.itemSelectionChanged.connect(self.parametersHaveChanged)
  148. def parametersHaveChanged(self):
  149. context = createContext()
  150. feedback = QgsProcessingFeedback()
  151. try:
  152. # messy as all heck, but we don't want to call the dialog's implementation of
  153. # createProcessingParameters as we want to catch the exceptions raised by the
  154. # parameter panel instead...
  155. parameters = {} if self.dialog.mainWidget() is None else self.dialog.mainWidget().createProcessingParameters()
  156. for output in self.algorithm().destinationParameterDefinitions():
  157. if not output.name() in parameters or parameters[output.name()] is None:
  158. if not output.flags() & QgsProcessingParameterDefinition.FlagOptional:
  159. parameters[output.name()] = self.tr("[temporary file]")
  160. for p in self.algorithm().parameterDefinitions():
  161. if p.flags() & QgsProcessingParameterDefinition.FlagHidden:
  162. continue
  163. if p.flags() & QgsProcessingParameterDefinition.FlagOptional and p.name() not in parameters:
  164. continue
  165. if p.name() not in parameters or not p.checkValueIsAcceptable(parameters[p.name()]):
  166. # not ready yet
  167. self.text.setPlainText('')
  168. return
  169. try:
  170. b = self.contains_keys(self, ["curTree"])
  171. if b == True:
  172. # 获取选中的项
  173. selectedItems = self.curTree.selectedItems()
  174. if len(selectedItems) == 0:
  175. self.algorithm().setSelectedValue("")
  176. else:
  177. for selectedItem in selectedItems:
  178. v = selectedItem.text(1)
  179. self.algorithm().setSelectedValue(v)
  180. commands = self.algorithm().getConsoleCommands(parameters, context, feedback, executing=False)
  181. commands = [c for c in commands if c not in ['cmd.exe', '/C ']]
  182. self.text.setPlainText(" ".join(commands))
  183. except QgsProcessingException as e:
  184. self.text.setPlainText(str(e))
  185. except AlgorithmDialogBase.InvalidParameterValue as e:
  186. self.text.setPlainText(self.tr("Invalid value for parameter '{0}'").format(e.parameter.description()))
  187. except AlgorithmDialogBase.InvalidOutputExtension as e:
  188. self.text.setPlainText(e.message)
  189. def contains_keys(self, obj, keys):
  190. if isinstance(obj, dict):
  191. return all(key in obj.keys() for key in keys)
  192. elif hasattr(type(obj), '__dict__'):
  193. return all(key in obj.__dict__ for key in keys)
  194. else:
  195. raise ValueError("Invalid object type")