ArcGIS Server Flex API调用GP服务的一般步骤 1、说明 ArcGIS Geoprocessing提供了大量地理处理和分析工具,可根据需要对这些工具进行组合构造自己的GIS分析模型,然后发布成GP服务,以方便各种Web客户端调用。Flex API中提供了访问GP服务的接口,通过该接口和GP工具,可实现具有高级GIS分析功能的Web应用。 2、模型创建与测试 创建模型可在modelbuilder可视化环境下进行,也可使用Python脚本定义。模型创建完成需要在ArcMap环境下测试是否正常运行。 详细建模过程请参考ArcGIS的帮助文档。 3、GP服务发布 发布GP服务可使用两种资源类型:GP工具;包含结果图层的MXD文档。其中包含结果图层的MXD文档发布成GP服务时又有两种选择:一种只发布为GP服务;另一种发布成MapService和GP服务。第二种方式可预先在MXD文档中对结果图层渲染,这样可简化客户端的可视化工作。实际项目中选择使用哪一种方式,需要根据具体业务需要确定,不能一概而论。 4、GP服务测试 (1)在ArcMap中加载MapService 注意为方便测试,该MapService不能使用发布GP服务时一同发布出来的MapService。 (2)在ArcToolbox中添加GP服务 将发布的GP服务添加到ArcToolbox中,点击运行,生成的结果会自动添加到当前的地图中。 5、ArcGIS Server Flex API调用GP服务示例 上面几小节简单的介绍了GP工具的制作和GP服务的发布,本小节正式进入正题,讲讲如何使用ArcGIS Server Flex API调用GP服务。 GP服务分同步和异步两种执行模式,Flex API也提供了两种处理方式与之对应。Flex API调用GP服务使用的是Geoprocessor类。该类提供了execute(params)和submitJob(params)两个方法调用后台的GP服务进行数据处理,其中execute(params)对应的是同步执行模式,执行完成触发executeComplete事件。submitJob(params)对应的是异步执行模式,执行完成触发jobComplete事件。对GP服务结果的处理我们可以定义在这些complete事件中。如果GP服务处理过程比较简单而且耗费时间少,我们可以选择同步执行模式,但如果比较耗时,为避免客户端长时间等待,常使用异步执行模式。 为保证Flex API正常调用GP服务,在GP模型定义和GP服务发布过程需要,还需要注意以下几项: (1)在配置MXD文档时,设置临时工作空间 在MXD中添加完GP工具后,如果未设置临时工作空间,则运行GP工具生成的结果将默认保存在C盘下,该路径会导致GP服务无法读取结果图层,可通过设置临时工作空间解决。设置方法:在ArcToolbox上右键选择Environment,设置scratchworkspace的路径即可。 (2)GP工具输出路径的处理 为方便访问输出图层,一般情况下使用环境变量来指定输出路径,即使用scratchworkspace变量,该变量指向ArcGIS Server的arcgisjobs目录。例如:%scratchworkspace%\idwraster。 (3)输出图层中文字符处理 如果GP工具中输出的图层名包含中文,需要更改为英文名称,否则添加到地图上的结果图层无法正常显示。 本示例以生成等值面为例,数据使用ArcGIS自带的World地图,软件环境使用ArcGIS Server9.3.1,ArcGIS for Flex API 1.3版本。示例代码如下: (1)发布服务 将包含GP工具的MXD文档发布成同名的地图服务和GP服务。 (2)Flex调用GP服务 |