mapBox 绘制多边形无法设置 边框宽度 解决方法

news2024/11/24 12:46:19

目录

一、问题

二、解决方法

 三、总结


tips:如嫌繁琐,直接看有颜色的文字即可!

一、问题

1.使用mapBox在地图上绘制点、线、面。绘制多边形的时候发现 直接用 zh(一家提供地图引擎的公司),提供的绘制多边形的方法无法设置边框颜色和边框宽度。很是离谱,按道理这种简单css就能实现的东西,为什么他们不能实现呢?况且fengMap是可以实现的。

二、解决方法

1.mapbox-gl-draw:下载链接https://api.mapbox.com/mapbox-gl-js/v2.15.0/mapbox-gl.js

2.方法一绘制完多边形后,再在多边形外面绘制 一条闭合的线段。于是写了如下的代码:

1)代码如下:


//线覆盖物基础参数
export const LineCoverConfig = {
  id: 'line',
  type: 'line',
  source: 'lineSource',
  paint: {
    'line-color': '#28e990',
    'line-width': 9,

  }
}

//多边形覆盖物样式
export const PolygonStyle = {
  color: '#ff5c2e',
  opacity: 0.5,
  height: 1,

}
//2)外边线样式(无法优化)
export const PolygonLineStyle = {
  id: 'polygonLine',
  type: 'line',
  source: 'polygonLineSource',
  paint: {
    'line-color': '#ff5c2e',
    'line-width': 2

  }
}      
    //根据坐标点添加线覆盖物 config:线覆盖物配置项
    addMark_line(pointArr, config, dataInfo) {
        const that = Locpard.instance;
        if (that && that.map) {
            let linePoint = []
            let option = Object.assign({}, LineCoverConfig, config);
            console.log("addMark_line", option, option.source, config)
            if (Array.isArray(pointArr)) {
                pointArr.forEach((element) => {
                    linePoint.push([element.y, element.x])
                })
                option.floor = pointArr[0]?.floor;
            }
            // that.map.drawLine( dataInfo.id, linePoint, option);

            this.drawLine(linePoint, option, dataInfo)
            const lineMarker = {
                id: option.id,
                source: option.source,
                type: 'layerLine'
            }
            return lineMarker;
        }
    }
    // 根据点集绘制 线段
    drawLine(pointArr, option, dataInfo) {
        const that = Locpard.instance;
        if (that) {
            that.map.map.addSource(option.source, {
                type: 'geojson',
                data: {
                    type: 'Feature',
                    properties: {
                        data: dataInfo
                    },
                    geometry: {
                        type: 'LineString',
                        coordinates: pointArr,
                    }
                }


            })
            that.map.map.addLayer(option)
        }
    }
    // 添加多边形
    addMark_polygon(option, dataInfo) {
        const that = Locpard.instance;
        if (that && that.map) {
            let pointArr = option.points.map((element) => {
                return [element.y, element.x]
            })
            let config = Object.assign({}, PolygonStyle, { ...option, floor: option.level })
            console.log("points", pointArr)
            let markerId = dataInfo.id.toString()
            //使用 zh 提供的api
            that.map.drawPolygon(markerId, pointArr, config)
            //手动 添加外边框
            that.addMark_line(option.points, { ...PolygonLineStyle, id: markerId, source: markerId }, dataInfo)
            return {
                id: markerId,
                source: markerId,
                type: "polygon"
            }
        }
    }

2)效果如下:

 3.方法二:总感觉方法一有问题,一次性渲染难道不是更好吗?为什么要去渲染两个图层,于是去mapBox找到绘制多边形的api,自己封装了一个绘制多边形的方法

1)代码如下:

//多边形覆盖物样式
export const PolygonStyle_2={
  id:'polygon',
  type:'fill',
  source:'polygonSource',
  layout:{},
  paint:{
    'fill-color':'#ff5c2e',
    'fill-opacity':0.5,
    'fill-outline-color':'#ff5c2e',
  }
}

    // can't set border-width
    addMark_polygon(option, dataInfo) {
        const that = Locpard.instance;
        if (that && that.map) {
            let pointArr = option.points.map((element) => {
                return [element.y, element.x]
            })
            option=Object.assign({},PolygonStyle_2,option)
            //that.map是 zh 封装的地图对象; that.map.map是 mapBox封装的地图对象
            that.map.map.addSource(option.source,{
                type:'geojson',
                data:{
                    type:'Feature',
                    geometry:{
                        type:'Polygon',
                        coordinates:[pointArr]
                    }
                }
            })
            that.map.map.addLayer(option)
            return {
                id:dataInfo.id.toString(),
                soureId:option.source,
                type: "polygon"
            }
        }
    }

2)效果如下: 虽然可以用fill-outline-color加边框了,仔细看一下可以看到边框的,但是不能设置边框的宽度。

尝试了 fill-outline-width,报错了,没有这个属性。去搜了一下gitHub上说:没有提供设置边框宽度的属性,因为WebGL不支持(会影响渲染速度)

 三、总结

1.所以如果你的需求是 设置边框颜色和边框宽度的话,就只能是 绘制两个图层:一个填充的多边形,外面再加一个 线覆盖图层(即采用方法一:其中的 that.map.drawPolygon(markerId, pointArr, config)==第三方厂家提供的方法 可以使用 方法二中的方法代替)

2.如果仅仅是添加边框颜色,则方法一和方法二都可以

3.不明白 fengMap难道不是用WebGL实现的?为什么它可以直接设置边框宽度呢?如有大佬知道,欢迎评论。

/*

希望对你有帮助!

如有错误,欢迎指正,非常感谢!

*/ 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/749389.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

龙蜥社区 6 月技术委员会会议召开!欢迎 5 位开放原子 TOC 导师加入

2023 年 6 月 16 日上午 10 点召开了龙蜥社区 6 月技术委员会线上会议,共计 38 人参会。本次会议由联通肖微主持,会议也荣幸的邀请到了开放原子 TOC 导师线上参会,技术委员们来自阿里云、统信、飞腾、中科方德、红旗、万里红、Intel、Arm、龙…

入门篇:从零上手GitOps

文章目录 GitOps 介绍如何将业务代码构建为容器镜像?如何将容器镜像部署到K8s?K8s如何实现自动扩容和自愈?1.传统的扩容和自愈2.k8s自愈机制3.k8s弹性扩容 如何借助GitOps实现应用秒级自动发布和回滚?1.传统 K8s 应用发布流程2.从…

高级细腻的家居照明,欧瑞博智能无主灯是怎么实现的?

作者 | 辰纹 来源 | 洞见新研社 如今的现代生活,人类对光的需求已超越简单照明,而是希望在不同场景下能有专属的细腻用光体验,智能照明应运而生,并成为上升趋势。现阶段,精细化家居需求要求智能照明不仅要巧妙融合美学…

二叉树进阶(AVLTree)

目录 1.AVLTree概念 2.AVLTree模拟实现 2.1 AVLTree节点 2.2 插入实现基本框架 2.3 左单旋 2.4 右单旋 2.5 LR双旋 2.6 RL双旋 2.7 AVLTree树验证 1.AVLTree概念 二叉搜索树虽可以缩短查找的效率,但如果数据有序或接近有序二叉搜索树将退化为单支树&#…

怎么从电影中截取动图?试试这个工具

图片、视频等都是当代流行的表达情感、传递信息的一种方式。其中,当属gif动图最受大众的欢迎,它比普通的静态图片画面丰富,又比视频的体积小。那么,如何从视频中截取动图呢?使用GIF中文网的视频转gif(https…

通过platform实现阻塞IO来驱动按键控制LED灯的亮灭

通过platform阻塞IO来驱动按键控制LED灯的亮灭 a .应用程序通过阻塞的io模型来读取number变量的值 b.number是内核驱动中的一个变量 c .number的值随着按键按下而改变(按键中断)例如number0按下按键number1 ,再次按下按键number0 d .在按下按键的时候需要同时将…

【Leetcode】42.接雨水(困难)

一、题目 1、题目描述 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。 示例1: 输入:height = [0,1,0,2,1,0,1,3,2,1,2,1] 输出:6 解释:上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况下,可以接 6…

雪花算法 — 集群高并发情况下如何保证分布式唯一全局ID生成?

雪花算法 问题 为什么需要分布式全局唯一ID以及分布式ID的业务需求 在复杂分布式系统中,往往需要对大量的数据和消息进行唯一标识: 如在美团点评的金融、支付、餐饮、酒店猫眼电影等产品的系统中数据逐渐增长,对数据库分库分表后需要有一…

接口测试辅助,Fiddler抓取安卓手机https请求(详细)

目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 Fiddler 是一款免…

Java设计模式之行为型-迭代器模式(UML类图+案例分析)

目录 一、基础概念 二、UML类图 三、角色设计 四、案例分析 五、总结 一、基础概念 迭代器模式是一种常用的设计模式,它主要用于遍历集合对象,提供一种方法顺序访问一个聚合对象中的各个元素,而又不暴露该对象的内部表示。 举个简单的…

第二章:Cyber RT通信机制解析与实践

Cyber RT解析与实践 第二章:Cyber RT通信机制解析与实践 Cyber RT解析与实践 Cyber RT解析与实践一、Cyber RT 通讯机制简介1. 话题2. 服务3. 参数 二、数据通信基础Protobuf1. Protobuf 简介2. Protobuf 创建3. Protobuf 编译4. Protobuf 案例实战 三、Cyber RT 话…

CPU性能指标简览

作为计算机的运算核心和控制核心,CPU(Central Processing Unit)由运算器、控制器、寄存器和实现其之间联系的数据、控制及状态的总线构成,决定着计算机运算性能强弱。作为信息技术产业的核心基础元器件,CPU的运作可分为…

3-40V输入,2.7V启动,20A电流,PWM\模拟信号调光

应用说明: Hi600X 是一系列外围电路简洁的宽调光比升压恒流驱动器,适用于 3-40V 输入电压范围的 LED 照明领域。 Hi600X 系列芯片,2.7V 启动电压,工作电压范围 5-40V,VIFB反馈电压 0.2V,提高整体转换效率。…

JVM的类加载机制和垃圾回收机制

目录 类加载机制类加载机制的步骤加载验证准备解析初始化 双亲委派模型工作原理双亲委派模型的优点 垃圾回收机制死亡对象的判断可达性分析算法可达性分析算法的缺点引用计数算法循环引用问题 垃圾回收算法标记-清除算法复制算法标记-整理算法分代算法 类加载机制 对于任意一个…

使用 vector + 递归 解决问题

class Solution {const char* To[10] { "","", "abc", "def", "ghi","jkl", "mno", "pqrs","tuv", "wxyz" };//常量字符串初始化string 注意此非定义(缺省值)--实例化…

收好这5个SVG编辑器,轻松实现高效创作

随着设计工作的不断发展,对SVG图形的需求也逐渐增加,SVG编辑器就随之诞生。可市面上的SVG编辑质量参差不齐,设计师无法第一时间找到适合自己的,于是本文就收集整理了5款相对来说比较好用的SVG编辑器为设计师们推荐,一起…

java项目之个人网站(ssm+mysql+jsp)

风定落花生,歌声逐流水,大家好我是风歌,混迹在java圈的辛苦码农。今天要和大家聊的是一款基于ssm的个人网站。技术交流和部署相关看文章末尾! 开发环境: 后端: 开发语言:Java 框架&#xf…

golang macaron静态资源访问配置

1、本地文件目录如下: 2、macaron配置 package mainimport ("log""net/http""gopkg.in/macaron.v1" )func myHandler(ctx *macaron.Context) string {return "the request path is: " ctx.Req.RequestURI }func main() …

基于linux下的高并发服务器开发(第一章)- Makefile(2)1.11

03 / 工作原理 ◼ 命令在执行之前,需要先检查规则中的依赖是否存在  如果存在,执行命令  如果不存在,向下检查其它的规则,检查有没有一个规则是用来生成这个依赖的,如 果找到了,则执行该规则中…

PowerShell 报错:因为在此系统上禁止运行脚本。有关详细信息

PowerShell 报错:因为在此系统上禁止运行脚本。有关详细信息 Import-Module : 无法加载文件 D:\\Documents\WindowsPowerShell\Modules\posh-git\1.1.0\posh-git.psm1,因为在此系统上禁止运行脚本。有关详细信息,请参阅 https:/go.microsoft.…