openlayer5 半径不准 画圆_openlayers绘制圆形时设置半径以米为单位

ol.geom.Circle半径参数radius单位是什么?

ol.geom.Circle方法有三个参数其中radius便是半径,但是官方文档没有明确说明其单位,只是说radius是number类型,很坑。

ol.geom.Circle设置半径的单位是随投影的单位。

然后继续看api文档发现 setRadius 这个方法是设置图形的半径。然后一句关键的话,官网原话:

Set the radius of the circle. The radius is in the units of the projection.

翻译过来也就是ol.geom.Circle设置半径的单位是随投影的单位。

那么我们就有思路了,就先获取到当前投影然后在获取当前投影的单位,在进行单位转换。

获取当前投影的单位getUnits

在ol.proj.Projection找到getUnits方法可以获取当前投影的单位

投影有哪些单位 ?

Projection units: 'degrees', 'ft', 'm', 'pixels', 'tile-pixels' or 'us-ft'.

ol.proj.Units可以查看有哪些单位,发现其中有'm'就是米这个单位。

单位转换 ?

那么如果将当前投影的单位转换成'm'米呢?

继续寻找api发现在ol.proj.Projection有getMetersPerUnit()方法

Get the amount of meters per unit of this projection.

这样不管当前投影是什么单位都可以设置以米为单位的半径值了。

因为ol.geom.Circle设置半径的单位是随投影的单位,所以需要将单位m转换成投影的单位

到此问题已经解决,代码如下:/**

* 获取转换后单位的半径

* @param {Number} radius 以米为单位的半径的值

* @returns {Number} circleRadius 以投影的单位为单位的半径的值

*/

let getRadius = (radius)=>{

let metersPerUnit = map.getView().getProjection().getMetersPerUnit();

let circleRadius = radius / metersPerUnit;

return circleRadius;

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值