WKT转GeoJson(js版)

先来个Polygon(包括MultiPolygon)转GeoJson的,最近有点忙,等有空加上其他的:

function processPolygonString2PolygonArray(polygonString, proj) {

        var geoJson = {};

        if (polygonString.startsWith("MULTIPOLYGON")) {
            // 多面
            geoJson["type"] = "MultiPolygon";

            var firstLeftIndex = polygonString.indexOf('(');
            var lastRightIndex = polygonString.indexOf(')');
            // 去掉首尾括号    
            var str = polygonString.substring(firstLeftIndex + 1, polygonString.length - 1); //   ((),(),()) , ((),(),()) , ((),(),())
            // console.log(str);

            var pArray = new Array();
            var polygonArray = str.split(")),((");
            for (var i = 0; i < polygonArray.length; i++) {
                var pStr = polygonArray[i];//每个polygon的String
                if (polygonArray.length === 1) {//如果只有1个,说明没有被分割
                    // 去掉第一个(  去掉结尾)
                    pStr = pStr.substring(1, pStr.length - 1);
                } else if (i === 0) {
                    // 第一个,去第一个(   补结尾加上 )
                    pStr = pStr.substring(1, pStr.length) + ")"; //  (),(),()   环的集合
                }
                else if (i === polygonArray.length - 1) {
                    // 最后一个: 补第一个( , 去 最后一个)
                    pStr = "(" + pStr.substring(0, pStr.length - 1);
                } else {
                    // 中间,补第一个(   补最后一个 )
                    pStr = "(" + pStr + ")";
                }

                // pStr 表示  () , () ,()   线环集合

                // 分割环
                var rArray = new Array();
                var ringsArray = pStr.split("),(");
                for (var j = 0; j < ringsArray.length; j++) {
                    var ringStr = ringsArray[j];

                    if (ringsArray.length === 1) {
                        // 去掉第一个(   去掉结尾  )
                        ringStr = ringStr.substring(1, ringStr.length - 1);
                    } else if (j === 0) {                    // 如果是第一个
                        // 去掉第一个(
                        ringStr = ringStr.substring(1, ringStr.length);
                    } else if (j === ringsArray.length - 1) {// 最后一个 
                        // 去掉结尾 )
                        ringStr = ringStr.substring(0, ringStr.length - 1);
                    }

                    // 再按逗号分割就是点集合
                    var ptsArray = new Array();
                    var pointArr = ringStr.split(",");
                    for (var k = 0; k < pointArr.length; k++) {
                        var pt_arr = pointArr[k].split(" ");
                        var proj_arr = proj4(proj).inverse([pt_arr[0], pt_arr[1]]);

                        ptsArray.push(proj_arr);
                    }

                    rArray.push(ptsArray);
                }
                pArray.push(rArray);
            }

            //console.log(JSON.stringify(pArray));

            geoJson["coordinates"] = pArray;

        } else if (polygonString.startsWith("POLYGON")) {
            // 面,其中有可能有环
            geoJson["type"] = "Polygon";
            var firstLeftIndex = polygonString.indexOf('(');
            var lastRightIndex = polygonString.indexOf(')');
            // 去掉首尾括号    
            var str = polygonString.substring(firstLeftIndex + 1, polygonString.length - 1); //   (),(),() 

            var rArray = new Array();
            var ringsArray = str.split("),(");
            for (var j = 0; j < ringsArray.length; j++) {
                var ringStr = ringsArray[j];

                if (ringsArray.length === 1) {
                    // 去掉第一个(   去掉结尾  )
                    ringStr = ringStr.substring(1, ringStr.length - 1);
                } else if (j === 0) {                    // 如果是第一个
                    // 去掉第一个(
                    ringStr = ringStr.substring(1, ringStr.length);
                } else if (j === ringsArray.length - 1) {// 最后一个 
                    // 去掉结尾 )
                    ringStr = ringStr.substring(0, ringStr.length - 1);
                }

                // 再按逗号分割就是点集合
                var ptsArray = new Array();
                var pointArr = ringStr.split(",");
                for (var k = 0; k < pointArr.length; k++) {
                    var pt_arr = pointArr[k].split(" ");
                    var proj_arr = proj4(proj).inverse([pt_arr[0], pt_arr[1]]);

                    ptsArray.push(proj_arr);
                }

                rArray.push(ptsArray);
            }

            geoJson["coordinates"] = rArray;
        }
        return geoJson;
    }

参考资料:
http://www.oschina.net/translate/geojson-spec#coordinate-reference-system-objects
http://blog.csdn.net/arenn/article/details/54907545
http://www.cnblogs.com/marsprj/archive/2013/02/08/2909452.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值