【10.2移动新特性】揭秘ArcGIS 10.2移动产品的离线功能【下:服务模式】
2014-02-12 11:33
393 查看
ArcGIS 10.2中的离线模式
ArcGIS 10.2提供了两种离线模式,分别称为“服务模式”和“桌面模式”。1、服务模式
即数据被发布成要素服务,用户可从服务器上下载部分或全部的数据并保存为一个Runtime Geodatabase,用来进行离线应用;该模式适合大量用户同时工作的场景。
2、桌面模式
Esri在ArcGIS 10.2.1的桌面产品中提供了专门的工具来制作Runtime Geodatabase,内容可以是要素、表格数据、切片缓存、网络数据集,用来实现离线的数据、离线的地理编码和离线的路径分析等功能。桌面模式适合单用户场景,创建的离线数据目前为只读型,可用来进行展示和查询。
服务模式
服务模式中,需要先将数据发布成要素服务。发布要素服务的方法和步骤与ArcGIS 10.1一致,不过要想通过服务进行数据的下载和同步等操作,服务需要提供一些能力,并且数据也需要相关的设置。服务配置
2、Feature Service要具备同步的能力
数据需求
在数据集上启用归档包括Global IDs的数据集
关系类和附件必须使用一个全局ID主键(如果有附件的话)
数据下载
服务发布好之后,就可以使用ArcGISRuntime SDK来下载数据、实现离线功能了。下载关键点如下:通过GeodatabaseTask获取FeatureService服务信息
通过Geodatabase创建本地Geodatabase数据库
数据下载所需的参数类GenerateGeodatabaseParameters
通过GeodatabaseStatusCallback类获取数据下载和创建数据库的相关状态
通过CallbackListener<Geodatabase>回调函数处理下载的数据,我们可以在这里将下载的数据显示到地图上。
下载的数据都以FeatureTable表的形势存储在本地数据库中。
Android API示例
以ArcGIS for AndroidAPI为例,采用服务模式,使用API中暴露的GeodatabaseTask类来下载数据生成Geodatabase;重载的GeodatabaseTask类的构造函数有一个CallbackLister监听,该监听是一个后台任务,用来从服务上下载数据并存储在移动端本地的geodatabase中,示例代码如下:/** * Create the GeodatabaseTask from the feature service URL w/o credentials. */ private void downloadData(String url) { Log.i(TAG, "Create GeoDatabase"); // create a dialog to update user on progress dialog = ProgressDialog.show(mMapView.getContext(), "Download Data", "Create local runtime geodatabase"); dialog.show(); // create the GeodatabaseTask gdbTask = new GeodatabaseTask(url, null, new CallbackListener() { // Handle errors public void onError(Throwable e) {Log.e(TAG, "Error occured creating Geodatabase Task"); dialog.dismiss(); } // Handle success public void onCallback(FeatureServiceInfo objs) { // create the geodatabase createGeodatabase(); } }); } |
上述代码中的downloadData方法的输入参数是要素服务的url,当弹出对话框之后,创建了GeodatabaseTask对象和CallbackListener监听,该监听有以下两个方法:
onError:该方法在创建对象失败时调用,可在此加入日志跟踪等代码;
onCallback:创建对象成功时调用,可将创建本地geodatabase的代码写在其中。如这里我们创建了createGeodatabase方法,用来传递参数,创建离线的geodatabase数据库文件,示例代码如下:
/** * Set up parameters to pass the the submitTask() method. A * CallbackListener is used for the response. */ private static void createGeodatabase() { // set up the parameters to generate a geodatabase GenerateGeodatabaseParameters params = new GenerateGeodatabaseParameters( layerIds, mMapView.getExtent(), mMapView.getSpatialReference(), returnAttachments, syncModel, mMapView.getSpatialReference()); // a callback which fires when the task has completed or failed. CallbackListener gdbResponseCallback = new CallbackListener() { public void onCallback(final Geodatabase gdb) { Log.i(TAG, "Geodatabase is: " + gdb.getPath()); dialog.dismiss(); // update map with local feature layer from geodatabase updateFeatureLayer(gdb.getPath()); } public void onError(Throwable e) { Log.e(TAG, "Error creating geodatabase"); dialog.dismiss(); } }; // a callback which updates when the status of the task changes GeodatabaseStatusCallback statusCallback = new GeodatabaseStatusCallback() { public void statusUpdated(GeodatabaseStatusInfo status) { Log.i(TAG, status.getStatus().toString()); } }; // create the fully qualified path for geodatabase file localGdbFilePath = createGeodatabaseFilePath(); // get geodatabase based on params submitTask(params, localGdbFilePath, statusCallback, gdbResponseCallback); } |
从代码中可以看出,传递的参数主要包括:
geodatabase中包含的图层,即可指定下载哪些图层;
图层的范围,即可指定数据的下载范围;
Geodatabase的空间参考;
是否返回附件;
同步方式,可选择一次同步一个图层,或者同步所有图层;
图层过滤信息等;
使用GenerateGeodatabaseParameters类来传递这些参数,这个类有多个构造函数,用户可以根据需要进行选择。之后,我们创建了CallbackListener监听来处理geodatabase创建成功和失败的情况。另外,还创建了GeodatabaseStatusCallback来检查创建的过程,当geodatabasetask更新的时候,执行statusUpdated方法,有效的更新状态可存储在枚举变量GeodatabaseStatusInfo.Status中,最后将创建的geodatabase的名称和路径返回:
/* *Request database, poll server to get status, and download the file */ private static void submitTask(GenerateGeodatabaseParameters params, String file, GeodatabaseStatusCallback statusCallback, CallbackListener gdbResponseCallback) { // submit task gdbTask.submitGenerateGeodatabaseJobAndDownload(params, file,statusCallback,gdbResponseCallback); } |
GeodatabaseTask.submitGenerateGeodatabaseJobAndDownload()方法在幕后做了很多工作,它向服务器请求当前服务的当前状态,下载数据到指定目录下,并存储在geodatabase中。
可通过示例向导加载“CreateRuntime Geodatabase Android SDK”查看相应源码。
相关文章推荐
- 【10.2移动新特性】揭秘ArcGIS 10.2移动产品的离线功能【上:桌面模式】
- ArcGIS 10.2移动产品的离线功能
- 【2013Esri全球用户大会精彩看点】ArcGIS 10.2移动产品新特性
- 【2013Esri全球用户大会精彩看点】ArcGIS 10.2移动产品新特性
- 【2013Esri全球用户大会精彩看点】ArcGIS 10.2移动产品新特性
- 【ArcGIS 10.2新特性】ArcGIS 10.2将PostgreSQL原生数据发布为要素服务
- 【ArcGIS 10.2新特性】ArcGIS 10.2将PostgreSQL原生数据发布为要素服务
- 【10.2移动新特性】Android 10.2 API简化,同样的功能,更少的代码!
- 10.2.2移动产品离线功能等具体解释----暨4月8日移动《在离线一体化》公开课Q&A
- 【移动产品】ArcGIS Runtime SDK for Android 10.1.1新特性及工程迁移
- 【10.2移动新特性】GraphicsLayer新增动态模式,性能极大提升!
- 10.2.2移动产品离线功能等详解----暨4月8日移动《在离线一体化》公开课Q&A
- 【10.2移动新特性】好用的Application Framework for ArcGIS Android,简化制图和地理编码流程!
- ArcGIS 10.1系列产品 升级安装至 ArcGIS 10.2
- 【ArcGIS 10.2新特性】地理数据(Geodatabase 和database)10.2 新特性
- 【2014 Esri开发者大会精彩看点】ArcGIS for JavaScript API实用功能及未来新特性(上)
- [置顶] ArcGIS 10.2以上GP服务调用
- 移动产品设计之ios导航模式
- 【移动产品】ArcGIS for Windows Phone 2.4发布
- 解决关于ArcGIS10.2服务手动启动的问题