无法隐式转换类型';Plantool.xRoute.LineString[]';到';Plantool
本文关键字:Plantool xRoute LineString 转换 类型 | 更新日期: 2023-09-27 17:49:15
情况:我有3个网络参考(xMap、xLocation、xRoute(xMap专门用于生成地图。xLocation专门用于定位位置。xRoute专门用于生成路由。
我使用一个简单的GUI来显示地图,并输入起点和终点路线的位置。
这些都是我的错误。
错误1无法隐式转换类型"Plantool.xRoute.LineString[]"到"Plantool.xMap.LineString[]">
错误2的最佳重载方法匹配'Plantool.xMap.XMapWSService.renderMapBoundingBox(Plantools.xMap.BoundingBox,Plantools.xMap.MapParams,Plantools.xMap.ImageInfo,Plantool.xMap.Layer[],bool,Plantool.xMap.CallerContext('有一些无效参数
错误3参数"1":无法从转换"Plantool.xRoute.BoundingBox'到"Plantool.xMap.BoundingBox">
我猜PTV xServer的重复方法/功能等与xMap、xLocate、xRoute是可选模块相同。这可能是一个简单的答案,有解决方案吗?
我正在寻找一个回家的长途旅行的头脑,并在这个代码上额外花了半个小时的时间。嗨,我是新来的。
低于他的我的班级。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Plantool.xMap;
using Plantool.xLocate;
using Plantool.xRoute;
namespace Plantool
{
class ClassMap
{
/*
* xServer clients
*/
private static XMapWSService xMapClient = new XMapWSService();
private static XRouteWSService xRouteClient = new XRouteWSService();
private static XLocateWSService xLocateClient = new XLocateWSService();
/* getLocation()
* Input: Address string
* Output: WKT (Well-Known-Text) Location
* Edited 20/12/12 - Davide Nguyen
*/
public string getLocation(string input)
{
// create the adress object
string[] address = input.Split(',');
Address addr = new Address();
addr.country = address[0];
addr.city = address[1];
addr.postCode = address[2];
// call findAddress on the xLocate server
// only the first argument of findAddress is mandatory,
// all others are nullable (see xLocate API documentation)
AddressResponse response = xLocateClient.findAddress(addr, null, null, null, null);
string result = "";
foreach (ResultAddress ra in response.wrappedResultList)
{
result += String.Format("POINT( {0} {1}) ", ra.coordinates.point.x, ra.coordinates.point.y);
}
string result2 = result.Replace(",", ".");
return result2;
}
/* route()
* Input: Start address, Destination address
* Output: string[] [0] DISTANCE [1] TIME [2] MAP
* Edited 20/12/12 - Davide Nguyen
*/
public string[] route(string startlocation, string destination)
{
#region WaypointDesc[]
// create the WayPoint for the Start
// ATTENTION: Here at the object WaypointDesc the parameters are not named
// "coords" as described within the documentation but
// "wrappedCoords"
WaypointDesc wpdStart = new WaypointDesc();
// please note that this has to be an array of Point...
wpdStart.wrappedCoords = new xRoute.Point[] { new xRoute.Point() };
wpdStart.wrappedCoords[0].wkt = getLocation(startlocation);
// Waypoint for the Destination...
WaypointDesc wpdDestination = new WaypointDesc();
wpdDestination.wrappedCoords = new xRoute.Point[] { new xRoute.Point() };
wpdDestination.wrappedCoords[0].wkt = getLocation(destination);
// create a new array of WayPointDescriptions and fill it with Start and Destination
WaypointDesc[] waypointDesc = new WaypointDesc[] { wpdStart, wpdDestination };
#endregion
try
{
// Route
Route route = calculateRoute(waypointDesc);
// Map
string DisplayMapURL = createMap(waypointDesc, route);
// get route info
string[] routeinfo = getRouteInfo(waypointDesc);
// Create the result
string[] result = new string[3];
result[0] = routeinfo[0]; // Distance
result[1] = routeinfo[1]; // Time
result[2] = DisplayMapURL;// Map URL
// Return the result
return result;
}
catch
{
throw new NotImplementedException();
}
}
/* getRouteInfo()
* Input: WaypointDesc[]
* Output: string mapURL
* Edited 20/12/12 - Davide Nguyen
*/
private static string createMap(WaypointDesc[] waypointDesc, Route route)
{
#region boundingBox
// Set boundingBox fand use corners from the calculated route
xRoute.BoundingBox boundingBox = new xRoute.BoundingBox();
boundingBox.leftTop = route.totalRectangle.rightTop;
boundingBox.rightBottom = route.totalRectangle.leftBottom;
#endregion
#region mapParams
// Build mapParams
MapParams mapParams = new MapParams();
mapParams.showScale = true;
mapParams.useMiles = false;
#endregion
#region imageInfo
// Create imageInfo and set the frame size and image format. NOTE: 1052; 863
ImageInfo imageInfo = new ImageInfo();
imageInfo.format = ImageFileFormat.PNG;
imageInfo.height = 1052;
imageInfo.width = 863;
imageInfo.imageParameter = "";
#endregion
#region layers
// Create a line from the calculated route
xRoute.LineString[] lineStrings = new xRoute.LineString[] { route.polygon };
Lines[] lines = new Lines[1];
LineOptions options = new LineOptions();
LinePartOptions partoptions = new LinePartOptions();
partoptions.color = new Color();
partoptions.visible = true;
partoptions.width = -10;
options.mainLine = partoptions;
lines[0] = new Lines();
lines[0].wrappedLines = lineStrings; //NEED HELP
lines[0].options = options;
// Define customLayer that contains the object lines and set layers.
CustomLayer customLayer = new CustomLayer();
customLayer.visible = true;
customLayer.drawPriority = 100;
customLayer.wrappedLines = lines;
customLayer.objectInfos = ObjectInfoType.NONE;
customLayer.centerObjects = true;
Layer[] layers = new Layer[] { customLayer };
#endregion
#region includeImageInResponse
// Set argument includeImageInResponse to false (default).
Boolean includeImageInResponse = false;
#endregion
// Return object map using the following method.
Map map = xMapClient.renderMapBoundingBox(boundingBox, mapParams, imageInfo, layers, includeImageInResponse, null); // NEED HELP
// Retrieve the image
string result = "http://" + map.image.url;
// Return the drawn map
return result;
}
/* getRouteInfo()
* Input: WaypointDesc[]
* Output: string[] [0] Distance in M [1] Time in H:M:S:MS
* Edited 20/12/12 - Davide Nguyen
*/
private string[] getRouteInfo(WaypointDesc[] waypointDesc)
{
// Call the service
RouteInfo routeInfo = xRouteClient.calculateRouteInfo(waypointDesc, null, null, null);
// Create the result
TimeSpan t = TimeSpan.FromSeconds(routeInfo.time);
string[] result = new string[2];
result[0] = string.Format("{0} KM", routeInfo.distance);
result[1] = string.Format("{0:D2}h:{1:D2}m:{2:D2}s:{3:D3}ms", t.Hours, t.Minutes, t.Seconds, t.Milliseconds);
// Return the result
return result;
}
/* getRouteLines()
* Input: WaypointDesc[]
* Output: Route object
* Edited 20/12/12 - Davide Nguyen
*/
private static Route calculateRoute(WaypointDesc[] waypointDesc)
{
#region ResultListOptions
// Instantiate a new object resultListOPtions
ResultListOptions resultListOptions = new ResultListOptions();
resultListOptions.polygon = true;
resultListOptions.totalRectangle = true;
resultListOptions.detailLevel = DetailLevel.STANDARD;
#endregion
#region CallerContext/CallerContextPropery
// Create a new CallerContextProperty object property
xRoute.CallerContextProperty property = new xRoute.CallerContextProperty();
property.key = "ResponseGeometry";
property.value = "WKT";
xRoute.CallerContext callerContext = new xRoute.CallerContext();
callerContext.wrappedProperties = new xRoute.CallerContextProperty[] { property };
#endregion
// Call the service
Route route = xRouteClient.calculateRoute(waypointDesc, null, null, resultListOptions, callerContext);
return route;
}
}
}
这两者之间似乎存在一些引用混淆。
using Plantool.xMap;
using Plantool.xRoute;
你可以删除这些:
using Plantool.xMap;
using Plantool.xLocate;
using Plantool.xRoute;
再加上这个:
using Plantool;
然后显式引用正确的类型,确保引用的是所需的类型。这将解决所有三条错误消息。
理想情况下,应该避免在只有命名空间不同的情况下发生名称冲突。在.NET框架中,您会注意到他们会小心避免这种情况,例如。。。
System.Data.Odbc.OdbcConnection
System.Data.SqlClient.SqlConnection
它们都可以被称为Connection
,假设一个在Odbc
命名空间中,另一个在SqlClient
命名空间中,但这可能会导致问题。
通过将LineString
重命名为RouteLineString
和MapLineString
,可以避免应用程序中的混乱。
根据我对xServer的记忆,这是一个主要问题:xMap、xRoute和xLocate中的常见类型不相同(就像您所说的,因为它们是可选模块(。xMap.LineString
实际上是与xRoute.LineString
不同的类型,即使它们具有相同的属性。你对此无能为力,除了:
- 如果两个类型共享一个公共的基类型或接口,请改用此公共类型
- 编写从
xRoute.LineString
映射到xLocate.LineString
的扩展方法。。。等等
例如:
public static xLocate.LineString ToXLocateLineString(this xRoute.LineString lineString)
{
return new xLocate.LineString
{
// Map type by copying properties
....
};
}
所以你可以写
xRoute.LineString[] input = ....
xMap.LineString[] output = input.Select(z => z.ToXLocateLineString()).ToArray();
甚至
public static xLocate.LineString[] ToXLocateLineStringArray(this xRoute.LineString[] lineString)
{
return lineString.Select(z => z.ToXLocateLineString()).ToArray();
}
然后
xMap.LineString[] output = input.ToXLocateLineStringArray();
也许他们改进了他们的API,因为我最后一次使用它,对此不确定。
干杯,在我看来,通过适当创建客户端类可以解决冗余问题。您可以使用Visual Studio的WSDL.EXE在一个步骤中合并WSDL,而不是一个接一个地添加三个WSDL(通过Visual Studio Wizards(。这适用于PTV xServer 1(在本线程中引用(,甚至更好地适用于xServer2我通常做的是CMD语句,如
WSDL/名称空间:";XServer"/sharetypes/out:";XServer.cs"https://xserver2-europe-eu-test.cloud.ptvgroup.com/services/ws/XLocate?wsdl"quot;https://xserver2-europe-eu-test.cloud.ptvgroup.com/services/ws/XRoute?wsdl"quot;https://xserver2-europe-eu-test.cloud.ptvgroup.com/services/ws/XTour?wsdl">
将此视为一般性建议。如今,映射接口完全不同。