SQL Server 2008空间数据应用系列十二:Bing Maps中呈现GeoRSS订阅的空间数据

阅读更多

友情提示,您阅读本篇博文的先决条件如下:

  1、本文示例基于Microsoft SQL Server 2008 R2调测。

  2、具备 Transact-SQL 编程经验和使用 SQL Server Management Studio 的经验。

  3、熟悉或了解Microsoft SQL Server 2008中的空间数据类型。

  4、具备相应(比如OGC规范、KML规范)的GIS专业理论知识。

  5、GeoRss订阅技术以及其他相关知识。


  GeoRSS是一种描述和查明互联网内容所在物理位置的方法。通过使用GeoRSS,搜索Web站点或者与地理位置有关的项目就成为可能。GeoRSS利用地理标识语言(GML),即利用可扩展标记语言 (Extensible Markup Language, XML)存储和传输地理数据的方法。原始的GML模型以由World Wide Web联盟(W3C)所开发的资源描述框架(RDF)为基础。GML保持着RDF的许多特性,包括智能代理和一个用于描述和查询数据的标准语法。

  

  GeoRSS 是在 RSS 订阅源中包含地理空间数据时所用的一个标准,它定义了一种名为 GeoRSS GML 的特定格式,用来在订阅源中包含 GML 格式的数据。客户端应用程序可以订阅 GeoRSS 订阅源,订阅方式与订阅常规 RSS 订阅源相同。可以轻松地将 GeoRSS 格式的数据导入Microsoft Bing Maps、Google Maps中,同样也可以将空间数据库中的空间数据发布为GeoRss订阅后快速的在GIS中呈现,本篇将介绍如何基于微软Bing Maps for Silverlight中呈现GeoRss订阅的空间数据。

一、发布空间数据到GeoRss

  前一篇文章《SQL Server 2008空间数据应用系列十:使用存储过程生成GeoRSS聚合空间信息》介绍了如何将空间数据通过存储过程+HTTP请求接口发布为GeoRss的具体实现,这里就一笔带过,详细请查阅上篇博文。

二、创建GeoRss阅读器

  创建GeoRss阅读器的目的是为了动态的请求GeoRss地址,将GeoRss数据解析为自己想要的数据结构,如下便是根据自己的需求结合GeoRss定义的一种数据结构样例。

using System.Collections.Generic;
using Microsoft.Maps.MapControl;
namespace GeoRss.Map.GeoRssUtils
{
public class GeoRssItem
{
public string Title{ get ; set ;}
public string Description{ get ; set ;}
public string Link{ get ; set ;}
public string PubData{ get ; set ;}
public LocationCollectionLocatios{ get ; set ;}
}
}

  核心原理就是使用WebClient动态的发起http请求,将返回的GeoRss数据通过Linq To XML的方式解析为对象结构的数据。其实现非常简单,不做具体分析,详细代码如下所示:

using System.Collections.Generic;
using System;
using System.Net;
using System.Xml.Linq;
using System.Linq;
using System.Windows;
using Microsoft.Maps.MapControl;
namespace GeoRss.Map.GeoRssUtils
{
public delegate void DownloadGeoRssCompletedEventHandler(List < GeoRssItem > items);

public delegate void DownloadGeoRssExceptionEventHandler(Exceptione);

public class GeoRssReader
{
public GeoRssReader()
{
wc
= new WebClient();
wc.DownloadStringCompleted
+= WebClientDownloadGeoRssCompleted;
}

public GeoRssReader(Uriuri)
:
this ()
{
this .uri = uri;
}

public GeoRssReader(Uriuri,DownloadGeoRssCompletedEventHandlerevh)
:
this (uri)
{
DownloadGeoRssCompleted
+= evh;
}

public Uriuri{ get ; set ;}

public event DownloadGeoRssCompletedEventHandlerDownloadGeoRssCompleted;
public event DownloadGeoRssExceptionEventHandlerDownloadGeoRssException;

public void ReadAsync()
{
if (DownloadGeoRssCompleted.Target != null )
{
wc.DownloadStringAsync(uri);
}
}

#region _private

private readonly WebClientwc;

private void WebClientDownloadGeoRssCompleted( object sender,DownloadStringCompletedEventArgse)
{
try
{
XNamespacensXml
= " http://www.w3.org/2005/Atom " ;
XNamespacensGeorss
= " http://www.georss.org/georss " ;
XNamespacensGeo
= " http://www.w3.org/2003/01/geo/wgs84_pos# " ;
XNamespacensMedia
= " http://search.yahoo.com/mrss/ " ;

varitems
= fromitem in XElement.Parse(e.Result).Descendants( " item " )
select
new GeoRssItem
{
Title
= (item.Element( " title " ) != null ) ? item.Element( " title " ).Value: null ,
Link
= (item.Element( " link " ) != null ) ? item.Element( " link " ).Value: null ,
Description
= (item.Element( " description " ) != null ) ? item.Element( " description " ).Value: null ,
PubData
= (item.Element( " pubDate " ) != null ) ? item.Element( " pubDate " ).Value: null ,
Locatios
= ParserLocations(XElement.Parse(item.LastNode.ToString().Replace( " : " , " X " )).Value)
};


if (DownloadGeoRssCompleted.Method != null )
{
DownloadGeoRssCompleted.Invoke(items.ToList());
}
}
catch (Exceptionex)
{
if (DownloadGeoRssException.Method != null )
{
DownloadGeoRssException.Invoke(ex);
}
else
{
throw ;
}
}
}

private LocationCollectionParserLocations( string points)
{
LocationCollectionlc
= new LocationCollection();
string []ps = points.Split( ' ' );
for ( int i = 0 ;i < ps.Length;i += 2 )
{
lc.Add(
new Location( double .Parse(ps[i]), double .Parse(ps[i + 1 ])));
}
return lc;
}

#endregion

}
}

三、基于SLBM呈现GeoRss数据

  引入Bing Maps Silverlight Control的控件库,定义一个专门的MapLayer图层来呈现GeoRss数据,其Silverlight前台的代码如下。

< Grid x:Name ="LayoutRoot" Background ="White" >
< map:Map x:Name ="map" Margin ="0,0,0,0" CredentialsProvider =" {StaticResourceMyCredentials} "
ScaleVisibility
="Visible"
CopyrightVisibility
="Collapsed" >
< map:MapLayer Name ="mlayer" > map:MapLayer >
map:Map >
Grid >

  应用程序加载的过程中使用上面所开发完成的GeoRss阅读器进行数据读取并解析,随后将结果呈现在Bing Maps Silverlight Control的应用中。代码如下:

public MainPage()
{
InitializeComponent();

string url = " http://localhost:32484/SHBuildingGeoHandler.ashx " ;
GeoRssReaderreader
= new GeoRssReader( new Uri(url,UriKind.RelativeOrAbsolute));
reader.DownloadGeoRssCompleted
+= new DownloadGeoRssCompletedEventHandler(reader_DownloadGeoRssCompleted);
reader.ReadAsync();
}

void reader_DownloadGeoRssCompleted(List < GeoRssItem > items)
{
// System.Diagnostics.Debug.WriteLine(items.Count);
foreach (varitem in items)
{
MapPolygonmp
= new MapPolygon();
mp.Locations
= item.Locatios;
mp.Fill
= new SolidColorBrush(Colors.Red);
this .mlayer.Children.Add(mp);

}
}

        

四、相关资料

  [1]、数据表中使用空间数据类型:http://www.cnblogs.com/beniao/archive/2011/02/21/1959347.html

  [2]、几何实例上的OGC方法:http://msdn.microsoft.com/zh-cn/visualc/bb933960.aspx

  [3]、几何图形实例上的扩展方法:http://msdn.microsoft.com/zh-cn/library/bb933880.aspx

  [4]、OGC 静态几何图形方法:http://msdn.microsoft.com/zh-cn/library/bb933894.aspx

  [5]、Bing Maps开发系列博文:http://www.cnblogs.com/beniao/archive/2010/01/13/1646446.html

  

你可能感兴趣的:(SQL Server 2008空间数据应用系列十二:Bing Maps中呈现GeoRSS订阅的空间数据)