平台:Vs 2010,Blend 4,Silverlight 4
调用API: ArcGis for Silverligth API(ESRI.ArcGIS.Client)
本来准备晚上或下午写的,早上公司服务器挂了,地图服务用不了干脆就来写一点吧!有个朋友问我动态配置 WebService,Wcf服务的问题,正好也把这个一并写了!
好了不说废话了,进下正题。
先来看一下如何动态的配置WebService,Wcf 服务,实现方式:从 Web.Config 文件中读取地址,然后在 Silverlight 实现绑定。
首先我们还是添加服务引用,引用远程或本机的Web服务。然后在 silverlight 加下以下代码
- <SPAN style="FONT-FAMILY: 宋体; FONT-SIZE: 12pt"> /// <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);
- }
- </SPAN>
注意把 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函数。
里面有个托管代码函数GetAppSetting();我们看下他的代码:
- <SPAN style="FONT-FAMILY: 宋体; FONT-SIZE: 12pt"> /// <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;
- }
-
}</SPAN>
我们看他了他调用了ConfigurationSettings.AppSetting中的key.那再来看下他调用的Web.Config文件中的节点:
这样动态的WebService、Wcf调用就完成了!
然后就是动态调用地图,其实和动态调用WebService、Wcf差不多。我简单发下他们的代码:
- <SPAN style="FONT-FAMILY: 宋体; FONT-SIZE: 12pt"> /// <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;
- }
- </SPAN>
我的代码里调用了两个地图层,两个都是 ArcGisTiledMapServiceLayer,这是切片的ArcGis地图服务,也就是把图片切成一块一块,然后下载到客户端来显示。
我们同样看到了 HtmlPage.Window.GetProperty("GetSLTiledLayer") as ScriptObject; 这行代码来调用外部 JavaScript 代码来获取切片服务的 Url。
设置了tiledLayer和imageLayer的Url后我们再设置下他们的 ID号,然后在我们的 Map实例中(也就是myMap)把他们加到地图层上来,然后这两个层就显示在地图上了。
- <SPAN style="FONT-FAMILY: 宋体; FONT-SIZE: 12pt"> <script type="text/javascript">
- //获取
- function GetSLTiledLayer(key) {
- if (key.toString() == 'TiledLayer') {
- var a = '<%=GetAppSetting("TiledLayer")%>';
- }
- return a;
- }
- </script>
- </SPAN>
Web.Config中的配置:
这时候我们就把动态服务和动态地图都配置好了!
纠结了半天的排版,我还是决定放弃了,本来想写那个ElementLayer在ArcGis上显示Silverlight原生元素了,我最终还是被博客园这个文字排版小工具给打败了,可能是我不太会用吧!下一讲再写那个东西吧!
转自:http://www.cnblogs.com/Royal_WH/archive/2010/11/04/1868873.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。