-
Notifications
You must be signed in to change notification settings - Fork 21
/
dzetsaka_provider.py
123 lines (96 loc) · 4.14 KB
/
dzetsaka_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
111
112
113
114
115
116
117
118
119
120
121
122
123
# -*- coding: utf-8 -*-
"""
/***************************************************************************
className
A QGIS plugin
desc
Generated by Plugin Builder: http://g-sherman.github.io/Qgis-Plugin-Builder/
-------------------
begin : 2018-02-24
copyright : (C) 2018 by Nicolas Karasiak
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__ = 'Nicolas Karasiak'
__date__ = '2018-02-24'
__copyright__ = '(C) 2018 by Nicolas Karasiak'
# This will get replaced with a git SHA1 when you do a git archive
__revision__ = '$Format:%H$'
from qgis.PyQt.QtGui import QIcon
import os
from qgis.core import QgsProcessingProvider
#from .moduleName_algorithm import classNameAlgorithm
#from .processing.moduleName_algorithm import classNameAlgorithm
from .processing.train import trainAlgorithm
from .processing.classify import classifyAlgorithm
from .processing.splitTrainValidation import splitTrain
pluginPath = os.path.dirname(__file__)
"""
import sys
sys.setrecursionlimit(10000) # 10000 is an example, try with different values
"""
class dzetsakaProvider(QgsProcessingProvider):
def __init__(self, providerType='Standard'):
QgsProcessingProvider.__init__(self)
# Load algorithms
# ,learnWithSpatialSampling()]#,classifyAlgorithm(),splitTrain()]
self.providerType = providerType
def icon(self):
"""
add icon
"""
iconPath = os.path.join(pluginPath, 'icon.png')
return QIcon(os.path.join(iconPath))
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.
"""
self.addAlgorithm(trainAlgorithm())
self.addAlgorithm(classifyAlgorithm())
self.addAlgorithm(splitTrain())
# self.addAlgorithm(trainSTANDalgorithm())
if self.providerType == 'Experimental':
from .processing.medianFilter import medianFilterAlgorithm
from .processing.closingFilter import closingFilterAlgorithm
self.addAlgorithm(closingFilterAlgorithm())
self.addAlgorithm(medianFilterAlgorithm())
from .processing.domainAdaptation import domainAdaptation
from .processing.shannonEntropy import shannonAlgorithm
self.addAlgorithm(domainAdaptation())
self.addAlgorithm(shannonAlgorithm())
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 'dzetsaka'
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 self.tr('dzetsaka')
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 self.name()