文章目录
- 0.引言
- 1.ArcGIS创建GP服务
- [2.ArcGIS Server发布GP服务](#2.ArcGIS Server发布GP服务)
- [3.ArcgisForJS使用ArcGIS Server发布的GP服务](#3.ArcgisForJS使用ArcGIS Server发布的GP服务)
0.引言
ArcGIS for JavaScript(或简称AGJS)是一个强大的工具,它允许开发者使用JavaScript在Web浏览器中创建和运行ArcGIS应用程序。ArcGIS Server是一个强大的服务器产品,它提供了许多服务,包括地理处理服务(GP服务)。GP服务是一种服务,它允许开发者在ArcGIS Server上运行各种地理处理任务等。ArcGIS for JS可以使用ArcGIS Server发布的GP服务来执行各种地理处理任务。
1.ArcGIS创建GP服务
(1)创建mxd地图文档,命名为bufferGP。
data:image/s3,"s3://crabby-images/b2b32/b2b321d31d964e7bf51f88ba15b245fca694f403" alt=""
(2)创建点要素
data:image/s3,"s3://crabby-images/18a9f/18a9f4534e79d948b50064f5089a44c9c065c2db" alt=""
(3)创建模型
data:image/s3,"s3://crabby-images/15f13/15f134f6ee16ef759d23f305866e697f3f422038" alt=""
data:image/s3,"s3://crabby-images/65f55/65f55abda93dd0433b4dd633f9ee6026faa1c120" alt=""
构建点生成缓冲区的模型。
data:image/s3,"s3://crabby-images/0ff19/0ff190fa7496f4befc85ef56188a1edf3d10bd7e" alt=""
设置heatPoints。
data:image/s3,"s3://crabby-images/8c16c/8c16c387b8cf07ae272ee0737f158ff95cd9882a" alt=""
data:image/s3,"s3://crabby-images/0e3df/0e3df7e16c36ac64802c407490e111cb3424a404" alt=""
设置距离[值或字段]。
data:image/s3,"s3://crabby-images/292a8/292a8b3d8e9e4040e1be291e1fa13ef5219ac312" alt=""
设置各组件显示模型参数。
data:image/s3,"s3://crabby-images/f85aa/f85aa24055adecffb5303e5b261a5d3eca76e878" alt=""
data:image/s3,"s3://crabby-images/5f1ba/5f1ba4e23665c78ad3ad34ff0ec8df3b1d49b91e" alt=""
同理设置其他组件的模型参数。
data:image/s3,"s3://crabby-images/7f753/7f753c859a4b971324c56406db0f8d21503f3031" alt=""
重命名各组件。
data:image/s3,"s3://crabby-images/ed89a/ed89acdba0f3536d97d8af2480d865adf3a00f71" alt=""
运行成功并退出。
2.ArcGIS Server发布GP服务
打开模型,执行一次模型。
data:image/s3,"s3://crabby-images/d1bbd/d1bbd180d0f94bc817d5f093c14f53413de46bc6" alt=""
打开结果查看会话。
data:image/s3,"s3://crabby-images/b8d61/b8d61c2ba4d0e75ce99253c5f6e76ef0cd75c1d3" alt=""
发布地理处理服务。
data:image/s3,"s3://crabby-images/d2e0e/d2e0e89ccc7fd91768f5d302a01d3e404a596cc9" alt=""
data:image/s3,"s3://crabby-images/89298/89298f5618d72ba8965ef2226e106394f51a845a" alt=""
data:image/s3,"s3://crabby-images/ec146/ec14618834c59963c6cf0562e1c9a92a608a317d" alt=""
data:image/s3,"s3://crabby-images/cfaf0/cfaf00b278a435989ff9ddeae912dc611d536184" alt=""
data:image/s3,"s3://crabby-images/fcc2a/fcc2a36c2c1e1a60690f004ff56af092db0a0587" alt=""
data:image/s3,"s3://crabby-images/28af3/28af38826e05365d6c38cfaa33c0b5f94098b555" alt=""
data:image/s3,"s3://crabby-images/0f853/0f8536cb2a91b15fa4e2b9a9f9a6067e44d176be" alt=""
在ArcGIS Server查看GP服务。
data:image/s3,"s3://crabby-images/0a76f/0a76f7ae38d6bd174586f00d6e8d703681d22683" alt=""
data:image/s3,"s3://crabby-images/23793/23793813060f703a3ce2863d8162e7ec788cd06a" alt=""
data:image/s3,"s3://crabby-images/396e1/396e130310123373b1d8042d7c62b77f179ae275" alt=""
data:image/s3,"s3://crabby-images/03f25/03f25e6cae4e17befb4b7b368317bb058a19ff8d" alt=""
地理处理服务地址:http://localhost:6080/arcgis/rest/services/gp/bufferService1/GPServer/bufferGPModel
3.ArcgisForJS使用ArcGIS Server发布的GP服务
(1)实现代码
csharp
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>GP服务</title>
<link rel="stylesheet" href="https://js.arcgis.com/4.28/esri/themes/light/main.css" />
<script src="https://js.arcgis.com/4.28/"></script>
<style type="text/css">
.MapClass {
width: 100%;
height: 600px;
border: 1px solid #000;
}
</style>
<script type="text/javascript" charset="utf-8">
require(["esri/Map",
"esri/views/MapView",
"esri/rest/geoprocessor",
"esri/rest/support/FeatureSet",
"esri/Graphic",
"esri/layers/GraphicsLayer",
"esri/rest/support/LinearUnit"
], (Map,
MapView,
geoprocessor,
FeatureSet,
Graphic,
GraphicsLayer,
LinearUnit) => {
var MyMap = new Map({
basemap: "gray-vector",
});
var inputGraphicContainer = [];
var graphicsLayer = new GraphicsLayer();
MyMap.add(graphicsLayer);
var view = new MapView({
container: "MyMapDiv",
center: [106.49446091380375, 29.559187456407138],
zoom: 10,
map: MyMap
});
const markerSymbol = {
type: "simple-marker",
color: [255, 0, 0],
outline: {
color: [255, 255, 255],
width: 2
}
};
const fillSymbol = {
type: "simple-fill",
color: [226, 119, 40, 0.75],
outline: {
color: [255, 255, 255],
width: 1
}
};
//点击绘点
view.on("click", createGraphic);
function createGraphic(event) {
const point = {
type: "point",
longitude: event.mapPoint.longitude,
latitude: event.mapPoint.latitude
};
const inputGraphic = new Graphic({
geometry: point,
symbol: markerSymbol
});
graphicsLayer.add(inputGraphic);
inputGraphicContainer.push(inputGraphic);
}
//清除点
document.getElementById("Btn").onclick = () => {
view.graphics.removeAll();
graphicsLayer.removeAll();
inputGraphicContainer = [];
};
//调用GP服务生成缓冲区
document.getElementById("buffer").onclick = () => {
const gpUrl="http://localhost:6080/arcgis/rest/services/gp/bufferService1/GPServer/bufferGPModel";
const featureSet = new FeatureSet();
featureSet.features = inputGraphicContainer;
const dis = new LinearUnit({
"distance": 5,
"units": "miles"
});
const params = {
input: featureSet,
dis: dis
};
const options = {
outSpatialReference: {
wkid: 102100
}
};
geoprocessor.execute(gpUrl, params, options).then(drawResultData);
}
function drawResultData(result) {
const resultFeatures = result.results[0].value.features;
const bufferGraphics = resultFeatures.map((feature) => {
feature.symbol = fillSymbol;
return feature;
});
graphicsLayer.addMany(bufferGraphics);
view.goTo({
target: bufferGraphics,
tilt: 0
}).catch((error) => {
if (error.name != "AbortError") {
console.error(error);
}
});
}
});
</script>
</head>
<body>
<div id="MyMapDiv" class="MapClass" style="width:900px;height:600px;"></div>
<input id="Btn" type="button" value="清除" />
<input id="buffer" type="button" value="缓冲区分析" />
</body>
</html>
(2)实现结果
data:image/s3,"s3://crabby-images/a6f1e/a6f1e3bf87f3f7d0abcfb4b32984b19120d251d4" alt=""
data:image/s3,"s3://crabby-images/ed920/ed920233f4d0e91ce56e735f1b64406336909fc0" alt=""
参考资料:
[1] 一入GIS深似海. 不一样的前端,JavaScript之arcgis api教程; 2020-11-02 [accessed 2024-02-25].
[2] 码农阿焦. ArcGIS API For JavaScript使用自定义GP服务; 2019-03-14 [accessed 2024-02-25].
[3] gis_morningsun. Arcgis javascript那些事儿(十六)------GP服务的发布与使用; 2017-08-10 [accessed 2024-02-25].
[4] 爱睡懒觉的老舅. 07-ArcGIS API For JavaScript之调用GP服务; 2019-11-26 [accessed 2024-02-25].
[5] No8g攻城狮. 【前端用法】jQuery在线引用地址(全); 2023-12-16 [accessed 2024-02-25].
[6] lqdcanty. jquery中click点击事件嵌套后多次触发的解决方案; 2017-06-01 [accessed 2024-02-25].
[7] 小苗吃不够 . jQuery绑定点击事件和改变事件的几种方式以及多个元素绑定多个事件; 2022-09-05 [accessed 2024-02-25].
[8] 孙霸天. GP服务的使用详解; 2022-01-28 [accessed 2024-02-25].
[9] 不断学习的GISer. arcgis js 4.x 调用gp栅格计算将结果渲染后叠加到天地图; 2021-11-11 [accessed 2024-02-25].
[10] 数据库及DotNet开发. 图解ArcGIS Server之发布GP服务-返回矢量数据; 2016-12-14 [accessed 2024-02-25].
[11] zhoutaotao0509. 基于ArcGIS API For JavaScript调用GP服务实现动态插值分析实现; 2016-08-28 [accessed 2024-02-25].
[12] HPhone. 使用ArcGIS GP服务之五 JavaScript的调用; 2012-11-18 [accessed 2024-02-25].