openlayers5實戰--踩坑總結


1.接口返回圓心坐標和半徑,直接通過new Circle(center,radius)添加圓形feature變小問題。

  解決辦法:

  new  Feature()的geometry參數不能直接賦值new  Circel()得到的geometry,

  要通過‘ol/geom/Polygon.js’中的fromCircle方法將new  Circel()得到的geometry轉化一遍然后賦值給new  Feature()的geometry。

  另:如果接口直接返回的坐標點畫圓,則使用‘ol/geom/Polygon.js’中的circular方法。

import {circular as circularPolygon, fromCircle as fromCirclePolygon} from CC;
eg1:
let lng = parseFloat(d[0].lng); let lat = parseFloat(d[0].lat); let radius = parseFloat(d[0].radius); let circle = new Circle(transform([lng, lat], 'EPSG:4326', 'EPSG:3857'), radius);
feature = new Feature({
   position: transform([lng, lat], 'EPSG:4326', 'EPSG:3857'),
   radius: radius,
   type: 'circle',
   id: 'N',
   geometry: fromCirclePolygon(circle)
})

eg2:
let lng = item.coordinateList[0].lng;
let lat = item.coordinateList[0].lat;
let radius = item.coordinateList[0].radius;
let circle4326 = circularPolygon([lng, lat],radius,64);
let circle3857 = circle4326.clone().transform('EPSG:4326', 'EPSG:3857');
feature = new Feature(circle3857);


  

2.測距不准問題。

  解決辦法:

  使用'ol/sphere.js'中的getLength()方法計算。

  

/*格式化測量長度
       *@params line:  type geometry
       */
      formatLength (line) {
        //定義長度變量
        let length = getLength(line);
        let output;
        if (length > 100) {
          output = `${(Math.round(length / 1000 * 100) / 100)} 公里`;
        } else {
          output = `${(Math.round(length * 100) / 100)} 米`;
        }
        return output;
      },

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM