geo几何 写入 geojson

auto sized = newClusterSegmentList.size();
        StringBuffer sb;
        Writer<StringBuffer> writer(sb);
        writer.StartObject();
        writer.String("type");
        writer.String("FeatureCollection");

        writer.String("features");
        writer.StartArray();
        for(auto &newcluster : newClusterSegmentList)
        {

            adjustCoord.setConvertFlag(COORD_CONVERT_FALG_ENU_TO_WGS84);
            newcluster._newGeometry->apply_rw(adjustCoord);
            writer.StartObject();
            writer.String("type");
            writer.String("Feature");

            writer.String("geometry");
            writer.StartObject();

            writer.String("type");
            writer.String("LineString");

            writer.String("coordinates");
            writer.StartArray();

             // 获取 LineString 对象中的坐标
            auto coordinates =  newcluster._newGeometry->getCoordinates();
            for (size_t i = 0; i < coordinates->getSize(); ++i) 
            {
                const geos::geom::Coordinate& coord = coordinates->getAt(i);
                writer.StartArray();
                writer.Double(coord.x);
                writer.Double(coord.y);
                writer.Double(coord.z);
                writer.EndArray();
            }

            writer.EndArray();

            writer.EndObject();


            writer.EndObject();

        }
        writer.EndArray();
        writer.EndObject();
        
        std::string path = "/media/linux/mydisk/tool/jsonDataCollect/boundary_fit_width/newclustercenterline/" + curClusterId +std::string(".geojson");//curClusterId
        std::ofstream out;
        out.open(path.c_str(), std::ios::out);
        out << sb.GetString();
        out.close();

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值