iOS中给WebView写入cookie

在混合模式的开发过程中,用户在NativeApp中进行了登陆,但打开WebApp的时候还需要登陆,这就会造成较差的用户体验。
如果WebApp支持使用从Cookie验证的话,可以通过在NativeApp往WebView写入cookie的方式来解决该问题。

代码如下:

NSMutableDictionary *cookieProperties =         [NSMutableDictionary dictionary];
[cookieProperties setObject:@"testCookie" forKey:NSHTTPCookieName];
[cookieProperties setObject:@"someValue123456" forKey:NSHTTPCookieValue];
[cookieProperties setObject:@"www.example.com" forKey:NSHTTPCookieDomain];
[cookieProperties setObject:@"www.example.com" forKey:NSHTTPCookieOriginURL];
[cookieProperties setObject:@"/" forKey:NSHTTPCookiePath];
[cookieProperties setObject:@"0" forKey:NSHTTPCookieVersion];

// set expiration to one month from now or any NSDate of your choosing
// this makes the cookie sessionless and it will persist across web sessions and app launches
/// if you want the cookie to be destroyed when your app exits, don't set this
[cookieProperties setObject:[[NSDate date] dateByAddingTimeInterval:2629743] forKey:NSHTTPCookieExpires];

NSHTTPCookie *cookie = [NSHTTPCookie cookieWithProperties:cookieProperties];
[[NSHTTPCookieStorage sharedHTTPCookieStorage] setCookie:cookie];
iOS Leave a comment

ArcGIS开发权威指南 上架

《ArcGIS开发权威指南》内容提要

随着Web GIS 2.0时代的到来,单个研发技术的实施已经不能满足当前GIS项目的基本需求。如今用户既需要专业人士进行业务管理,又要求整个企业进行协作分享,而且还需要将信息通过网络或者移动端进行发布,这无疑需要多源技术的共同结合才能完成。那么从事GIS行业的开发者就需要了解GIS多源的开发技术。《ArcGIS开发权威指南》主要介绍ArcGIS平台及相关产品的开发模式,包括桌面端开发、Web端开发、移动端开发、数据库开发、脚本开发等主流的ArcGIS开发技术。

《ArcGIS开发权威指南》要求用户具有ArcGIS for Desktop、ArcGIS for Server、ArcSDE等ArcGIS产品相关基础,同时要求具有C#、Java、Python、JavaScript、PL/SQL等编程基础。《ArcGIS开发权威指南》适合ArcGIS开发工程师、GIS项目经理、GIS系统建设者,以及即将步入社会的相关专业学生阅读。

购买地址: 亚马逊

 

ArcGIS Leave a comment

Esri与开源

Esri与开源

随着主流的开发平台逐渐开源化,加上GitHub的兴起,开源深入了各个领域,Esri也不例外,积极的拥抱开源。
目前,Esri产品不仅支持开源产品(Linux,PostgreSQL,Python等),还开源了许多产品。
Esri开源代码主要通过github来进行发布,主页面为http://esri.github.io/

在Esri开源的产品中既有App开发框架,也有web前端功能类库,还有服务器端产品,基本上覆盖了Web开发,移动端开发和服务器端开发。使用Esri开源的产品,可以大大加快用户业务系统的开发,降低系统开发难度。 目前主要的开源产品包括:

  • FlexViewer
  • Esri Geoportal Server
  • ArcGIS Editor for OpenStreetMap
  • Terraformer
  • Esri Leaflet
  • Koop
  • Esri Geometry API for Java
  • 其他

FlexViewer

  • 项目地址:https://github.com/Esri/arcgis-viewer-flex
  • 项目截图:
    image
  • 项目介绍:FlexViewer可以说是目前为止Esri最成功的一款开源产品。FlexViewer从2009年开源至今,已经有成千上万个网站在使用。
    Flex Viewer是可以高效开发基于WEB的地理信息应用系统的一种完全免费的应用程序框架。业务人员使用该框架可以无需任何额外的编程就能够通过简单配置的方法快速搭建起一个基于ArcGIS Server的、以地图为中心的富客户端(RIA)应用的原型。该框架中还自带了大量的能够满足各种地图应用需要的Widget,如Identify、GeoRSS、DataExtract、BookMark、NetworkAnalyst、MapSwitcher等地图交互和分析等工具。同时,如果需要增加新的Widget,则开发人员只需在自定义的Widget中实现框架要求的接口,然后再将该Widget配置到框架中的Config.xml文件中,就能在无需修改框架代码的情况下轻松地完成独立Widget与框架的无缝集成。

Esri Geoportal Server

  • 项目地址:https://github.com/Esri/geoportal-server
  • 项目截图:
  • 项目介绍:Geoportal Server主要用于展示和使用各项空间资源,包括数据集、栅格数据以及网络服务。它能够帮助用户管理和发布各项空间资源的元数据以便于检索和展示资源。
    Geoportal server可支撑基于标准的数据交换和元数据展示应用。 使用Geoportal server可以提高企业或组织内地理空间活动的效率和效果,能够促进地理信息资源的共享,提高地理信息资源的查找效率并充分利用这些资源。

ArcGIS Editor for OpenStreetMap

项目地址:https://github.com/Esri/arcgis-osm-editor
* 项目截图:
image
* 项目介绍
ArcGIS Editor for OpenStreetMap是一个基于c#开发的在ArcMap中读取OpenStreetMap数据的插件。使用这个插件的功能如下:
1. 从OSM网站下载数据并存储到File Geodatabase中 2. 创建planet文件(.osm) 3. 编辑OSM数据 4. 将编辑后的数据更新到OSM网站 5. 从OSM数据创建网络数据集

Terraformer

  • 项目地址:https://github.com/Esri/Terraformer
  • 项目介绍:Terraformer是基于javascript的地理工具包,主要包括下面几个模块:
    1. Terraformer Core,主要用来处理GeoJSON
    2. WKT Parser,用来将WKT格式的数据转换成GeoJSON
    3. ArcGIS Geometry Parser,用来将ArcGIS Geometry格式数据转换成GeoJSON
    4. GeoStore,使用GeoJSON格式存储和查询空间数据的框架,支持空间索引

该项目既可以在浏览器中使用,又可以在node.js中使用

Esri Leaflet

项目地址:https://github.com/Esri/esri-leaflet
项目截图:
image
项目介绍:
Esri Leaflet是著名开源地图类库Leaflet的插件,主要实现在Leaflet中加载基础地图、要素服务的功能。同时还支持加载Esri的切片地图服务、动态地图服务和影像服务。
Esri Leaflet的目标不是替换掉 ArcGIS API for JavaScript,而是为Leaflet用户提供更方便调用Esri服务的方式。

Koop

项目地址:https://github.com/koopjs/koop

项目架构:
image
项目介绍:
Koop是一个基于Javascript的开源ETL工具。Koop支持将不同来源的数据转换成GeoJSON服务或者ArcGIS 要素服务。方便将来源不同的数据集成到Esri的产品体系中。
Koop是一个服务器端产品,运行在node.js中。

Esri Geometry API for Java

项目地址:https://github.com/Esri/geometry-api-java
项目介绍:Esri Geometry API for Java主要用来为第三方软件集成空间数据处理能力,例如Hadoop用户可以使用该类库在MapReduce环境中进行空间数据处理。该类库同样也可以用于Hive UDF中。当然,所有使用java开发的项目都可以集成该类库来进行空间数据的处理。
Esri Geometry API for Java提供的主要功能包括:

  1. 可以通过API直接创建Geometry,或者从JSON,WKT,Shape格式导入Geometry
  2. 提供了空间操作,例如叠加、相交、裁剪、缓冲分析等
  3. 提供了空间拓扑判定功能,例如相等、包含等

其他

除了上面的开源产品,Esri还开源了非常多的产品,主要包括:

更多的开源产品可以到主页面查看http://esri.github.io/

ArcGIS Leave a comment

QGIS python开发手册–使用栅格图层

使用栅格图层

图层详细信息

栅格图层一般包含一个或多个波段,即单波段栅格图层或多波段栅格图层。一般来说彩色图形包含红、蓝、绿三个波段。单波段图层一般用来表示连续变量(如高程)或离散变量(如土地利用)。在有些情况下,栅格图层包含一个调色板,栅格值对应的颜色会存储在调色板中,下面代码获取栅格图层的基本信息,例如长度、宽度、范围波段数、元数据等等。

    rlayer.width(), rlayer.height()
    (812, 301)
    rlayer.extent()
    <qgis._core.QgsRectangle object at 0x000000000F8A2048>
    rlayer.extent().toString()
    u'12.095833,48.552777 : 18.863888,51.056944'
    rlayer.rasterType()
    2  # 0 = GrayOrUndefined (single band), 1 = Palette (single band), 2 = Multiband
    rlayer.bandCount()
    3
    rlayer.metadata()
    u'<p class="glossy">Driver:</p>...'
    rlayer.hasPyramids()
    False

渲染器

当栅格图层加载后,QGIS会根据栅格类型使用一个默认的渲染器。渲染器可以在图层的属性中修改,也可以使用程序修改.下面代码查询当前使用的渲染器:

    >>> rlayer.renderer()
    <qgis._core.QgsSingleBandPseudoColorRenderer object at 0x7f471c1da8a0>
    >>> rlayer.renderer().type()
    u'singlebandpseudocolor'

使用QgsRasterLayer对象的setRenderer()方法可以给图层设置渲染器,可选的渲染器包括:
* QgsMultiBandColorRenderer * QgsPalettedRasterRenderer * QgsSingleBandColorDataRenderer * QgsSingleBandGrayRenderer * QgsSingleBandPseudoColorRenderer 这些渲染器全部继承于QgsRasterRenderer。

单波段栅格图层既可以以灰度图的方式显示,也可以通过色带映射的方式以彩色方式显示。多波段栅格图层,一般把波段映射成RGB颜色值进行显示。当然多波段栅格图层也可以使用灰度或者色带的方式显示其中的一个波段。

下面的小节会展开介绍如何查询和修改栅格图层的显示风格。

单波段栅格图层

下面的例子使用一个从绿色到黄色的色带(对应栅格值0-255)来渲染单波段栅格图层,首先创建一个QgsRasterShader对象,并配置他的shader函数:

>> fcn = QgsColorRampShader()
>>> fcn.setColorRampType(QgsColorRampShader.INTERPOLATED)
>> lst = [ QgsColorRampShader.ColorRampItem(0, QColor(0,255,0)), \
QgsColorRampShader.ColorRampItem(255, QColor(255,255,0)) ]
>>> fcn.setColorRampItemList(lst)
>>> shader = QgsRasterShader()
>>> shader.setRasterShaderFunction(fcn)

shader函数完成像素值和颜色值的映射,映射方式有三种:
* 线性:使用线性插值的方式获得像素的颜色值
* 离散:像素值大于或等于某一个阈值对应的颜色值,类似与ArcGIS中的分类渲染
* 精确:不进行插值,只有设置的色带中有对应的值才显示,类似于ArcGIS中的唯一值渲染
第二步,给栅格图层设置渲染器:

>>> renderer = QgsSingleBandPseudoColorRenderer(layer.dataProvider(), 1, shader)
>>> layer.setRenderer(renderer)

代码中的数字1为波段号。

多波段栅格图层

默认情况下,QGIS的多波段栅格图层使用RGB模式来生成彩色图像,有些情况下,如果用户想重置这个设置,可以使用下面的代码,代码重设了波段对应RGB的顺序,把波段1设为G,把波段2设为R:

rlayer.renderer().setGreenBand(1)
rlayer.renderer().setRedBand(2)

刷新图层

当用户修改了图层的符号设置并且需要立即显示的话,需要立即刷新图层,代码如下:

if hasattr(layer, "setCacheImage"):
      layer.setCacheImage(None)
layer.triggerRepaint()

前两行代码确保图层的缓存图片被删除。该方法在QGIS1.4以后有效,为了兼容QGIS的所有版本,请在使用前检查该函数是否存在。
triggerRepaint()方法用来强制地图刷新。
需要注意的是,对于WMS服务,只使用这个方法无效,还需要重新加载数据,刷新才会起作用,代码如下:

layer.dataProvider().reloadData()
layer.triggerRepaint()

在有些情况下,用户修改完图层的符号设置后,需要更新Layer List显示的图例,通过下面代码可以实现:

iface.legendInterface().refreshLayerSymbology(layer)

查询值

查询栅格图层中特定位置的值,使用identify()方法即可,代码如下:

ident = rlayer.dataProvider().identify(QgsPoint(15.30, 40.98), \
  QgsRaster.IdentifyFormatValue)
if ident.isValid():
  print ident.results()

result方法的返回结果是一个字段对象,包含每个波段对应的值:

{1: 17, 2: 220}

 

python Leave a comment

QGIS Python开发手册-加载图层

加载图层

在QGIS中,图层主要分为矢量图层和栅格图层,另外还支持自定义图层,本文不予讨论。

矢量图层

加载矢量图层,需要知道图层的数据源标识、名称和数据源类型(provider),加载代码如下:

layer = QgsVectorLayer(data_source, layer_name, provider_name)
if not layer.isValid():
      print "Layer failed to load!"

根据数据源类型的不同,数据源标识也不同。图层名称用于在图层列表Widget里显示。需要注意的是在加载图层后要判断是否加载成功,可以通过layer的isValid()方法进行判断。
在QGIS中快速打开并显示图层的方式是使用QgisInterface的addVectorLayer方法,代码如下:

 layer = iface.addVectorLayer("/path/to/shapefile/file.shp",     "layer_name_you_like", "ogr")
if not layer:
      print "Layer failed to load!"

该方法创建一个图层,静将图层假入到地图对象中,其返回一个图层对象。如果图层对象为None,则图层加载失败。
下面介绍加载不同数据源的图层:
* OGR–数据源标识为指向文件的路径

 vlayer = QgsVectorLayer("/path/to/shapefile/file.shp", "layer_name_you_like", "ogr")   

* PostGIS数据库–数据源标识是数据库连接字符串,可以通过QgsDataSourceURI类来生成,需要注意的是QGIS编译的时候选择了支持Postgres,否则不支持PostGIS。代码如下:

     uri = QgsDataSourceURI()
    # set host name, port, database name, username and password
    uri.setConnection("localhost", "5432", "dbname", "johny", "xxx")
    # set database schema, table name, geometry column and optionally
    # subset (WHERE clause)
    uri.setDataSource("public", "roads", "the_geom", "cityid = 2643")

    vlayer = QgsVectorLayer(uri.uri(), "layer_name_you_like", "postgres")

* CSV或其他平面数据文件–用分号作为分隔符,并且x字段存储x坐标,y字段存储y坐标,使用上述规则打开文件,则相关代码如下:

      uri = "/some/path/file.csv?delimiter=%s&xField=%s&yField=%s" % (";", "x", "y")
    vlayer = QgsVectorLayer(uri, "layer_name_you_like", "delimitedtext")

需要注意的是,从QGIS1.7开始,该类型的数据源标识为URL,因此路径要包含file://前缀。另外,使用该数据源还可以加载WKT格式的数据,并且允许定义参考系,相关代码如下:

    uri = "file:///some/path/file.csv?delimiter=%s&crs=epsg:4723&wktField=%s" % (";", "shape")

* GPX–gpx数据源可以读取从gpx文件里读取tracks, routes and waypoints 。使用gpx数据源的时候需要在路径中指定上述三种类型中的一种,代码如下:

     uri = "path/to/gpx/file.gpx?type=track"
    vlayer = QgsVectorLayer(uri, "layer_name_you_like", "gpx")

* SpatiaLite数据库–从QGIS1.1开始支持,类似于PostGIS数据库

    uri = QgsDataSourceURI()
    uri.setDatabase('/home/martin/test-2.3.sqlite')
    schema = ''
    table = 'Towns'
    geom_column = 'Geometry'
    uri.setDataSource(schema, table, geom_column)

    display_name = 'Towns'
    vlayer = QgsVectorLayer(uri.uri(), display_name, 'spatialite')

* MySQL,几何对象为WKB类型,通过OGR读取–数据源标识为数据库连接字符串,代码如下:

    uri = "MySQL:dbname,host=localhost,port=3306,user=root,password=xxx|layername=my_table"
    vlayer = QgsVectorLayer( uri, "my_table", "ogr" )

* WFS连接–数据源标识为URI,代码如下:

    uri = "http://localhost:8080/geoserver/wfs?srsname=EPSG:        23030&typename=union&version=1.0.0&request=GetFeature&service=WFS",
    vlayer = QgsVectorLayer("my_wfs_layer", "WFS")
uri也可以通过urilib创建:

    params = {
        'service': 'WFS',
     'version': '1.0.0',
    'request': 'GetFeature',
    'typename': 'union',
    'srsname': "EPSG:23030"
    }
    uri = 'http://localhost:8080/geoserver/wfs?' +      urllib.unquote(urllib.urlencode(params))

栅格图层

在QGIS中,使用GDAL来读取栅格图层,因此支持非常多种栅格格式。如果打开某些栅格文件有问题,请检查GDAL是否支持这种格式。
加载栅格图层,只需要指定栅格文件的路径和名称即可,代码如下:

    fileName = "/path/to/raster/file.tif"
    fileInfo = QFileInfo(fileName)
    baseName = fileInfo.baseName()
    rlayer = QgsRasterLayer(fileName, baseName)
    if not rlayer.isValid():
         print "Layer failed to load!"

和矢量图层类似,使用QgisInterface的addRasterLayer方法可以快速加载和显示栅格图层,代码如下:

    iface.addRasterLayer("/path/to/raster/file.tif", "layer_name_you_like")

上面的代码会创建一个栅格图层,并将该图层添加到地图对象中。
栅格图层还可以从WCS服务中创建,代码如下:

    urlWithParams = 'url=http://wms.jpl.nasa.gov/wms.cgi&layers=global_mosaic&styles=pseudo&format=image/jpeg&crs=EPSG:4326'
    rlayer = QgsRasterLayer(urlWithParams, 'some layer name', 'wms')
    if not rlayer.isValid():
          print "Layer failed to load!"

同样的,栅格图层还可以从WMS服务创建,代码如下:

    urlWithParams = 'url=http://wms.jpl.nasa.gov/wms.cgi&layers=global_mosaic&styles=pseudo&format=image/jpeg&crs=EPSG:4326'
    rlayer = QgsRasterLayer(urlWithParams, 'some layer name', 'wms')
    if not rlayer.isValid():
          print "Layer failed to load!"

图层加入到地图中

图层加载完成后,如果想进行显示,需要加载到地图中。代码如下:

    QgsMapLayerRegistry.instance().addMapLayer(layer)

当程序退出的时候,图层会自动析构,如果想手动删除,可以使用下面的代码:

    QgsMapLayerRegistry.instance().removeMapLayer(layer_id) 

用户可以通过图层的id来获取地图中图层,下面的方法列出地图对象中的所有图层:

    QgsMapLayerRegistry.instance().mapLayers()
python Leave a comment

QGIS python开发手册-加载工程文件

加载工程文件

在QGIS中加载工程文件需要使用QgsProject实例的read()方法,该方法需要传入QFileInfo对象。QFileInfo对象指定了QGIS工程文件的路径,下面的代码加载QGIS的工程文件到当前应用程序中:

# If you are not inside a QGIS console you first need to import
# qgis and PyQt4 classes you will use in this script as shown below:
from qgis.core import QgsProject
from PyQt4.QtCore import QFileInfo
# Get the project instance
project = QgsProject.instance()
# Print the current project file name (might be empty in case no projects have been loaded)
print project.fileName
u'/home/user/projects/my_qgis_project.qgs'
# Load another project
project.read(QFileInfo('/home/user/projects/my_other_qgis_project.qgs'))
print project.fileName
u'/home/user/projects/my_other_qgis_project.qgs'

在应用程序中,如果修改了工程文件,例如增加、删除图层,可以使用QgsProject实例的write()方法保存工程文件,write()方法可以传入QFileInfo对象,将工程文件另存到其他目录中。如下面代码:

# Save the project to the same
project.write()
# ... or to a new file
project.write(QFileInfo('/home/user/projects/my_new_qgis_project.qgs'))

read()和write()方法都会返回布尔类型的结果,用于判断读写是否成功。
需要注意的是,如果自定义程序是一个独立应用的话,为了能够同步的加载地图画布(canvas),需要首先实例化QgsLayerTreeMapCanvasBridge对象,代码如下:

bridge = QgsLayerTreeMapCanvasBridge( \
     QgsProject.instance().layerTreeRoot(), canvas)
# Now you can safely load your project and see it in the canvas
project.read(QFileInfo('/home/user/projects/my_other_qgis_project.qgs'))
python Leave a comment

QGIS python开发手册

QGIS python开发手册

原文地址:http://docs.qgis.org/testing/en/docs/pyqgisdevelopercookbook/intro.html

QGIS是一个用户界面友好的桌面地理信息系统,可运行在Linux、Unix、Mac OSX和Windows等平台之上。QGIS是基于Qt,使用C++开发的一个用户界面友好、跨平台的开源版桌面地理信息系统。
QGIS项目开始于2002年 5月,是基于跨平台的图形工具Qt软件包,采用C++ 语言开发的一个GIS软件。目前的开发非常活跃,当前(2014年)的最新版本是QGIS 2.10 版。QGIS源码采用 GNU General Public License协议对外发布。
QGIS的官方网址为http://www.qgis.org/
从0.9版本开始QGIS就支持Python进行开发,称之为PyQGIS。PyQGIS依赖于SIP和PyQt4.

在QGIS中使用Python

启动QGIS时运行Python代码

有两种方式:设置PYQGIS_STARTUP环境变量和使用startup.py文件

设置PYQGIS_STARTUP环境变量

可以通过设置环境变量PYQGISSTARTUP来达到在QGIS初始化完成前执行python代码的目的。将PYQGISSTARTUP设置为用户想执行的python文件即可。
这种方法一般情况下很少用到,但这是在QGIS初始化完成之前执行python代码的方法之一。这个方法在清理系统路径(sys.path)的时候非常有用,系统路径里面有时候含有一些无效的路径。还有就是一些python模块需要单独初始化的情况使用。

使用startup.py文件

每次QGIS启动的时候,都会在用户的Python home目录(一般为.qgis2/python目录)下面查找startup.py文件,如果存在,则执行。

Python控制台

在QGIS中,可以通过Python控制台来执行Python代码。在Plugins 菜单下选择 Python Console,打开Python控制台,如图1:

图中的代码用来获取当前选中的图层,并显示其ID,如果该图层是矢量图层,则显示图层包含的要素个数。
在QGIS的执行环境中默认有一个iface变量,该变量是QgsInterface类型的实例。使用这个变量可以访问地图的canvas,菜单,工具条以及其他模块。
为了方便用户,在Python控制台启动的时候会自动加载相关模块,代码如下:

from qgis.core import *
import qgis.utils

如果用户经常使用Python控制台,可以通过Settings 菜单下的Configure shortcuts工具设置快捷键,方便快速启动。

Python插件

QGIS支持以插件的方式增强其功能,在支持Python之前,只能通过C++来实现。支持Python后,可以通过Python来实现插件。相对于c++实现的插件,Python实现的插件开发更简单并且更容易分发。目前,已经有非常多的Python插件可以下载。用户可以通过Plugins菜单下的manage and install plugins工具来获取、安装、卸载插件。

Python应用程序

在数据处理的时候,经常需要使用脚本的方式来自动化的批量处理。使用PyQGIS,可以很容易的实现。导入qgis.core模块并初始化,用户就可以使用了。
如果用户想创建一个可交互的应用程序,例如实现测量数据、将地图导出到PDF中等功能,则使用 qgis.gui模块即可。 qgis.gui模块提供了很多GUI组件供用户使用。地图组件可以很容易到集成用户的应用程序中。

在自定义应用程序中使用pyQGIS

首先,导入QGIS模块,然后设置QGIS路径。如果用户在调用setPrefixPath的时候将第二个参数设置为True,QGIS会将该目录下的所有目录都加入到路径中。最后调用initQgis()方法,让QIGS查找所有有效的数据源。代码如下:

from qgis.core import *

#supply path to where is your qgis installed
QgsApplication.setPrefixPath("/path/to/qgis/installation", True)

# load providers
QgsApplication.initQgis()

初始化之后,用户就可以使用QGIS API来工作了,例如加载图层,处理数据,空间分析等。
当用户需要结束应用程序的时候,需要调用exitQgis() 方法,确保所有的资源被清除。代码如下:

QgsApplication.exitQgis()

运行自定义程序

为了确保应用程序能够正确执行,用户需要指定环境变量来告诉应用程序在何处找到QGIS类库和python模块,如果没有设置或者设置错误,则程序不能够正确运行,如下面代码:

>>> import qgis.core
ImportError: No module named qgis.core

上面的错误可以通过设置环境变量PYTHONPATH来解决,在下面命令中,qgispath请用QGIS的安装路径代替:

*    linux:export PYTHONPATH=/qgispath/share/qgis/python     
*    windows:set PYTHONPATH=c:\qgispath\python
*    OSX: export PYTHONPATH=/Applications/QGIS.app/Contents/Resources/python/

PYTHON的环境变量设置好之后,还需要设置qgiscore 和 qgisgui的引用目录。

*    linux:export LD_LIBRARY_PATH=/qgispath/lib    
*    windows:set PATH=C:\qgispath;%PATH%
*    OSX: export DYLD_LIBRARY_PATH=/Applications/QGIS.app/Contents/MacOS/lib/:/Applications/QGIS.app/Contents/Frameworks/

上面这些命令可以放到一个启动脚本中,系统启动的时候自动加载。

自定义程序部署

用户自定义的程序不输有两种方式:
1 用户分别单独安装QGIS和自定义程序,这种方式好处是安装包比较小,但需要用户配置路径。
2 将QGIS和自定义程序打包在一起发布,这种方式程序安装包比较大,但用户不用配置路径,打开即可使用。

python Leave a comment

熊本中文离线地图App上线

下载地址:https://itunes.apple.com/us/app/xiong-ben-zhong-wen-li-xian/id1013594007?ls=1&mt=8

熊本中文离线地图是一款支持中文地名和酒店标注的地图。所有数据全部打包在应用中,在离线环境在完全可用,是去熊本旅游的必备工具。
主要特征包括:
1 地图数据完全离线
2 酒店全部中文标注,并提供酒店详细描述
3 景点、购物、美食、活动等重要地点中文标注
4 支持酒店查询,快速在地图上定位
5 支持景点、购物、美食、活动等信息在地图上的展示,并提供列表视图快速浏览
系统截图:


App Leave a comment

小松中文离线地图App上线

下载地址:https://itunes.apple.com/us/app/xiao-song-zhong-wen-li-xian/id1013594003?ls=1&mt=8

小松中文离线地图是一款支持中文地名和酒店标注的地图。所有数据全部打包在应用中,在离线环境在完全可用,是去小松旅游的必备工具。
主要特征包括:
1 地图数据完全离线
2 酒店全部中文标注,并提供酒店详细描述
3 景点、购物、美食、活动等重要地点中文标注
4 支持酒店查询,快速在地图上定位
5 支持景点、购物、美食、活动等信息在地图上的展示,并提供列表视图快速浏览
系统截图:


App Leave a comment

高知中文离线地图App上线

下载地址:https://itunes.apple.com/us/app/gao-zhi-zhong-wen-de-tu/id1013550342?ls=1&mt=8

高知中文离线地图是一款支持中文地名和酒店标注的地图。所有数据全部打包在应用中,在离线环境在完全可用,是去高知旅游的必备工具。
主要特征包括:
1 地图数据完全离线
2 酒店全部中文标注,并提供酒店详细描述
3 景点、购物、美食、活动等重要地点中文标注
4 支持酒店查询,快速在地图上定位
5 支持景点、购物、美食、活动等信息在地图上的展示,并提供列表视图快速浏览
系统截图:


App Leave a comment