变态重口极致另类在线-波多久久夜色精品国产-波多野结衣在线观看一区-波多野结衣在线观看一区二区-污污的网站免费阅读-污污视频网址

當前位置: 首頁IT技術 → Bing Maps開發擴展:Oracle Spatial的空間數據渲染

Bing Maps開發擴展:Oracle Spatial的空間數據渲染

更多

  Oracle Spatial的空間數據應用和微軟SQL Server 2008的大同小異,SQL Server 2008提供了基于SQLCLR的編程支持,Oracle Spatial暫時還沒有比較完善的組件支持。在實際開發應用中我們可以選擇折中的解決方案,比如將空間數據讀取為通用的空間數據表達格式(如:WKT),利用開源的WKT讀取組件便可將WKT數據解析為對應的空間數據坐標點或坐標集合。

  下面以一個實際的案例來介紹如何讀取Oracle Spatial數據為WKT,并通過WKT組件解析數據,最終在Bing Maps中進行渲染。現要實現將數據庫中地市表配置的全國地市數據中四川省的數據讀取出來在地圖中進行渲染,Oracle Spatial的sdo_geometry數據類型則可以直接使用函數(get_wkt())進行轉換為clob數據類型數據。

  select t.areacode,t.areaname, (t.area.get_wkt()) wkt from areainfo t where areacode like '8623%'

 

  為了方便客戶端的使用,服務端可以通過WCF服務封裝數據為數組返回,以下為地市實體對象數據結構和WCF服務的定義。

  namespace OracleSpatial.DataService.Models

  {

   [DataContract]

   public class AreaInfo

   {

   [DataMember]

   public string AreaCode { get; set; }

   [DataMember]

   public string AreaName { get; set; }

   [DataMember]

   public string WKT { get; set; }

   }

  }

  namespace OracleSpatial.DataService

  {

   [ServiceContract]

   public interface IGeometryService

   {

   [OperationContract]

   List GetAreaInfo();

   }

  }

  Bing Maps的Silverlight客戶端調用WCF服務以獲取數據庫中的數據,這里就不做詳細介紹。在這里需要特別介紹的是幾個開源應用:

  1、SharpMap開源的GeoAPI.

  2、NetTopologySuite.

  這兩個開源庫分別定義好了不同GIS坐標系的空間標準,以及基于地理空間的空間對象、空間計算和空間分析接口,在應用開發中可以非常方便的完成空間數據的讀寫、驗證、計算和分析功能。本文使用到了WKT讀取組件(WKTReader),可以實現將WKT格式的字符串解析為符合GIS坐標系標準的通用空間對象(Geometry),此空間對象中就包含了完整的WKT數據的描述,如WKT所表示的坐標點,坐標點集合,內部坐標點,空間面積等等。

  public MainPage()

  {

   InitializeComponent();

   this.Loaded += (sender, e) =>

   {

   LoadChinaMap();

   GeometryServiceClient service = new GeometryServiceClient();

   service.GetAreaInfoCompleted += service_GetAreaInfoCompleted;

   service.GetAreaInfoAsync();

   };

  }

  private void service_GetAreaInfoCompleted(object sender, GetAreaInfoCompletedEventArgs e)

  {

   if (e.Error == null)

   {

   ObservableCollection result = e.Result;

   WKTReader reader = reader = new WKTReader();

   IGeometry geometry = reader.Read(result[0].WKT);

   }

  }

  

   通過WKTReader將WKT格式的空間數據解析為IGeometry接口的空間對象,就可以非常方便的獲取WKT空間數據中的各種坐標值。如果上面所獲取到的數據,我們就可以通過繪制多邊形以及通過自定義標注將數據渲染在地圖中。

  private void service_GetAreaInfoCompleted(object sender, GetAreaInfoCompletedEventArgs e)

  {

   if (e.Error == null)

   {

   ObservableCollection result = e.Result;

   WKTReader reader = null;

   foreach (var item in result)

   {

   reader = new WKTReader();

   IGeometry geometry = reader.Read(item.WKT);

   //邊界

   MapPolygon line = new MapPolygon();

   line.Locations = CoordinateConvertor.CoordinatesToLocationCollection(geometry.Coordinates);

   line.Fill = new SolidColorBrush(Colors.Gray);

   line.BorderBrush = new SolidColorBrush(Colors.Green);

   line.BorderThickness = new Thickness(2);

   line.MouseEnter += new MouseEventHandler(line_MouseEnter);

   line.MouseLeave += new MouseEventHandler(line_MouseLeave);

   this.mlayer.Children.Add(line);

   //名稱標注

   this.mlayer.AddChild(new PointControl(item.AreaName),

   new Microsoft.Maps.MapControl.Location(geometry.InteriorPoint.Y, geometry.InteriorPoint.X));

   }

   }

  }

  private void line_MouseLeave(object sender, MouseEventArgs e)

  {

   MapPolygon mp = sender as MapPolygon;

   mp.Fill = new SolidColorBrush(Colors.Gray);

 

  }

  private void line_MouseEnter(object sender, MouseEventArgs e)

  {

   MapPolygon mp = sender as MapPolygon;

   mp.Fill = new SolidColorBrush(Colors.Yellow);

  }

  

熱門評論
最新評論
昵稱:
表情: 高興 可 汗 我不要 害羞 好 下下下 送花 屎 親親
字數: 0/500 (您的評論需要經過審核才能顯示)
主站蜘蛛池模板: 甜性涩爱在线观看e8 | 成人免费公开视频 | 337p日本大胆欧洲色噜噜高清 | 最好看2019高清中文字幕 | 成人羞羞视频在线 | 国产精品青草久久福利不卡 | 农村偷人一级超爽毛片 | 欧美激情视频免费 | 黄色片大全在线观看 | 国产你懂的视频 | 国产亚洲欧洲国产综合一区 | 欧美日韩在线一本卡 | 免费韩国理伦片在线观看 | 国产播放啪视频免费视频 | 在线看欧美成人中文字幕视频 | www.日本视频 | 一个人看的www高清免费 | 日韩一级二级 | 欧美在线看片 | 我色综合| 日韩在线视频线视频免费网站 | 久久亚洲一级毛片 | 91最新地址永久入口 | 插插宗合网 | 真实一级一级一片免费视频 | 伊人在综合 | 人人揉人人添人人捏人人看 | 国产成人18黄网站免费网站 | 久久久久成人精品免费播放动漫 | 色视频网站在线观看 | 免费看一片 | 国产精品视频国产永久视频 | 日韩激情淫片免费看 | 一级特黄色毛片免费看 | 免费看黄色的网址 | 女同志videos最新 | 一个人看的www高清免费 | 免费又黄又猛又爽的大片 | 亚洲 中文 欧美 日韩 在线人 | 一级国产视频 | 男人午夜剧场 |