最近在接触地图数据转换的东西,从硬件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的更多相关文章

  1. C#、C++用GDAL读shp文件(转载)

    C#.C++用GDAL读shp文件 C#用GDAL读shp文件 (2012-08-14 17:09:45) 标签: 杂谈 分类: c#方面的总结 1.目前使用开发环境为VS2008+GDAL1.81 ...

  2. Android GIS开发系列-- 入门季(13)Gdal简单写个shp文件

    Gdal是用来读写栅格与矢量数据的,在Gdal官网,可以下载相关的资源进行平台的编译.其实Arcgis底层也是用Gdal来读取shp文件的,那在Android中可以直接读写shp文件吗,是可以的.这里 ...

  3. Java 使用GDAL 读写 shapefile

    读取shp文件,并把它转化为json import org.gdal.ogr.*; import org.gdal.ogr.Driver; import org.gdal.gdal.*; public ...

  4. shp的基本操作

    本节将介绍如何利用python完成对shp的基本操作 1.读取shp四至 import shapefile sf = shapefile.Reader(r"E:\shp\1.shp" ...

  5. webapi_uploadfile_gdal_to_geojson_and_unzipfile

    using ICSharpCode.SharpZipLib.Zip; using OSGeo.GDAL; using OSGeo.OGR; using System; using System.Col ...

  6. python使用游标访问数据

    游标是一种数据访问对象,可用于在表中迭代一组行或者向表中插入新行.游标有三种形式:搜索.插入或更新.游标通常用于读取现有几何和写入新几何. 每种类型的游标均由对应的 ArcPy 函数(SearchCu ...

  7. SublimeCodeIntel代码自动补全配置

    主要使用python3,所有配置以python3为例.其他语言同理.利用sublimeCodeIntel插件可以实现自动提示python3代码.跳转追踪自定义函数.查看系统函数等.功能还是相当强大的. ...

  8. gdal集成kml库的做法

    作者:朱金灿 来源:http://blog.csdn.net/clever101 最近要读取kml文件,具体就是把kml文件当作一个矢量文件来读取.我发现gdal是支持集成kml库的.不过集成这个km ...

  9. GDAL集成对KML文件的支持

    目录 1. 正文 1.1. 编译LibKML 1.1.1. 第三方库支持 1.1.2. 编译错误 1.2. 配置GDAL 1.3. 链接问题 2. 参考 1. 正文 GDAL可以支持将KML作为矢量文 ...

随机推荐

  1. win 10 精简组件列表

    轻松访问工具 操作中心 应用程序虚拟化(App-V) Telemetry Client (Asimov)(遥测) Assigned Access(按需访问) 自动播放 网络后台传输 备份 生物识别服务 ...

  2. mongo 监听指定语句

    class Program { private static string conn = "mongodb://47.104.206.56:27017"; //数据库名称 priv ...

  3. vim命令:编辑模式和命令模式

      vim:编辑模式 从一般模式进入编辑模式,只需你按一个键即可(i,I,a,A,o,O,r,R).当进入编辑模式时,会在屏幕的最下一行出现“INSERT或REPLACE”的字样.从编辑模式回到一般模 ...

  4. 虚拟机网络连接方式导致的p地址为10.0.2.*的问题

    全世界都知道通过 ifconfig 命令查看本机ip地址,我当然希望安装的虚拟机和当前局域网的其他机器一样内网ip为192.168.1.*,如下图所示: 而当我执行该命令时,实际情况却是这样的: 解决 ...

  5. Docker 核心技术之网络管理

    为什么需要Docker网络管理 容器的网络默认与宿主机.与其他容器都是相互隔离. 容器中可以运行一些网络应用(如nginx.web应用.数据库等),如果要让外部也可以访问这些容器内运行的网络应用,那么 ...

  6. pm2 常用命令解析

    https://blog.csdn.net/chengxuyuanyonghu/article/details/74910875 (以上基本命令解析,一下补充) pm2 ecosystem  #在当前 ...

  7. FJUTOJ-周赛2016-12-16

    注:fjutoj基本每周都有一次周赛,欢迎大家都来参加! 网址:http://59.77.139.92/index.jsp A题:来源 POJ 2773 题意:给两个数m和k,问第k 个和m 互素的数 ...

  8. 在Asp.Net Core中集成ABP Dapper

    在实际的项目中,除了集成ABP框架的EntityFrameworkCore以外,在有些特定的场景下不可避免地会使用一些SQL查询语句,一方面是由于现在的EntityFrameworkCore2.X有些 ...

  9. linux shell 命令集锦

    -h FILEFILE exists and is a symbolic link (same as -L)文件存在并且是一个字符链接(与-L选项相同) dirname $0  定位执行的命令脚本的相 ...

  10. Dlib Python 检测人脸特征点 Face Landmark Detection

    首先安装Dlib,Opencv库 Dlib安装链接:http://www.cnblogs.com/as3asddd/p/7237280.html 环境:Mac Sierra 10.12.1 Pytho ...