QGIS/python/plugins/processing/core/VectorWriter.py

94 lines
3.3 KiB
Python
Raw Normal View History

2012-10-05 23:28:47 +02:00
# -*- coding: utf-8 -*-
"""
***************************************************************************
2013-08-12 20:44:27 +02:00
VectorWriter.py
2012-10-05 23:28:47 +02:00
---------------------
Date : September 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__ = 'September 2012'
__copyright__ = '(C) 2012, Victor Olaya'
2012-10-05 23:28:47 +02:00
# This will get replaced with a git SHA1 when you do a git archive
2012-10-05 23:28:47 +02:00
__revision__ = '$Format:%H$'
2012-09-14 11:53:46 +03:00
from PyQt4.QtCore import *
from qgis.core import *
2013-08-12 20:44:27 +02:00
class VectorWriter:
2012-09-14 11:53:46 +03:00
MEMORY_LAYER_PREFIX = 'memory:'
2012-09-14 11:53:46 +03:00
TYPE_MAP = {
QGis.WKBPoint: 'Point',
QGis.WKBLineString: 'LineString',
QGis.WKBPolygon: 'Polygon',
QGis.WKBMultiPoint: 'MultiPoint',
QGis.WKBMultiLineString: 'MultiLineString',
QGis.WKBMultiPolygon: 'MultiPolygon',
}
2012-09-14 11:53:46 +03:00
def __init__(self, fileName, encoding, fields, geometryType,
crs, options=None):
2012-09-14 11:53:46 +03:00
self.fileName = fileName
self.isMemory = False
self.memLayer = None
self.writer = None
if encoding is None:
settings = QSettings()
encoding = settings.value('/Processing/encoding', 'System')
2012-09-14 11:53:46 +03:00
if self.fileName.startswith(self.MEMORY_LAYER_PREFIX):
self.isMemory = True
uri = self.TYPE_MAP[geometryType]
if crs.isValid():
uri += '?crs=' + crs.authid() + '&'
fieldsdesc = ['field=' + str(f.name()) for f in fields]
fieldsstring = '&'.join(fieldsdesc)
uri += fieldsstring
self.memLayer = QgsVectorLayer(uri, self.fileName, 'memory')
2013-02-28 22:08:32 +01:00
self.writer = self.memLayer.dataProvider()
2012-09-14 11:53:46 +03:00
else:
formats = QgsVectorFileWriter.supportedFiltersAndFormats()
OGRCodes = {}
for (key, value) in formats.items():
extension = unicode(key)
2012-09-14 11:53:46 +03:00
extension = extension[extension.find('*.') + 2:]
extension = extension[:extension.find(' ')]
2012-09-14 11:53:46 +03:00
OGRCodes[extension] = value
extension = self.fileName[self.fileName.rfind('.') + 1:]
if extension not in OGRCodes:
extension = 'shp'
self.filename = self.filename + 'shp'
2013-02-07 01:09:39 +01:00
qgsfields = QgsFields()
for field in fields:
qgsfields.append(field)
2013-02-07 01:09:39 +01:00
self.writer = QgsVectorFileWriter(self.fileName, encoding,
qgsfields, geometryType, crs, OGRCodes[extension])
2012-09-14 11:53:46 +03:00
def addFeature(self, feature):
if self.isMemory:
self.writer.addFeatures([feature])
else:
self.writer.addFeature(feature)