2012-10-04 19:33:47 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
2007-01-09 02:39:15 +00:00
|
|
|
|
2012-10-04 19:33:47 +02:00
|
|
|
"""
|
|
|
|
***************************************************************************
|
|
|
|
__init__.py
|
|
|
|
---------------------
|
|
|
|
Date : January 2007
|
|
|
|
Copyright : (C) 2007 by Martin Dobias
|
2012-10-08 00:29:13 +02:00
|
|
|
Email : wonder dot sk at gmail dot com
|
2012-10-04 19:33:47 +02:00
|
|
|
***************************************************************************
|
|
|
|
* *
|
|
|
|
* 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__ = 'Martin Dobias'
|
|
|
|
__date__ = 'January 2007'
|
|
|
|
__copyright__ = '(C) 2007, Martin Dobias'
|
|
|
|
# This will get replaced with a git SHA1 when you do a git archive
|
|
|
|
__revision__ = '$Format:%H$'
|
2013-06-11 22:13:34 +10:00
|
|
|
|
2013-07-17 20:44:21 +10:00
|
|
|
import sip
|
2014-05-02 11:42:37 +02:00
|
|
|
|
2013-07-17 20:44:21 +10:00
|
|
|
try:
|
|
|
|
apis = ["QDate", "QDateTime", "QString", "QTextStream", "QTime", "QUrl", "QVariant"]
|
|
|
|
for api in apis:
|
|
|
|
sip.setapi(api, 2)
|
|
|
|
except ValueError:
|
|
|
|
# API has already been set so we can't set it again.
|
|
|
|
pass
|
|
|
|
|
2013-09-25 17:08:17 -06:00
|
|
|
from qgis.core import QgsFeature, QgsGeometry
|
|
|
|
|
2013-06-12 08:42:01 +10:00
|
|
|
try:
|
2013-06-12 08:57:34 +10:00
|
|
|
# Add a __nonzero__ method onto QPyNullVariant so we can check for null values easier.
|
|
|
|
# >>> value = QPyNullVariant("int")
|
|
|
|
# >>> if value:
|
|
|
|
# >>> print "Not a null value"
|
|
|
|
from types import MethodType
|
|
|
|
from PyQt4.QtCore import QPyNullVariant
|
2013-06-12 08:42:01 +10:00
|
|
|
def __nonzero__(self):
|
|
|
|
return False
|
2013-06-11 22:13:34 +10:00
|
|
|
|
2013-08-28 13:14:00 +02:00
|
|
|
def __repr__(self):
|
|
|
|
return 'NULL'
|
|
|
|
|
2013-08-29 12:17:20 +02:00
|
|
|
def __eq__(self, other):
|
|
|
|
return isinstance(other, QPyNullVariant) or other is None
|
|
|
|
|
2013-08-30 12:00:21 +02:00
|
|
|
def __ne__(self, other):
|
|
|
|
return not isinstance(other, QPyNullVariant) and other is not None
|
|
|
|
|
2013-06-12 08:42:01 +10:00
|
|
|
QPyNullVariant.__nonzero__ = MethodType(__nonzero__, None, QPyNullVariant)
|
2013-08-28 13:14:00 +02:00
|
|
|
QPyNullVariant.__repr__ = MethodType(__repr__, None, QPyNullVariant)
|
2013-08-29 12:17:20 +02:00
|
|
|
QPyNullVariant.__eq__= MethodType(__eq__, None, QPyNullVariant)
|
2013-08-30 12:00:21 +02:00
|
|
|
QPyNullVariant.__ne__= MethodType(__ne__, None, QPyNullVariant)
|
2013-08-29 12:17:20 +02:00
|
|
|
|
|
|
|
# define a dummy QPyNullVariant instance NULL in qgis.core
|
|
|
|
# this is mainly used to compare against
|
|
|
|
# so one can write if feat['attr'] == NULL:
|
|
|
|
from qgis import core
|
|
|
|
core.NULL = QPyNullVariant( int )
|
2013-06-12 08:42:01 +10:00
|
|
|
except ImportError:
|
|
|
|
pass
|
2013-09-23 20:55:57 +10:00
|
|
|
|
|
|
|
|
|
|
|
def mapping_feature(feature):
|
|
|
|
geom = feature.geometry()
|
|
|
|
properties = {}
|
|
|
|
fields = [field.name() for field in feature.fields()]
|
|
|
|
properties = dict(zip(fields, feature.attributes()))
|
2013-09-25 17:08:17 -06:00
|
|
|
return {
|
2013-09-23 20:55:57 +10:00
|
|
|
'type' : 'Feature',
|
|
|
|
'properties' : properties,
|
|
|
|
'geometry' : geom.__geo_interface__}
|
|
|
|
|
|
|
|
def mapping_geometry(geometry):
|
|
|
|
geo = geometry.exportToGeoJSON()
|
|
|
|
# We have to use eval because exportToGeoJSON() gives us
|
2013-09-25 17:08:17 -06:00
|
|
|
# back a string that looks like a dictionary.
|
2013-09-23 20:55:57 +10:00
|
|
|
return eval(geo)
|
|
|
|
|
|
|
|
QgsFeature.__geo_interface__ = property(mapping_feature)
|
|
|
|
QgsGeometry.__geo_interface__ = property(mapping_geometry)
|