GraphicLayer與BusineDataLayer層級控制

補充說明:

當參與層級控制的元素是點型元素時,是無法參與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;避免單庫/單表數據傾斜。簡化運維&#…