平台:Vs 2010,Blend 4,Silverlight 4
调用API: ArcGis for Silverligth API(ESRI.ArcGIS.Client)
本来准备晚上或下午写的,早上公司服务器挂了,地图服务用不了干脆就来写一点吧!有个朋友问我动态配置 WebService,Wcf服务的问题,正好也把这个一并写了!
好了不说废话了,进下正题。
先来看一下如何动态的配置WebService,Wcf 服务,实现方式:从 Web.Config 文件中读取地址,然后在 Silverlight 实现绑定。
首先我们还是添加服务引用,引用远程或本机的Web服务。然后在 silverlight 加下以下代码
/// <summary>
/// 动态引用WebServices
/// </summary>
/// <returns></returns>
public Service.TyphoonServiceSoapClient GetDynamicClient()
{
BasicHttpBinding binding = new BasicHttpBinding(
Application.Current.Host.Source.Equals("https") ? BasicHttpSecurityMode.Transport : BasicHttpSecurityMode.None);
// 这里可以设置你接收消息的大小,为int最大值
binding.MaxReceivedMessageSize = int.MaxValue;
binding.MaxBufferSize = int.MaxValue;
EndpointAddress client;
if (webServicePath == String.Empty)
{
try
{
ScriptObject myScript = HtmlPage.Window.GetProperty("GetWebServiceUrl") as ScriptObject;
webServicePath = myScript.InvokeSelf("TyphoonSL").ToString();
client = new EndpointAddress(webServicePath);
}
catch
{
client = new EndpointAddress("http://localhost:7629/TyphoonService.asmx");
}
}
else
{
client = new EndpointAddress(webServicePath);
}
return new Service.TyphoonServiceSoapClient(binding, client);
}
注意把 public Service.TyphoonServiceSoapClient GetDynamicClient() 这行改成你自己的服务实例也就是改 Service.TyphoonServiceSoapClient,
同样也要改最后一行的 return new Service.TyphoonServiceSoapClient(binding, client);
大家可能注意到上面的两句话。
ScriptObject myScript = HtmlPage.Window.GetProperty("GetWebServiceUrl") as ScriptObject;
webServicePath = myScript.InvokeSelf("TyphoonSL").ToString();
这里的 HtmlPage.Window.GetProperty("GetWebServiceUrl"),表示外部 JavaScript 方法,也就是承载 Silverlight 页面中的JavaScript函数。
webServicePath是一个全局的string型变量,是用来保存WebService地址。
myScript.InvokeSelf("TyphoonSL").ToString();是表示调用外部JavaScript方法并传一个值"typhoonSL"进去.
好Silverlight程序里大功告成,我们看下承载 Silverlight 页面中的JavaScript函数。
<script type="text/javascript">
//获取WebService地址
function GetWebServiceUrl(args) {
var a = '';
if (args.toString() == 'TyphoonSL') {
a = '<%=GetAppSetting("TyphoonSL")%>';
}
return a;
}
</script>
里面有个托管代码函数GetAppSetting();我们看下他的代码:
/// <summary>
/// 获取配置字串
/// </summary>
/// <param name="key">字段名称</param>
/// <returns>配置字串</returns>
public static string GetAppSetting(string key)
{
try
{
if (key != null)
{
return System.Configuration.ConfigurationSettings.AppSettings[key].ToString();
}
else
{
return String.Empty;
}
}
catch
{
return String.Empty;
}
}
我们看他了他调用了ConfigurationSettings.AppSetting中的key.那再来看下他调用的Web.Config文件中的节点:
<appSettings><add key="TyphoonSL" value="http://localhost:7629/TyphoonService.asmx"/></appSettings>
这样动态的WebService、Wcf调用就完成了!
然后就是动态调用地图,其实和动态调用WebService、Wcf差不多。我简单发下他们的代码:
/// <summary>
/// 添加底图
/// </summary>
private void TiledLayerInit()
{
ArcGISTiledMapServiceLayer tiledLayer = new ArcGISTiledMapServiceLayer();
ArcGISTiledMapServiceLayer imageLayer = new ArcGISTiledMapServiceLayer();
try
{
ScriptObject myScr = HtmlPage.Window.GetProperty("GetSLTiledLayer") as ScriptObject;
string url = myScr.InvokeSelf("TiledLayer").ToString();
tiledLayer.Url = url;
}
catch (Exception ex)
{
MessageBox.Show("请配置 Gis 底图!" + ex.ToString(), "温馨提示", MessageBoxButton.OK);
}
finally
{
// tiledLayer.Url = "http://demo.augow.com/ArcGIS/rest/services/Map001/World/MapServer";
}
imageLayer.Url = "http://services.arcgisonline.com/ArcGIS/rest/services/NGS_Topo_US_2D/MapServer";
tiledLayer.ID = "StreetMapLayer";
imageLayer.ID = "ImageMapLayer";
myMap.Layers.Add(tiledLayer);
myMap.Layers.Add(imageLayer);
myMap.Layers["ImageMapLayer"].Visible = false;
}
我的代码里调用了两个地图层,两个都是 ArcGisTiledMapServiceLayer, 这是切片的ArcGis地图服务,也就是把图片切成一块一块,然后下载到客户端来显示。
我们同样看到了 HtmlPage.Window.GetProperty("GetSLTiledLayer") as ScriptObject; 这行代码来调用外部 JavaScript 代码来获取切片服务的 Url。
设置了tiledLayer和imageLayer的Url后我们再设置下他们的 ID号,然后在我们的 Map实例中(也就是myMap)把他们加到地图层上来,然后这两个层就显示在地图上了。
继续看承载页面JavaScript代码:
<script type="text/javascript">
//获取
function GetSLTiledLayer(key) {
if (key.toString() == 'TiledLayer') {
var a = '<%=GetAppSetting("TiledLayer")%>';
}
return a;
}
</script>
GetAppSetting方法和上面给出的托管代码一样。
Web.Config中的配置:
<appSettings>
<add key="TiledLayer" value="http://bbs.gao00.com/ArcGIS/rest/services/Map001/World/MapServer"/>
<add key="TyphoonSL" value="http://localhost:7629/TyphoonService.asmx"/>
</appSettings>
这时候我们就把动态服务和动态地图都配置好了!
纠结了半天的排版,我还是决定放弃了,本来想写那个ElementLayer在ArcGis上显示Silverlight原生元素了,我最终还是被博客园这个文字排版小工具给打败了,可能是我不太会用吧!下一讲再写那个东西吧!