-
Notifications
You must be signed in to change notification settings - Fork 1
/
processing_coolparks_provider.py
110 lines (89 loc) · 3.73 KB
/
processing_coolparks_provider.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
# -*- coding: utf-8 -*-
"""
/***************************************************************************
CoolParks tool
A QGIS plugin
Coolparks toolbox
Generated by Plugin Builder: http://g-sherman.github.io/Qgis-Plugin-Builder/
-------------------
begin : 2023-07-06
copyright : (C) 2023 by Jérémy Bernard
email : [email protected]
***************************************************************************/
/***************************************************************************
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
***************************************************************************/
"""
__author__ = 'Jérémy Bernard'
__date__ = '2023-07-06'
__copyright__ = '(C) 2023 by Jérémy Bernard'
# This will get replaced with a git SHA1 when you do a git archive
__revision__ = '$Format:%H$'
from qgis.core import QgsProcessingProvider
from processing.core.ProcessingConfig import ProcessingConfig
from .preprocessing_algorithm import CoolParksPreparerAlgorithm
from .processing_algorithm import CoolParksProcessorAlgorithm
from .postprocessing_algorithm import CoolParksAnalyzerAlgorithm
import os.path
from qgis.PyQt.QtGui import QIcon
import inspect
# from PyQt5.QtGui import QIcon
class ProcessingCoolParksProvider(QgsProcessingProvider):
def __init__(self):
"""
Default constructor.
"""
self.plugin_dir = os.path.dirname(__file__)
QgsProcessingProvider.__init__(self)
if not (os.path.isdir(self.plugin_dir + '/temp')):
os.mkdir(self.plugin_dir + '/temp')
def unload(self):
"""
Unloads the provider. Any tear-down steps required by the provider
should be implemented here.
"""
pass
def loadAlgorithms(self):
"""
Loads all algorithms belonging to this provider.
"""
#Preprocessor
self.addAlgorithm(CoolParksPreparerAlgorithm())
# #Processor
self.addAlgorithm(CoolParksProcessorAlgorithm())
# #Postprocessor
self.addAlgorithm(CoolParksAnalyzerAlgorithm())
def id(self):
"""
Returns the unique provider id, used for identifying the provider. This
string should be a unique, short, character only string, eg "qgis" or
"gdal". This string should not be localised.
"""
return 'CoolParksTool'
def name(self):
"""
Returns the provider name, which is used to describe the provider
within the GUI.
This string should be short (e.g. "Lastools") and localised.
"""
return 'CoolParksTool'
def icon(self):
"""
Should return a QIcon which is used for your provider inside
the Processing toolbox.
"""
icon = QIcon(os.path.dirname(__file__) + "/Icons/CoolParksTool.png")
return icon
def longName(self):
"""
Returns the a longer version of the provider name, which can include
extra details such as version numbers. E.g. "Lastools LIDAR tools
(version 2.2.1)". This string should be localised. The default
implementation returns the same string as name().
"""
return 'CoolParksTool, Version 0.1'