补充说明:

当参与层级控制的元素是点型元素时,是无法参与ZIndex层级控制的,此时可以换个解决方案

1.给不同的高度值实现,元素间的层级控制覆盖

import * as mars3d from "mars3d"export let map // mars3d.Map三维地图对象
export let graphicLayer // 矢量图层对象// 需要覆盖config.json中地图属性参数(当前示例框架中自动处理合并)
export const mapOptions = {scene: {center: { lat: 24.688611, lng: 119.260277, alt: 1673759, heading: 348, pitch: -69 }}
}// 初始化地图业务,生命周期钩子函数(必须),框架在地图初始化完成后自动调用该函数
export function onMounted(mapInstance) {map = mapInstance // 记录mapaddDemoLayer1()addDemoLayer2()
}async function addDemoLayer1() {graphicLayer1 = new mars3d.layer.GraphicLayer({})map.addLayer(graphicLayer1)const res = await mars3d.Util.fetchJson({ url: "https://data.mars3d.cn/file/apidemo/mudi.json" })for (let i = 0; i < 50; i++) {const item = res.data[i]const label = new mars3d.graphic.CircleEntity({position: [item.lng, item.lat,200],style: {radius: 480.0,materialType: mars3d.MaterialType.Water,materialOptions: {normalMap: "https://data.mars3d.cn/img/textures/waterNormals.jpg", // 水正常扰动的法线图frequency: 80.0, // 控制波数的数字。animationSpeed: 0.02, // 控制水的动画速度的数字。amplitude: 5.0, // 控制水波振幅的数字。specularIntensity: 0.8, // 控制镜面反射强度的数字。baseWaterColor: "#006ab4", // rgba颜色对象基础颜色的水。#00ffff,#00baff,#006ab4blendColor: "#006ab4" // 从水中混合到非水域时使用的rgba颜色对象。}},attr: item,flyTo: true})graphicLayer1.addGraphic(label)}
}function addDemoLayer2() {const singleDigitPins = {}// 创建矢量数据图层(业务数据图层)graphicLayer = new mars3d.layer.BusineDataLayer({url: "https://data.mars3d.cn/file/apidemo/mudi.json",dataColumn: "data", // 数据接口中对应列表所在的取值字段名lngColumn: "lng",latColumn: "lat",altColumn: "z",// 点的聚合配置cluster: {enabled: true,pixelRange: 20,image: async function (count, result) {const key = "type1-" + count // 唯一标识,不同图层需要设置不一样let image = singleDigitPins[key]if (image) {return image // 当前页面变量有记录}image = await localforage.getItem(key)if (image) {singleDigitPins[key] = imagereturn image // 浏览器客户端缓存有记录}image = await getClusterImage(count) // 生成图片singleDigitPins[key] = image // 记录到当前页面变量,未刷新页面时可直接使用localforage.setItem(key, image) // 记录到浏览器客户端缓存,刷新页面后也可以继续复用return image}},symbol: {type: "billboard",styleOptions: {image: "https://data.mars3d.cn/img/marker/mark-blue.png",width: 25,height: 34, // billboard聚合必须有width、heighthorizontalOrigin: Cesium.HorizontalOrigin.CENTER,verticalOrigin: Cesium.VerticalOrigin.BOTTOM,scaleByDistance: new Cesium.NearFarScalar(1000, 0.7, 5000000, 0.3),label: {text: "{text}",font_size: 19,color: Cesium.Color.AZURE,outline: true,outlineColor: Cesium.Color.BLACK,outlineWidth: 2,horizontalOrigin: Cesium.HorizontalOrigin.LEFT,verticalOrigin: Cesium.VerticalOrigin.BOTTOM,pixelOffset: new Cesium.Cartesian2(10, 0), // 偏移量distanceDisplayCondition: new Cesium.DistanceDisplayCondition(0.0, 80000)}}}})map.addLayer(graphicLayer)bindLayerEvent(graphicLayer)
}
function bindLayerEvent() {graphicLayer.on(mars3d.EventType.clusterStop, function (event) {console.log("聚合发生了变化,并渲染完成", event)})// 单击事件graphicLayer.on(mars3d.EventType.click, function (event) {console.log("你单击了", event)if (map.camera.positionCartographic.height > 90000) {const graphic = event.graphic// graphic.closePopup()if (graphic?.cluster) {// 单击了聚合的点console.log("单击了聚合的点", graphic.graphics)} else {// 单击了具体的点对象const position = graphic.positionShowmap.flyToPoint(position, {radius: 5000, // 距离目标点的距离duration: 4,complete: function (e) {// 飞行完成回调方法// graphic.openPopup()}})}}})graphicLayer.bindPopup(function (event) {if (event.graphic?.cluster) {const graphics = event.graphic.graphics // 对应的grpahic数组,可以自定义显示if (graphics) {const names = []for (let index = 0; index < graphics.length; index++) {names.push(graphics[index].attr.text)}const inthtml = `单击了聚合点(${graphics.length}个):<br/>${names.join(",")}`return inthtml}}const item = event.graphic?.attrif (!item) {return false}const inthtml = `<table style="width: auto;"><tr><th scope="col" colspan="2" style="text-align:center;font-size:15px;">${item.text} </th></tr><tr><td>省:</td><td>${item.province}</td></tr><tr><td>市:</td> <td>${item.city}</td></tr><tr><td>县/区:</td> <td>${item.district}</td></tr><tr><td>地址:</td> <td>${item.address}</td></tr><tr><td>视频:</td> <td><video src='http://data.mars3d.cn/file/video/lukou.mp4' controls autoplay style="width: 300px;" ></video></td></tr></table>`return inthtml})
}// 生成聚合图标,支持异步
async function getClusterImage(count) {let colorInif (count < 10) {colorIn = "rgba(110, 204, 57, 0.6)"} else if (count < 100) {colorIn = "rgba(240, 194, 12,  0.6)"} else {colorIn = "rgba(241, 128, 23,  0.6)"}const radius = 40const thisSize = radius * 2const circleCanvas = document.createElement("canvas")circleCanvas.width = thisSizecircleCanvas.height = thisSizeconst circleCtx = circleCanvas.getContext("2d", { willReadFrequently: true })circleCtx.fillStyle = "#ffffff00"circleCtx.globalAlpha = 0.0circleCtx.fillRect(0, 0, thisSize, thisSize)// 圆形底色circleCtx.globalAlpha = 1.0circleCtx.beginPath()circleCtx.arc(radius, radius, radius, 0, Math.PI * 2, true)circleCtx.closePath()circleCtx.fillStyle = colorIncircleCtx.fill()// 数字文字const text = count + "个"circleCtx.font = radius * 0.6 + "px bold normal" // 设置字体circleCtx.fillStyle = "#ffffff" // 设置颜色circleCtx.textAlign = "center" // 设置水平对齐方式circleCtx.textBaseline = "middle" // 设置垂直对齐方式circleCtx.fillText(text, radius, radius) // 绘制文字(参数:要写的字,x坐标,y坐标)return circleCanvas.toDataURL("image/png") // getImage方法返回任意canvas的图片即可
}// 释放当前地图业务的生命周期函数,具体项目中时必须写onMounted的反向操作(如解绑事件、对象销毁、变量置空)
export function onUnmounted() {graphicLayer.remove()graphicLayer = nullmap = null
}// 计算贴地高度示例代码,可以将获取到的高度更新到数据库内,后续不用重复计算。
export function getDataSurfaceHeight() {if (graphicLayer.length === 0) {globalMsg("数据尚未加载成功!")return}showLoading()// 对图层内的数据做贴地运算,自动得到贴地高度graphicLayer.autoSurfaceHeight({ exact: true }).then((graphics) => {hideLoading()const arr = []for (let i = 0, len = graphics.length; i < len; i++) {const graphic = graphics[i]const point = graphic.pointarr.push({...graphic.attr,lat: point.lat,lng: point.lng,z: point.alt})}mars3d.Util.downloadFile("point.json", JSON.stringify({ data: arr }))})
}export function enabledAggressive(val) {graphicLayer.clusterEnabled = val
}export function layerShowChange(val) {graphicLayer.show = val
}

覆盖效果

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

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

uniapp 百家云直播插件打包失败

打包错误日志 Android自有证书 打包失败 错误日志: https://app.liuyingyong.cn/build/errorLog/cf41a610-effe-11ef-88db-05262d4c3e5d原因&#xff1a;需要导入插件依赖 依赖地址&#xff1a;https://ext.dcloud.net.cn/plugin?id16289 百家云直播插件地址 直播插…

【C++】”如虎添翼“:模板初阶

泛型编程&#xff1a; C中一种使用模板来实现代码重用和类型安全的编程范式。它允许程序员编写与数据类型无关的代码&#xff0c;从而可以用相同的代码逻辑处理不同的数据类型。模板是泛型编程的基础 模板分为两类&#xff1a; 函数模板&#xff1a;代表了一个函数家族&#x…

十五、多态与虚函数

十五、多态与虚函数 15.1 引言 面向对象编程的基本特征&#xff1a;数据抽象&#xff08;封装&#xff09;、继承、多态基于对象&#xff1a;我们创建类和对象&#xff0c;并向这些对象发送消息多态&#xff08;Polymorphism&#xff09;&#xff1a;指的是相同的接口、不同的…

点云特征提取的两大经典范式:Voxel-based 与 Pillar-based

点云特征提取的两大经典范式&#xff1a;Voxel-based 与 Pillar-based 在点云处理领域&#xff0c;尤其是针对 3D 目标检测任务&#xff0c;特征提取是核心环节之一。目前&#xff0c;Voxel-based&#xff08;体素化&#xff09;和 Pillar-based&#xff08;柱状化&#xff09…

前苹果首席设计官回顾了其在苹果的设计生涯、公司文化、标志性产品的背后故事

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

web 自动化之 selenium 元素四大操作三大切换等待

文章目录 一、元素的四大操作二、三大切换&等待1、切换窗口:当定位的元素不在当前窗口&#xff0c;则需要切换窗口2、切换iframe&#xff1a;当定位的元素在frame/iframe&#xff0c;则需要切换3、切换弹出窗口 一、元素的四大操作 1、输入 2、点击 3、获取文本 4、获取属…

window server 2012安装sql server2008 r2

执行sql server2008 r2安装目录下的setup 选择运行程序而不获取帮助 然后就是让人绝望的 只能先搞这个了&#xff0c;F*微软&#xff0c;自家软件不让正常安装 打开服务器管理器->添加角色和功能->选择Web 服务&#xff08;IIS&#xff09;->添加.NET Framework3.5 然…

【K8S学习之生命周期钩子】详细了解 postStart 和 preStop 生命周期钩子

0. 参考 Kubernetes容器生命周期 —— 钩子函数详解&#xff08;postStart、preStop&#xff09; - 人艰不拆_zmc - 博客园详解Kubernetes Pod优雅退出 - 人艰不拆_zmc - 博客园 1. Kubernetes 生命周期钩子概述 在 Kubernetes 中&#xff0c;生命周期钩子&#xff08;Lifec…

测试文章标题01

模型上下文协议&#xff08;Model Context Protocol, MCP&#xff09;深度解析 一、MCP的核心概念 模型上下文协议&#xff08;Model Context Protocol, MCP&#xff09;是一种用于规范机器学习模型与外部环境交互的标准化框架。其核心目标是通过定义统一的接口和数据格式&am…

kubuntu系统详解

Kubuntu 系统深度解析&#xff08;从系统架构到用户体验&#xff09; 一、定位与核心特性 Kubuntu 是 Ubuntu 的官方 KDE 衍生版&#xff0c;基于 Ubuntu 的稳定底层&#xff08;Debian 技术栈&#xff09;&#xff0c;搭载 KDE Plasma 桌面环境&#xff0c;主打 “功能丰富、…

cURL:通过URL传输数据的命令行工具库介绍

文章目录 1. 什么是 curl&#xff1f;2. 下载与安装 curl3. curl 的常见用法3.1 获取网页内容3.2 下载文件3.3 发送 POST 请求&#xff08;带表单数据&#xff09;3.4 发送带 JSON 的 POST 请求 1. 什么是 curl&#xff1f; cURL&#xff08;CommandLine URL&#xff09;是非常…

从零搭建AI工作站:Gemma3大模型本地部署+WebUI配置全套方案

文章目录 前言1. 安装Ollama2.Gemma3模型安装与运行3. 安装Open WebUI图形化界面3.1 Open WebUI安装运行3.2 添加模型3.3 多模态测试 4. 安装内网穿透工具5. 配置固定公网地址总结 前言 如今各家的AI大模型厮杀得如火如荼&#xff0c;每天都有新的突破。今天我要给大家安利一款…

Element Plus对话框(ElDialog)全面指南:打造灵活弹窗交互

&#x1f4cc; 开篇导语 对话框是Web应用中实现用户交互的核心组件之一&#xff0c;常用于信息确认、表单提交或详情展示。Element Plus的ElDialog组件以高扩展性和优雅动效著称&#xff0c;支持高度定制化开发。本文将从基础配置到进阶技巧&#xff0c;手把手教你掌握对话框组…

解决WSL、Ubuntu的.ico图标不正确显示缩略图

解决WSL、Ubuntu的.ico图标不正确显示缩略图 问题描述 Win10系统中由于更新了某些软件&#xff0c;篡改了默认的图像显示软件&#xff0c;导致WSL等软件未能成功显示图标&#xff0c;表现如下&#xff1a; 解决方法 将ico文件的默认打开方式更改为“画图”&#xff0c;如下…

[数据结构高阶]并查集初识、手撕、可以解决哪类问题?

标题&#xff1a;[数据结构高阶]并查集初识、手撕、可以解决哪类问题&#xff1f; 水墨不写bug 文章目录 一、认识并查集二、模拟实现并查集三、用并查集解决问题1、[省份的数量](https://leetcode.cn/problems/number-of-provinces/)2、[等式方程的可满足性](https://leetcode…

如何快速入门大模型?

学习大模型的流程是什么 &#xff1f; 提示词工程&#xff1a;只需掌握提问技巧即可使用大模型&#xff0c;通过优化提问方式获得更精准的模型输出套壳应用开发&#xff1a;在大模型生态上开发业务层产品&#xff08;如AI主播、AI小助手等&#xff09;&#xff0c;只需调用API…

《AI大模型应知应会100篇》第59篇:Flowise:无代码搭建大模型应用

第59篇&#xff1a;Flowise&#xff1a;无代码搭建大模型应用 摘要&#xff1a;本文将详细探讨 Flowise 无代码平台的核心特性、使用方法和最佳实践&#xff0c;提供从安装到部署的全流程指南&#xff0c;帮助开发者和非技术用户快速构建复杂的大模型应用。文章结合实战案例与配…

python打卡day23@浙大疏锦行

知识回顾: 1. 转化器和估计器的概念 2. 管道工程 3. ColumnTransformer和Pipeline类 作业&#xff1a; 整理下全部逻辑的先后顺序&#xff0c;看看能不能制作出适合所有机器学习的通用pipeline 一、导入数据库 import pandas as pd import numpy as np import matplo…

Vue.js框架的优缺点

别再让才华被埋没&#xff0c;别再让github 项目蒙尘&#xff01;github star 请点击 GitHub 在线专业服务直通车GitHub赋能精灵 - 艾米莉&#xff0c;立即加入这场席卷全球开发者的星光革命&#xff01;若你有快速提升github Star github 加星数的需求&#xff0c;访问taimili…

交易流水表的分库分表设计

交易流水表的分库分表设计需要结合业务特点、数据增长趋势和查询模式&#xff0c;以下是常见的分库分表策略及实施建议&#xff1a; 一、分库分表核心目标 解决性能瓶颈&#xff1a;应对高并发写入和查询压力。数据均衡分布&#xff1a;避免单库/单表数据倾斜。简化运维&#…