相關資訊
本類常用軟件
-
福建農村信用社手機銀行客戶端下載下載量:584204
-
Windows優(yōu)化大師下載量:416898
-
90美女秀(視頻聊天軟件)下載量:366961
-
廣西農村信用社手機銀行客戶端下載下載量:365699
-
快播手機版下載量:325855
Oracle Spatial的空間數據應用和微軟SQL Server 2008的大同小異,SQL Server 2008提供了基于SQLCLR的編程支持,Oracle Spatial暫時還沒有比較完善的組件支持。在實際開發(fā)應用中我們可以選擇折中的解決方案,比如將空間數據讀取為通用的空間數據表達格式(如: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坐標系的空間標準,以及基于地理空間的空間對象、空間計算和空間分析接口,在應用開發(fā)中可以非常方便的完成空間數據的讀寫、驗證、計算和分析功能。本文使用到了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);
}