Я не могу преобразовать геометрию в проекцию, определенную в proj4.defs в openlayers 5.3 - PullRequest
0 голосов
/ 22 мая 2019

У меня есть приложение Node mapping, которое использует openlayers V5.3.0. Когда я пытаюсь преобразовать геометрию из EPSG: 4326 в проекцию, определенную с помощью proj4.defs, я получаю это сообщение об ошибке: TypeError: Невозможно прочитать свойство 'getCode' с нулевым значением

Если я изменю openLayers на версию 4.6.4, код для преобразования геометрии работает.

Кто-нибудь еще сталкивался с этой проблемой?

Следующий HTML-код демонстрирует проблему.

<html>
<head>
    <meta http-equiv="Cache-Control" content="no-cache">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" >
    <title>Projection Test</title>

    <script
            src="https://code.jquery.com/jquery-2.2.4.min.js"
            integrity="sha256-BbhdlvQf/xTY9gja0Dq3HiwQF8LaCRTXxZKRutelT44="
            crossorigin="anonymous"></script>

   <!-- <script src="https://cdnjs.cloudflare.com/ajax/libs/openlayers/4.6.4/ol-debug.js"></script> -->

    <script src="https://cdn.rawgit.com/openlayers/openlayers.github.io/master/en/v5.3.0/build/ol.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/proj4js/2.5.0/proj4.js"></script>


    <script>proj4.defs("EPSG:28355","+proj=utm +zone=55 +south +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=m +no_defs");</script>

     <script>

         $(document).ready(function() {
             let gJSONOpts = {
                 dataProjection: "EPSG:3857",
                 featureProjection: "EPSG:28355"
             };

             let jsonPt = {
                 "type": "Feature",
                 "id": "GEO_BRM_STOPS.fid--79f50be5_16adc4d0ce7_6a6b",
                 "geometry": {
                     "type": "Point",
                     "coordinates": [16154413.50099648, -4988654.4460995]
                 },
                 "geometry_name": "OBJ"
             };

             let feature = new ol.format.GeoJSON().readFeature(jsonPt.geometry, gJSONOpts);
             let tg = feature.getGeometry().transform('EPSG:28355', "EPSG:4326");
             let out = 'Projected Coordinates: ' + tg.getCoordinates()[0] + ', ' +tg.getCoordinates()[1];

             $("#mapvwr").html(out);

         });
     </script>
</head>
<body>
    <div id="mapvwr">

    </div>
</body>
</html>

Вставьте вышеперечисленное в HTML-файл и покажите его в браузере.

Раскомментируйте эту строку:

 <!-- <script src="https://cdnjs.cloudflare.com/ajax/libs/openlayers/4.6.4/ol-debug.js"></script> -->

и закомментируйте следующую строку:

<script src="https://cdn.rawgit.com/openlayers/openlayers.github.io/master/en/v5.3.0/build/ol.js"></script>

Чтобы увидеть правильный результат:

Projected Coordinates: 145.11756553931886, -40.83921285742692

1 Ответ

0 голосов
/ 22 мая 2019

Я нашел проблему. Мне нужно добавить это как скрипт ol.proj.proj4.register(proj4); после того, как я определил проекцию.

...