-
-
Notifications
You must be signed in to change notification settings - Fork 3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[processing] add missed fTools algorithms: Define current projection
and Create spatial index. Also add missed Assign projection from GDALTools
- Loading branch information
Showing
9 changed files
with
267 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,81 @@ | ||
# -*- coding: utf-8 -*- | ||
|
||
""" | ||
*************************************************************************** | ||
self.py | ||
--------------------- | ||
Date : January 2016 | ||
Copyright : (C) 2016 by Alexander Bruy | ||
Email : alexander dot bruy at gmail dot com | ||
*************************************************************************** | ||
* * | ||
* 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__ = 'Alexander Bruy' | ||
__date__ = 'January 2016' | ||
__copyright__ = '(C) 2016, Alexander Bruy' | ||
|
||
# This will get replaced with a git SHA1 when you do a git archive | ||
|
||
__revision__ = '$Format:%H$' | ||
|
||
import os | ||
|
||
from PyQt4.QtGui import QIcon | ||
|
||
from processing.algs.gdal.GdalAlgorithm import GdalAlgorithm | ||
from processing.core.parameters import ParameterRaster | ||
from processing.core.parameters import ParameterCrs | ||
from processing.core.outputs import OutputRaster | ||
from processing.algs.gdal.GdalUtils import GdalUtils | ||
|
||
from processing.tools.system import isWindows | ||
|
||
pluginPath = os.path.split(os.path.split(os.path.dirname(__file__))[0])[0] | ||
|
||
|
||
class AssignProjection(GdalAlgorithm): | ||
|
||
INPUT = 'INPUT' | ||
CRS = 'CRS' | ||
OUTPUT = 'OUTPUT' | ||
|
||
def getIcon(self): | ||
return QIcon(os.path.join(pluginPath, 'images', 'gdaltools', 'projection-add.png')) | ||
|
||
def defineCharacteristics(self): | ||
self.name, self.i18n_name = self.trAlgorithm('Assign projection') | ||
self.group, self.i18n_group = self.trAlgorithm('[GDAL] Projections') | ||
|
||
self.addParameter(ParameterRaster(self.INPUT, self.tr('Input layer'), False)) | ||
self.addParameter(ParameterCrs(self.CRS, | ||
self.tr('Desired CRS'), '')) | ||
|
||
self.addOutput(OutputRaster(self.OUTPUT, self.tr('Layer with projection'), True)) | ||
|
||
def getConsoleCommands(self): | ||
fileName = self.getParameterValue(self.INPUT) | ||
crs = self.getParameterValue(self.CRS) | ||
output = self.getOutputValue(self.OUTPUT) | ||
|
||
arguments = [] | ||
arguments.append('-a_srs') | ||
arguments.append(crs) | ||
|
||
arguments.append(fileName) | ||
|
||
commands = [] | ||
if isWindows(): | ||
commands = ['cmd.exe', '/C ', 'gdal_edit.bat', | ||
GdalUtils.escapeAndJoin(arguments)] | ||
else: | ||
commands = ['gdal_edit.py', GdalUtils.escapeAndJoin(arguments)] | ||
|
||
self.setOutputValue(self.OUTPUT, fileName) | ||
return commands |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,92 @@ | ||
# -*- coding: utf-8 -*- | ||
|
||
""" | ||
*************************************************************************** | ||
SpatialIndex.py | ||
--------------------- | ||
Date : January 2016 | ||
Copyright : (C) 2016 by Alexander Bruy | ||
Email : alexander dot bruy at gmail dot com | ||
*************************************************************************** | ||
* * | ||
* 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__ = 'Alexander Bruy' | ||
__date__ = 'January 2016' | ||
__copyright__ = '(C) 2016, Alexander Bruy' | ||
|
||
# This will get replaced with a git SHA1 when you do a git archive | ||
|
||
__revision__ = '$Format:%H$' | ||
|
||
import os | ||
import re | ||
|
||
from PyQt4.QtGui import QIcon | ||
|
||
from qgis.core import QgsCoordinateReferenceSystem | ||
from qgis.utils import iface | ||
|
||
from processing.core.GeoAlgorithm import GeoAlgorithm | ||
from processing.core.parameters import ParameterVector | ||
from processing.core.parameters import ParameterCrs | ||
from processing.core.outputs import OutputVector | ||
|
||
from processing.tools import dataobjects, vector | ||
|
||
pluginPath = os.path.split(os.path.split(os.path.dirname(__file__))[0])[0] | ||
|
||
|
||
class DefineProjection(GeoAlgorithm): | ||
|
||
INPUT = 'INPUT' | ||
CRS = 'CRS' | ||
OUTPUT = 'OUTPUT' | ||
|
||
#def getIcon(self): | ||
# return QIcon(os.path.join(pluginPath, 'images', 'ftools', 'basic_statistics.png')) | ||
|
||
def defineCharacteristics(self): | ||
self.name, self.i18n_name = self.trAlgorithm('Define current projection') | ||
self.group, self.i18n_group = self.trAlgorithm('Vector general tools') | ||
|
||
self.addParameter(ParameterVector(self.INPUT, | ||
self.tr('Input Layer'), | ||
[ParameterVector.VECTOR_TYPE_ANY])) | ||
self.addParameter(ParameterCrs(self.CRS, 'Output CRS')) | ||
self.addOutput(OutputVector(self.OUTPUT, | ||
self.tr('Layer with projection'), True)) | ||
|
||
|
||
def processAlgorithm(self, progress): | ||
fileName = self.getParameterValue(self.INPUT) | ||
layer = dataobjects.getObjectFromUri(fileName) | ||
crs = QgsCoordinateReferenceSystem(self.getParameterValue(self.CRS)) | ||
|
||
provider = layer.dataProvider() | ||
ds = provider.dataSourceUri() | ||
p = re.compile('\|.*') | ||
dsPath = p.sub('', ds) | ||
|
||
if dsPath.lower().endswith('.shp'): | ||
dsPath = dsPath[:-4] | ||
|
||
wkt = crs.toWkt() | ||
with open(dsPath + '.prj', 'w') as f: | ||
f.write(wkt) | ||
|
||
qpjFile = dsPath + '.qpj' | ||
if os.path.exists(qpjFile): | ||
with open(qpjFile, 'w') as f: | ||
f.write(wkt) | ||
|
||
layer.setCrs(crs) | ||
iface.mapCanvas().refresh() | ||
|
||
self.setOutputValue(self.OUTPUT, fileName) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,74 @@ | ||
# -*- coding: utf-8 -*- | ||
|
||
""" | ||
*************************************************************************** | ||
SpatialIndex.py | ||
--------------------- | ||
Date : January 2016 | ||
Copyright : (C) 2016 by Alexander Bruy | ||
Email : alexander dot bruy at gmail dot com | ||
*************************************************************************** | ||
* * | ||
* 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__ = 'Alexander Bruy' | ||
__date__ = 'January 2016' | ||
__copyright__ = '(C) 2016, Alexander Bruy' | ||
|
||
# This will get replaced with a git SHA1 when you do a git archive | ||
|
||
__revision__ = '$Format:%H$' | ||
|
||
import os | ||
|
||
from PyQt4.QtGui import QIcon | ||
|
||
from qgis.core import QgsVectorDataProvider | ||
|
||
from processing.core.GeoAlgorithm import GeoAlgorithm | ||
from processing.core.parameters import ParameterVector | ||
from processing.core.outputs import OutputVector | ||
|
||
from processing.tools import dataobjects, vector | ||
|
||
pluginPath = os.path.split(os.path.split(os.path.dirname(__file__))[0])[0] | ||
|
||
|
||
class SpatialIndex(GeoAlgorithm): | ||
|
||
INPUT = 'INPUT' | ||
OUTPUT = 'OUTPUT' | ||
|
||
#def getIcon(self): | ||
# return QIcon(os.path.join(pluginPath, 'images', 'ftools', 'basic_statistics.png')) | ||
|
||
def defineCharacteristics(self): | ||
self.name, self.i18n_name = self.trAlgorithm('Create spatial index') | ||
self.group, self.i18n_group = self.trAlgorithm('Vector general tools') | ||
|
||
self.addParameter(ParameterVector(self.INPUT, | ||
self.tr('Input Layer'), | ||
[ParameterVector.VECTOR_TYPE_ANY])) | ||
self.addOutput(OutputVector(self.OUTPUT, | ||
self.tr('Indexed layer'), True)) | ||
|
||
|
||
def processAlgorithm(self, progress): | ||
fileName = self.getParameterValue(self.INPUT) | ||
layer = dataobjects.getObjectFromUri(fileName) | ||
provider = layer.dataProvider() | ||
|
||
if provider.capabilities() & QgsVectorDataProvider.CreateSpatialIndex: | ||
if not provider.createSpatialIndex(): | ||
progress.setInfo(self.tr('Can not create spatial index')) | ||
else: | ||
progress.setInfo(self.tr("Layer's data provider does not support " | ||
"spatial indexes")) | ||
|
||
self.setOutputValue(self.OUTPUT, fileName) |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.