GdalAlgorithmDialog.py 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239
  1. """
  2. ***************************************************************************
  3. GdalAlgorithmDialog.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 GdalAlgorithmDialog(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 GdalParametersPanel(parent, alg)
  61. class GdalParametersPanel(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 = True
  71. loop = True
  72. if algname == "postgistogeoserver":
  73. # 资源目录
  74. label = QLabel()
  75. label.setText(self.tr("资源目录树(必选)"))
  76. layout.addWidget(label)
  77. tree = Tree("zyml")
  78. self.curTree = tree.initTreeWidget()
  79. layout.addWidget(self.curTree)
  80. self.curTree.itemSelectionChanged.connect(self.parametersHaveChanged)
  81. gdalHidden = True
  82. elif algname == "importvectorintopostgisdatabaseavailableconnections" or algname == "importrasterintopostgisdatabase" or algname == "gdbtopostgis":
  83. # 行政区划
  84. label = QLabel()
  85. label.setText(self.tr("行政区划(必选)"))
  86. layout.addWidget(label)
  87. tree = Tree("xzqh")
  88. self.curTree = tree.initTreeWidget()
  89. layout.addWidget(self.curTree)
  90. self.curTree.itemSelectionChanged.connect(self.parametersHaveChanged)
  91. # 上传附件
  92. pushBtn = QPushButton()
  93. pushBtn.setText("选择附件")
  94. pushBtn.clicked.connect(self.uploadChange)
  95. layout.addWidget(pushBtn)
  96. self.filelist = QPlainTextEdit()
  97. self.filelist.setReadOnly(True)
  98. layout.addWidget(self.filelist)
  99. gdalHidden = True
  100. elif algname == "postgisupdate":
  101. label = QLabel()
  102. label.setText(self.tr("预分析结果"))
  103. layout.addWidget(label)
  104. self.vectorupdate = QPlainTextEdit()
  105. self.vectorupdate.setReadOnly(True)
  106. layout.addWidget(self.vectorupdate)
  107. gdalHidden = True
  108. loop = False
  109. elif algname == "postgisrestore" or algname == "spotfileupload" or algname == "spotfiledownload" or algname == "spotfiledelete" or algname == "licensemake":
  110. gdalHidden = True
  111. loop = False
  112. label = QLabel()
  113. label.setText(self.tr("控制台"))
  114. label.setHidden(gdalHidden)
  115. layout.addWidget(label)
  116. self.text = QPlainTextEdit()
  117. self.text.setReadOnly(True)
  118. self.text.setHidden(gdalHidden)
  119. layout.addWidget(self.text)
  120. w.setLayout(layout)
  121. self.addExtraWidget(w)
  122. self.connectParameterSignals(loop=loop)
  123. self.parametersHaveChanged()
  124. def uploadChange(self):
  125. file_paths, _ = QFileDialog.getOpenFileNames(self, '选择文件', '', 'All Files (*)')
  126. fileliststr = ",".join(file_paths)
  127. self.filelist.setPlainText(fileliststr)
  128. printStr(fileliststr)
  129. def connectParameterSignals(self, loop):
  130. for wrapper in list(self.wrappers.values()):
  131. wrapper.widgetValueHasChanged.connect(self.parametersHaveChanged)
  132. # TODO - remove when all wrappers correctly emit widgetValueHasChanged!
  133. # For compatibility with 3.x API, we need to check whether the wrapper is
  134. # the deprecated WidgetWrapper class. If not, it's the newer
  135. # QgsAbstractProcessingParameterWidgetWrapper class
  136. # TODO QGIS 4.0 - remove
  137. if issubclass(wrapper.__class__, WidgetWrapper):
  138. w = wrapper.widget
  139. else:
  140. w = wrapper.wrappedWidget()
  141. if loop == True:
  142. self.connectWidgetChangedSignals(w)
  143. for c in w.findChildren(QWidget):
  144. self.connectWidgetChangedSignals(c)
  145. def connectWidgetChangedSignals(self, w):
  146. if isinstance(w, QLineEdit):
  147. w.textChanged.connect(self.parametersHaveChanged)
  148. elif isinstance(w, QComboBox):
  149. w.currentIndexChanged.connect(self.parametersHaveChanged)
  150. elif isinstance(w, QgsProjectionSelectionWidget):
  151. w.crsChanged.connect(self.parametersHaveChanged)
  152. elif isinstance(w, QCheckBox):
  153. w.stateChanged.connect(self.parametersHaveChanged)
  154. elif isinstance(w, MultipleInputPanel):
  155. w.selectionChanged.connect(self.parametersHaveChanged)
  156. elif isinstance(w, NumberInputPanel):
  157. w.hasChanged.connect(self.parametersHaveChanged)
  158. elif isinstance(w, QgsProcessingLayerOutputDestinationWidget):
  159. w.destinationChanged.connect(self.parametersHaveChanged)
  160. elif isinstance(w, QTreeWidget):
  161. w.itemSelectionChanged.connect(self.parametersHaveChanged)
  162. def parametersHaveChanged(self):
  163. context = createContext()
  164. feedback = QgsProcessingFeedback()
  165. try:
  166. # messy as all heck, but we don't want to call the dialog's implementation of
  167. # createProcessingParameters as we want to catch the exceptions raised by the
  168. # parameter panel instead...
  169. parameters = {} if self.dialog.mainWidget() is None else self.dialog.mainWidget().createProcessingParameters()
  170. for output in self.algorithm().destinationParameterDefinitions():
  171. if not output.name() in parameters or parameters[output.name()] is None:
  172. if not output.flags() & QgsProcessingParameterDefinition.FlagOptional:
  173. parameters[output.name()] = self.tr("[temporary file]")
  174. for p in self.algorithm().parameterDefinitions():
  175. if p.flags() & QgsProcessingParameterDefinition.FlagHidden:
  176. continue
  177. if p.flags() & QgsProcessingParameterDefinition.FlagOptional and p.name() not in parameters:
  178. continue
  179. if p.name() not in parameters or not p.checkValueIsAcceptable(parameters[p.name()]):
  180. # not ready yet
  181. self.text.setPlainText('')
  182. return
  183. try:
  184. b = self.contains_keys(self, ["curTree"])
  185. if b == True:
  186. # 获取选中的项
  187. selectedItems = self.curTree.selectedItems()
  188. if len(selectedItems) == 0:
  189. self.algorithm().setSelectedValue("")
  190. else:
  191. for selectedItem in selectedItems:
  192. v = selectedItem.text(1)
  193. self.algorithm().setSelectedValue(v)
  194. commands = self.algorithm().getConsoleCommands(parameters, context, feedback, executing=False)
  195. b = self.contains_keys(self, ["vectorupdate"])
  196. if b == True:
  197. if len(commands) == 0:
  198. self.vectorupdate.setPlainText("更新数据包通过预分析,可进行数据更新!")
  199. else:
  200. self.vectorupdate.setPlainText("\n".join(commands))
  201. commands = [c for c in commands if c not in ['cmd.exe', '/C ']]
  202. self.text.setPlainText(" ".join(commands))
  203. except QgsProcessingException as e:
  204. self.text.setPlainText(str(e))
  205. except AlgorithmDialogBase.InvalidParameterValue as e:
  206. self.text.setPlainText(self.tr("Invalid value for parameter '{0}'").format(e.parameter.description()))
  207. except AlgorithmDialogBase.InvalidOutputExtension as e:
  208. self.text.setPlainText(e.message)
  209. def contains_keys(self, obj, keys):
  210. if isinstance(obj, dict):
  211. return all(key in obj.keys() for key in keys)
  212. elif hasattr(type(obj), '__dict__'):
  213. return all(key in obj.__dict__ for key in keys)
  214. else:
  215. raise ValueError("Invalid object type")