本文版权归小能所有,转载麻烦标明出处,谢谢! 同时写作过程中也参阅了大量其他网络文档,如果您觉得侵犯版权,请和我联系:
chinazhousheng@gmail.com
网络分析之最短路径查询系列:
昨天参照ArcGIS Server
开发文档进行改造,
原开发文档是依据地址定位服务来进行定位后再来做最佳路径分析,
我本次开发是舍弃locator
服务,
直接在页面中输入起始地址以及目的地名称,
如图1
所示,
后台网络分析后,
将结果显示在客户端页面中,
其最终效果如图2
所示.
非常感谢网友Alex Xu
给的大量帮助!
![](https://images.cnblogs.com/cnblogs_com/chinazhousheng/a2.JPG)
图1 图2
前提条件:发布一个NAServer,如果不会操作,可以参考开发文档中的NAServer路径开发的例子,里面有操作说明,不过是E文的.如果你连地图发布都还不会的话,建议看一下帮助文档.呵 呵 .
废话少说,说一下关键代码
第一步:开启NAServer并对其中的一些参数进行设置,呵呵,当然这些都是在最短路径按钮的onclick事件中
using
(NAServerProxy naServer
=
NAServerProxy.Create(SERVER_NAME, ROUTE_SERVICE_NAME,
null
))
![](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
{
if (naServer == null)
throw (new System.Exception("Could not find the web service."))
// Get the NAServerSolverParams
string[] naLayers = naServer.GetNALayerNames(esriNAServerLayerType.esriNAServerRouteLayer);
NAServerSolverParams solverParams = naServer.GetSolverParameters(naLayers[0]) as NAServerSolverParams;
// Set the NAServerRouteParams
NAServerRouteParams routeParams = solverParams as NAServerRouteParams;
routeParams.ReturnMap = false;
routeParams.ReturnRouteGeometries = true;
routeParams.ReturnStops = true;
routeParams.ReturnDirections = false;
}
第二步:好的,下面将对输入的地址进行查找,输入的地址分别在Start_Txt和End_Txt文本框中.(为了节约篇幅,定点查找,我在这里就不提了,需要DEMO的朋友http://www.cnblogs.com/chinazhousheng/archive/2008/05/20/1203192.html);查找到点以后,返回值类型为PointN类型.
第三步:地址定位,在此这前,我首先提一下PropertySet,这是类似于数组的类型,但其内部可以嵌套数组,所以我们要做的就是将一些相关的信息,比如第二步查找到的两个地址位置存入到PropertySet中去.下面是代码
private
PropertySet GeocodeAddress(
string
streetAddress)
![](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
{
//寻找地理位置,这是第二步完成的…….
PointN addr_point = Query_Point_Txt(streetAddress);
//新建propertyset及PropertySetProperty数组
PropertySet propSet = new PropertySet();
PropertySetProperty[] propSetProperty_new = new PropertySetProperty[2];
propSet.PropertyArray = propSetProperty_new;
//设置propSet结构
propSet.PropertyArray[0] = CreatePropertySetProperty("Shape", addr_point) as PropertySetProperty;
propSet.PropertyArray[1] = CreatePropertySetProperty("Name", streetAddress) as PropertySetProperty;
return propSet;
}
第四步:返回PropertySet后就好办了,我们将其赋值到NAServerPropertySets中去.重点关注一下NAServerSolverParams参数, solverParams,所有我们查找的地理位置最终会全部交给他,由他来给NAServer去处理.
PropertySet[] propSets
=
new
PropertySet[
2
];
propSets[
0
]
=
GeocodeAddress(start_txt);
propSets[
1
]
=
GeocodeAddress(end_txt);
NAServerPropertySets StopsPropSets
=
new
NAServerPropertySets();
StopsPropSets.PropertySets
=
propSets;
![](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
/**/
/// solverParams为第一步传入的NAServerSolverParams参数.
NAServerRouteParams routeParams
=
solverParams
as
NAServerRouteParams;
routeParams.Stops
=
StopsPropSets;
第五步,最佳路径生成,其结果保存在NAServerSolverResults中,其最佳路径类型为PolylineN
NAServerSolverResults solverResults;
solverResults
=
naServer.Solve(solverParams);
第六步:显示在客户端的浏览器中.这一步基本上代码就按照开发文档中的来的了,我也没有研究太多,也很容易吧,大家看一下就基本上差不多了,我也把代码贴出来
Code
public void OutputResults(NAServerSolverResults solverResults)
![](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
{
string messagesSolverResults = "";
NAServerRouteResults RouteSolverResults = solverResults as NAServerRouteResults;
// Add graphics from route and stops
GraphicElement[] graphicElements = new GraphicElement[RouteSolverResults.RouteGeometries.Length + RouteSolverResults.Stops.Records.Length];
AddRoutesToGraphicElements(RouteSolverResults.RouteGeometries, graphicElements);
AddStopsToGraphicElements(RouteSolverResults.Stops, graphicElements);
//注意下面这个应该改成你要取的地图服务所在的位置,一般为Map.GetFunctionality(0);
ESRI.ArcGIS.ADF.Web.DataSources.ArcGISServer.MapFunctionality mapFunctionality = (ESRI.ArcGIS.ADF.Web.DataSources.ArcGISServer.MapFunctionality)CsMap.GetFunctionality(2);
mapFunctionality.MapDescription.CustomGraphics = graphicElements;
// Zoom to extent
PolylineN polylineN = RouteSolverResults.RouteGeometries[0] as PolylineN;
EnvelopeN envelopeN = polylineN.Extent as EnvelopeN;
double width = envelopeN.XMax - envelopeN.XMin;
double height = envelopeN.YMax - envelopeN.YMin;
double fivePercent;
if (width > height)
fivePercent = width * .05;
else
fivePercent = height * .05;
envelopeN.XMin = envelopeN.XMin - fivePercent;
envelopeN.YMin = envelopeN.YMin - fivePercent;
envelopeN.XMax = envelopeN.XMax + fivePercent;
envelopeN.YMax = envelopeN.YMax + fivePercent;
CsMap.Extent = ESRI.ArcGIS.ADF.Web.DataSources.ArcGISServer.Converter.ToAdfEnvelope(envelopeN);
CsMap.Refresh();
}
// Add all stops as black circles
private void AddStopsToGraphicElements(ESRI.ArcGIS.ADF.ArcGISServer.RecordSet stops, GraphicElement[] graphicElements)
![](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
{
Record[] stopRecords = stops.Records;
int stopCount = stopRecords.Length;
RgbColor rgb = new RgbColor();
rgb.Red = 0;
rgb.Green = 0;
rgb.Blue = 0;
rgb.AlphaValue = 255;
SimpleMarkerSymbol sms = new SimpleMarkerSymbol();
sms.Color = rgb;
sms.Style = esriSimpleMarkerStyle.esriSMSCircle;
sms.Size = 16;
int iGraphicElement = graphicElements.Length - stopCount;
for (int iStop = 0; iStop < stopCount; iGraphicElement++, iStop++)
![](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
ESRI.ArcGIS.ADF.ArcGISServer.MarkerElement me = new ESRI.ArcGIS.ADF.ArcGISServer.MarkerElement();
me.Point = stopRecords[iStop].Values[1] as PointN;
me.Symbol = sms;
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
graphicElements[iGraphicElement] = me;
}
}
// Add routes as blue lines
private void AddRoutesToGraphicElements(ESRI.ArcGIS.ADF.ArcGISServer.Polyline[] polylines, GraphicElement[] graphicElements)
![](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
{
RgbColor rgb = new RgbColor();
rgb.Red = 0;
rgb.Green = 0;
rgb.Blue = 255;
rgb.AlphaValue = 32;
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
SimpleLineSymbol sls = new SimpleLineSymbol();
sls.Color = rgb;
sls.Style = esriSimpleLineStyle.esriSLSSolid;
sls.Width = 6;
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
for (int i = 0; i < polylines.Length; i++)
![](https://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
ESRI.ArcGIS.ADF.ArcGISServer.LineElement le = new ESRI.ArcGIS.ADF.ArcGISServer.LineElement();
le.Line = polylines[i];
le.Symbol = sls;
![](https://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
graphicElements[i] = le;
}
}