2012-10-05 23:28:47 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
"""
|
|
|
|
***************************************************************************
|
|
|
|
SagaUtils.py
|
|
|
|
---------------------
|
|
|
|
Date : August 2012
|
|
|
|
Copyright : (C) 2012 by Victor Olaya
|
|
|
|
Email : volayaf 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__ = 'Victor Olaya'
|
|
|
|
__date__ = 'August 2012'
|
|
|
|
__copyright__ = '(C) 2012, Victor Olaya'
|
|
|
|
# This will get replaced with a git SHA1 when you do a git archive
|
|
|
|
__revision__ = '$Format:%H$'
|
|
|
|
|
2012-09-15 18:25:25 +03:00
|
|
|
import os
|
2013-02-26 00:10:01 +01:00
|
|
|
import stat
|
|
|
|
import traceback
|
2012-09-15 18:25:25 +03:00
|
|
|
import subprocess
|
2013-02-26 00:10:01 +01:00
|
|
|
from sextante.core.SextanteUtils import SextanteUtils
|
2012-09-15 18:25:25 +03:00
|
|
|
from sextante.core.SextanteConfig import SextanteConfig
|
|
|
|
from sextante.core.SextanteLog import SextanteLog
|
2013-02-24 16:05:59 +01:00
|
|
|
from qgis.core import *
|
|
|
|
from PyQt4.QtCore import *
|
2013-02-26 00:10:01 +01:00
|
|
|
from sextante.core.SextanteVectorWriter import SextanteVectorWriter
|
|
|
|
from sextante.core.QGisLayers import QGisLayers
|
|
|
|
|
2012-09-15 18:25:25 +03:00
|
|
|
|
|
|
|
class SagaUtils:
|
|
|
|
|
|
|
|
SAGA_LOG_COMMANDS = "SAGA_LOG_COMMANDS"
|
|
|
|
SAGA_LOG_CONSOLE = "SAGA_LOG_CONSOLE"
|
|
|
|
SAGA_AUTO_RESAMPLING = "SAGA_AUTO_RESAMPLING"
|
|
|
|
SAGA_RESAMPLING_REGION_XMIN = "SAGA_RESAMPLING_REGION_XMIN"
|
|
|
|
SAGA_RESAMPLING_REGION_YMIN = "SAGA_RESAMPLING_REGION_YMIN"
|
|
|
|
SAGA_RESAMPLING_REGION_XMAX = "SAGA_RESAMPLING_REGION_XMAX"
|
|
|
|
SAGA_RESAMPLING_REGION_YMAX = "SAGA_RESAMPLING_REGION_YMAX"
|
|
|
|
SAGA_RESAMPLING_REGION_CELLSIZE = "SAGA_RESAMPLING_REGION_CELLSIZE"
|
|
|
|
SAGA_FOLDER = "SAGA_FOLDER"
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def sagaBatchJobFilename():
|
|
|
|
|
|
|
|
if SextanteUtils.isWindows():
|
|
|
|
filename = "saga_batch_job.bat";
|
|
|
|
else:
|
|
|
|
filename = "saga_batch_job.sh";
|
|
|
|
|
|
|
|
batchfile = SextanteUtils.userFolder() + os.sep + filename
|
|
|
|
|
|
|
|
return batchfile
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def sagaPath():
|
|
|
|
folder = SextanteConfig.getSetting(SagaUtils.SAGA_FOLDER)
|
|
|
|
if folder == None:
|
|
|
|
folder =""
|
|
|
|
|
|
|
|
return folder
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def sagaDescriptionPath():
|
|
|
|
return os.path.join(os.path.dirname(__file__),"description")
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def createSagaBatchJobFileFromSagaCommands(commands):
|
|
|
|
|
|
|
|
fout = open(SagaUtils.sagaBatchJobFilename(), "w")
|
|
|
|
if SextanteUtils.isWindows():
|
|
|
|
fout.write("set SAGA=" + SagaUtils.sagaPath() + "\n");
|
|
|
|
fout.write("set SAGA_MLB=" + SagaUtils.sagaPath()+ os.sep + "modules" + "\n");
|
|
|
|
fout.write("PATH=PATH;%SAGA%;%SAGA_MLB%\n");
|
|
|
|
else:
|
|
|
|
pass
|
|
|
|
for command in commands:
|
2012-11-15 23:53:31 +01:00
|
|
|
fout.write("saga_cmd " + command.encode("utf8") + "\n")
|
2012-09-15 18:25:25 +03:00
|
|
|
|
|
|
|
fout.write("exit")
|
|
|
|
fout.close()
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def executeSaga(progress):
|
|
|
|
if SextanteUtils.isWindows():
|
|
|
|
command = ["cmd.exe", "/C ", SagaUtils.sagaBatchJobFilename()]
|
|
|
|
else:
|
|
|
|
os.chmod(SagaUtils.sagaBatchJobFilename(), stat.S_IEXEC | stat.S_IREAD | stat.S_IWRITE)
|
|
|
|
command = [SagaUtils.sagaBatchJobFilename()]
|
|
|
|
loglines = []
|
|
|
|
loglines.append("SAGA execution console output")
|
|
|
|
proc = subprocess.Popen(command, shell=True, stdout=subprocess.PIPE, stdin=subprocess.PIPE,stderr=subprocess.STDOUT, universal_newlines=True).stdout
|
|
|
|
for line in iter(proc.readline, ""):
|
|
|
|
if "%" in line:
|
|
|
|
s = "".join([x for x in line if x.isdigit()])
|
2012-11-19 08:04:03 +01:00
|
|
|
try:
|
|
|
|
progress.setPercentage(int(s))
|
|
|
|
except:
|
|
|
|
pass
|
2012-09-15 18:25:25 +03:00
|
|
|
else:
|
|
|
|
line = line.strip()
|
|
|
|
if line!="/" and line!="-" and line !="\\" and line!="|":
|
|
|
|
loglines.append(line)
|
|
|
|
progress.setConsoleInfo(line)
|
|
|
|
if SextanteConfig.getSetting(SagaUtils.SAGA_LOG_CONSOLE):
|
|
|
|
SextanteLog.addToLog(SextanteLog.LOG_INFO, loglines)
|
|
|
|
|
2013-02-24 16:05:59 +01:00
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def checkSagaIsInstalled(cls):
|
|
|
|
if SextanteUtils.isWindows():
|
|
|
|
path = SagaUtils.sagaPath()
|
|
|
|
if path == "":
|
|
|
|
return "SAGA folder is not configured.\nPlease configure it before running SAGA algorithms."
|
|
|
|
cmdpath = os.path.join(path, "saga_cmd.exe")
|
|
|
|
if not os.path.exists(cmdpath):
|
|
|
|
return ("The specified SAGA folder does not contain a valid SAGA executable.\n"
|
|
|
|
+ "Please, go to the SEXTANTE settings dialog, and check that the SAGA\n"
|
|
|
|
+ "folder is correctly configured")
|
|
|
|
|
|
|
|
SAGA_INSTALLED = "/SextanteQGIS/SagaInstalled"
|
|
|
|
settings = QSettings()
|
|
|
|
if settings.contains(SAGA_INSTALLED):
|
|
|
|
return
|
|
|
|
|
|
|
|
try:
|
|
|
|
qgis = QGisLayers.iface
|
|
|
|
crs = qgis.mapCanvas().mapRenderer().destinationCrs()
|
|
|
|
fields = []
|
|
|
|
fields.append(QgsField("NUM_FIELD", QVariant.Int))
|
|
|
|
filename = SextanteUtils.getTempFilename("shp")
|
|
|
|
writer = SextanteVectorWriter(filename, None, fields, QGis.WKBPoint, crs)
|
|
|
|
for x in range(5):
|
|
|
|
for y in range(5):
|
|
|
|
attrs = []
|
|
|
|
attrs.append(QVariant(x))
|
|
|
|
outFeat = QgsFeature()
|
|
|
|
pt = QgsPoint(x, y)
|
|
|
|
outFeat.setGeometry(QgsGeometry.fromPoint(pt))
|
|
|
|
outFeat.setAttributes(attrs)
|
|
|
|
writer.addFeature(outFeat)
|
|
|
|
del writer.writer
|
2013-02-26 00:10:01 +01:00
|
|
|
del writer
|
|
|
|
from sextante.core.Sextante import runalg
|
|
|
|
result = runalg("saga:thiessenpolygons", filename, None)
|
2013-02-24 16:05:59 +01:00
|
|
|
if not os.path.exists(result['POLYGONS']):
|
|
|
|
return "It seems that SAGA is not correctly installed in your system.\nPlease install it before running SAGA algorithms."
|
|
|
|
except:
|
2013-02-26 00:10:01 +01:00
|
|
|
s = traceback.format_exc()
|
|
|
|
return "Error while checking SAGA installation. SAGA might not be correctly configured.\n" + s;
|
|
|
|
|
2013-02-24 16:05:59 +01:00
|
|
|
|
|
|
|
settings.setValue("/SextanteQGIS/SagaInstalled", True)
|
|
|
|
|