Android Arcgis(13)、Gdal简单写个shp文件

Gdal是用来读写栅格与矢量数据的,在Gdal官网,可以下载相关的资源进行平台的编译。其实Arcgis底层也是用Gdal来读取shp文件的,那在Android中可以直接读写shp文件吗,是可以的。这里已经有人编译了Android端的so ,下载地址。也可以自己尝试编译相关so。

新建项目,将下载的so 与相关资源导入,相关目录结构如下:

注意gdal的相关包名不要修改,避免so读取不到相应的类。
简单写个shp,注意导包,要导入org.gdal下面相关的类:

private void writeShp() throws UnsupportedEncodingException {
        //存放路径
        String shpPath = basePath + "/my_line.shp";
        ogr.RegisterAll();
        gdal.SetConfigOption("GDAL_FILENAME_IS_UTF8", "NO");
        // 不支持中文
        gdal.SetConfigOption("SHAPE_ENCODING", "");
        String strDriverName = "ESRI Shapefile";
        org.gdal.ogr.Driver oDriver = ogr.GetDriverByName(strDriverName);
        if (oDriver == null) {
            System.out.println(" 驱动不可用!\n");
            return;
        }
        // 创建数据源
        DataSource oDS = oDriver.CreateDataSource(shpPath, null);
        if (oDS == null) {
            return;
        }
        // 创建一个84坐标系的图层
        org.gdal.osr.SpatialReference sap = new org.gdal.osr.SpatialReference();
        sap.SetWellKnownGeogCS("WGS84");
        Layer oLayer = oDS
                .CreateLayer("TestPolygon", sap, ogr.wkbPolygon, null);
        if (oLayer == null) {
            System.out.println("图层创建失败!\n");
            return;
        }
        // 下面创建属性表
        // 先创建一个叫FieldID的整型属性
        FieldDefn oFieldID = new FieldDefn("ID", ogr.OFTInteger);
        oLayer.CreateField(oFieldID, 1);

        // 再创建一个叫FeatureName的字符型属性,字符长度为50
        FieldDefn oFieldName = new FieldDefn("name", ogr.OFTString);
        oFieldName.SetWidth(100);
        oLayer.CreateField(oFieldName, 1);

        FeatureDefn oDefn = oLayer.GetLayerDefn();

        // 创建要素
        Feature oFeatureTriangle = new Feature(oDefn);
        oFeatureTriangle.SetField(0, 0);
        oFeatureTriangle.SetField(1, "test");
        Geometry geomTriangle = Geometry
                .CreateFromWkt("POLYGON ((112 45,112 30,140 30))");
        oFeatureTriangle.SetGeometry(geomTriangle);

        oLayer.CreateFeature(oFeatureTriangle);
        //同步到文件中,一定要写
        oLayer.SyncToDisk();
    }

用Arcgis MapView加载shp文件效果:

Gdal Java相关Api

注:1.上面Gdal对中文不支持,读写都乱码!暂时没有找到解决方法。
2.此Gdal只能对已经存在的shp文件添加要素,删除、更新无效。

评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值