KML,SHP TAB互转,GDAL
最近在接触地图数据转换的东西,从硬件kml的数据转换其他的格式,因为从没做过着东西, 先去了解kml文件格式
http://baike.baidu.com/view/400307.htm?fr=aladdin
原来是谷歌地球的一种数据格式,先大致看了写里面的标签,kml与xml文件差多,
kml数据:

longitude:经度 latitude:纬度 altitude:高度 其他的就自己去看了。
现在开始转换,在谷歌上找到一个开源的项目 里面是对地图数据的操作,GDAL
http://www.gdal.org/ogr/ogr_formats.html 参考这里。
kml->SHP
private string CreateShp(List<Placemark> list)
{ //注册Ogr库
string pszDriverName = DriverType.Shapefile;
OSGeo.OGR.Ogr.RegisterAll(); //为了支持中文路径,请添加下面这句代码
OSGeo.GDAL.Gdal.SetConfigOption("GDAL_FILENAME_IS_UTF8", "YES");
// 为了支持shp属性表字段支持中文,请添加下面这句
OSGeo.GDAL.Gdal.SetConfigOption("SHAPE_ENCODING", " "); //调用对Shape文件读写的Driver接口
OSGeo.OGR.Driver poDriver = OSGeo.OGR.Ogr.GetDriverByName(pszDriverName);
if (poDriver == null)
return "打开驱动失败"; //用此Driver创建Shape文件
OSGeo.OGR.DataSource poDS;
poDS = poDriver.CreateDataSource(CreateSavePath(), null);
if (poDS == null)
return "创建数据源失败"; //创建层Layer
OSGeo.OGR.Layer poLayer;
poLayer = poDS.CreateLayer(CurrentDate, null, OSGeo.OGR.wkbGeometryType.wkbPoint, null);
if (poLayer == null)
return "创建地图层失败"; //创建属性
OSGeo.OGR.FieldDefn oField = new OSGeo.OGR.FieldDefn("name", OSGeo.OGR.FieldType.OFTString);
oField.SetWidth();
OSGeo.OGR.FieldDefn oField2 = new OSGeo.OGR.FieldDefn("height", OSGeo.OGR.FieldType.OFTInteger); OSGeo.OGR.FieldDefn ofield3 = new FieldDefn("lat", FieldType.OFTInteger);
OSGeo.OGR.FieldDefn ofield4 = new FieldDefn("lng", FieldType.OFTInteger); poLayer.CreateField(oField, );
poLayer.CreateField(oField2, );
poLayer.CreateField(ofield3, );
poLayer.CreateField(ofield4, ); //创建一个Feature,一个Point
OSGeo.OGR.Feature poFeature = new Feature(poLayer.GetLayerDefn());
OSGeo.OGR.Geometry pt = new Geometry(OSGeo.OGR.wkbGeometryType.wkbPoint); foreach (Placemark item in list)
{
//属性一"名称"赋值
poFeature.SetField(, item.Name);
//属性二"高度"赋值
poFeature.SetField(, item.LookAt.altitude);
poFeature.SetField(, item.LookAt.latitude);
poFeature.SetField(, item.LookAt.longitude); //添加坐标点 x y z
pt.AddPoint(item.LookAt.longitude, item.LookAt.latitude, item.LookAt.altitude); poFeature.SetGeometry(pt);
//将带有坐标及属性的Feature要素点写入Layer中
poLayer.CreateFeature(poFeature); } //关闭文件读写
poFeature.Dispose();
poDS.Dispose(); return "转换成功";
}
SHP->mapinfo tab转换出现问题,当我的经纬度像上图一样小数位数比较多的情况,会自动截断,仔细调试都没找到解决办法,截断都是没规则的,只能继续谷歌了,╮(╯▽╰)╭。
代码如下:
public string Convert(string driverTypeName, OnAction action)
{
string msg = string.Empty;
DataSource sourceSource;
OSGeo.OGR.Driver shpDriver;
RegisterAll(driverTypeName, out sourceSource, out shpDriver);
DataSource destSource = shpDriver.CreateDataSource(Dest, new string[] {
"AUX=YES",
"STATISTICS=YES"}); //中文
int layerCount = sourceSource.GetLayerCount();
for (int i = ; i < layerCount; i++)
{
Layer layer = sourceSource.GetLayerByIndex(i);
int featureCount = layer.GetFeatureCount();
Layer destLayer = null; //深度拷贝
//Layer destLayer = destSource.CopyLayer(layer, dest, null); #region MyRegion
for (int j = ; j < featureCount; j++)
{
Feature feature = layer.GetFeature(j); if (feature != null)
{
try
{ if (destLayer == null)
{
wkbGeometryType geoType = feature.GetGeometryRef().GetGeometryType();
//创建图层
destLayer = destSource.CreateLayer(
layer.GetName(),
action(layer),
geoType,
new string[] { });
//创建字段
FeatureDefn featureDefn = layer.GetLayerDefn();
for (int k = ; k < featureDefn.GetFieldCount(); k++)
{
destLayer.CreateField(featureDefn.GetFieldDefn(k), );
}
}
//写入要素 Feature cloneFeature = feature.Clone(); // Feature newfeature = ConvetToFeature(feature); destLayer.CreateFeature(cloneFeature); // OnFeatureConvert(featureCount, EventArgs.Empty);
}
catch (Exception ex)
{
msg = "转换失败"+ex.Message;
continue;
}
}
}
#endregion //保存
destLayer.SyncToDisk();
} msg = "转换成功";
sourceSource.Dispose();
destSource.Dispose();
shpDriver.Dispose();
return msg;
}
原来是坐标系的问题,
shp的默认与tab的坐标系不一样。参考文章:http://blog.sina.com.cn/s/blog_6e51df7f0100ui7n.html
坐标系转换参考:http://wiki.woodpecker.org.cn/moin/lilin/ogr-create
终于解决。
KML,SHP TAB互转,GDAL的更多相关文章
- C#、C++用GDAL读shp文件(转载)
C#.C++用GDAL读shp文件 C#用GDAL读shp文件 (2012-08-14 17:09:45) 标签: 杂谈 分类: c#方面的总结 1.目前使用开发环境为VS2008+GDAL1.81 ...
- Android GIS开发系列-- 入门季(13)Gdal简单写个shp文件
Gdal是用来读写栅格与矢量数据的,在Gdal官网,可以下载相关的资源进行平台的编译.其实Arcgis底层也是用Gdal来读取shp文件的,那在Android中可以直接读写shp文件吗,是可以的.这里 ...
- Java 使用GDAL 读写 shapefile
读取shp文件,并把它转化为json import org.gdal.ogr.*; import org.gdal.ogr.Driver; import org.gdal.gdal.*; public ...
- shp的基本操作
本节将介绍如何利用python完成对shp的基本操作 1.读取shp四至 import shapefile sf = shapefile.Reader(r"E:\shp\1.shp" ...
- webapi_uploadfile_gdal_to_geojson_and_unzipfile
using ICSharpCode.SharpZipLib.Zip; using OSGeo.GDAL; using OSGeo.OGR; using System; using System.Col ...
- python使用游标访问数据
游标是一种数据访问对象,可用于在表中迭代一组行或者向表中插入新行.游标有三种形式:搜索.插入或更新.游标通常用于读取现有几何和写入新几何. 每种类型的游标均由对应的 ArcPy 函数(SearchCu ...
- SublimeCodeIntel代码自动补全配置
主要使用python3,所有配置以python3为例.其他语言同理.利用sublimeCodeIntel插件可以实现自动提示python3代码.跳转追踪自定义函数.查看系统函数等.功能还是相当强大的. ...
- gdal集成kml库的做法
作者:朱金灿 来源:http://blog.csdn.net/clever101 最近要读取kml文件,具体就是把kml文件当作一个矢量文件来读取.我发现gdal是支持集成kml库的.不过集成这个km ...
- GDAL集成对KML文件的支持
目录 1. 正文 1.1. 编译LibKML 1.1.1. 第三方库支持 1.1.2. 编译错误 1.2. 配置GDAL 1.3. 链接问题 2. 参考 1. 正文 GDAL可以支持将KML作为矢量文 ...
随机推荐
- 【转】分享JavaScript监听全部Ajax请求事件的方法
若Ajax请求是由jQuery的$.ajax发起的,默认情况下可以使用 jQuery的Global Ajax Event Handlers监听到Ajax事件,然而我遇到的却是用原生JavaScript ...
- 【故障公告】推荐系统中转站撑爆服务器 TCP 连接引发的故障
上周五下午,我们在博客中部署了推荐系统,在博文下方显示“最新IT新闻”的地方显示自动推荐的关联博文.我们用的推荐系统是第四范式的推荐服务,我们自己只是搭建了一个推荐系统中转站(基于 ASP.NET C ...
- Python--day13(函数嵌套定义,global、nonlocal、闭包函数、装饰器)
今日主要内容 1. 函数的嵌套定义 2. global.nonlocal关键字 3. 闭包及闭包的应用场景 4. 装饰器 1. 函数的嵌套定义 概念:在一个函数的内部定义另一个函数 为什么要有 ...
- 用Case类生成模板代码
将类定义为case类会生成许多模板代码,好处在于: ①会生成一个apply方法,这样就可以不用new关键字创建新的实例. ②由于case类的构造函数参数默认是val,那么构造函数参数会自动生成访问方法 ...
- 02Spring Boot配置文件详解
02Spring Boot配置文件详解 文章指导 学习笔记 学习代码 自定义属性 在src/main/java/resources目录下创建一个application.properties或appli ...
- 四、Jedis操作Redis
前言: 原来我们操作mysql需要用的jdbc,现在操作redis则需要jedis,jedis是客户端,而redis是服务器,使用jedis客户端来操作redis. 在这里要使用jedis操作red ...
- springboot+shiro 一个项目部署多个,session名冲突问题
问题 前几天遇到一个比较奇怪的问题, 一个项目部署多个,端口不同.启动之后在同一浏览器中进行登录,后一个登录的会把前一个登录的挤掉,导致只能登录一个. 原因 是因为sessionid相同,然后修改了s ...
- zookeeper集群的简单搭建
zookeeper简单介绍 zookeeper是一个为分布式应用提供一致性服务的软件,它是开源的Hadoop项目的一个子项目,并根据google发表的一篇论文来实现的.zookeeper为分布式系统提 ...
- js中字符串可以调用的方法
var s = "hello,world" //定义一个字符串 s.length() // => 11 s.charAt(0) ...
- 【地图功能开发系列:二】根据地址名称通过百度地图API查询出坐标
根据地址名称通过百度地图API查询出坐标 百度地图ApiUrl string url = "http://api.map.baidu.com/geocoder?address={0}& ...