| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418 |
- <template>
- <div id="loading" class="dataLoading" v-if="loading">
- <span class="loadText">数据加载中...</span>
- </div>
- <div class="mapBox">
- <div id="cesiumContainer" style="width: 100%; height: 100vh"></div>
- <div :class="!menuComTStyB ? 'menuComTSty' : 'menuComT'" v-if="0">
- <menuCom
- :showbasemap="false"
- :showwindspeed="false"
- :showcloud="false"
- :showrainfall="false"
- :showtemperature="false"
- :showcity="false"
- :showwind="false"
- :showexit="true"
- :showwindModel="true"
- @handleWindModel="showwindmodel"
- @handleInit="handleInitView"
- @handleExit="switchLayer"
- />
- </div>
- <el-drawer
- v-model="windDrawer"
- direction="rtl"
- class="windModelDrawer"
- :before-close="handleClose"
- >
- <template #header>
- <h3 style="font-weight: bold">{{ windDrawerHeader }}</h3>
- </template>
- <template #default>
- <div class="windDrawerCla">
- <div class="line" v-if="!showModelMsg">
- <div class="leftContent">
- <span>{{ windDrawerTitle }}</span>
- </div>
- </div>
- <div class="jcxx" v-if="showBasicMsg">
- <windHome :modelValItem="modelVal" />
- </div>
- <div class="spjk" v-if="showVideoMsg">
- <!-- <iframe
- src="/public/static/windVideo.mp4"
- frameborder="0"
- style="width: 100%; height: 100%"
- ></iframe> -->
- <video ref="videoPlayer" controls width="95%" muted autoplay>
- <source src="/static/windVideo.mp4" type="video/mp4" />
- </video>
- </div>
- <div class="gzck" v-if="showProblemMsg">
- <windPro />
- </div>
- <div class="third" v-if="showModelMsg">
- <ModelUnpack
- :modelUnpackType="modelUnpackType"
- :showModelMsg="showModelMsg"
- />
- </div>
- </div>
- </template>
- </el-drawer>
- <comModelDialog
- :showcomModelDia="showcomModelDia"
- :modelVal="modelVal"
- @showDia="showComDia"
- />
- <windView
- v-if="showWindDetail"
- @coverOnChange="coverOnChange"
- :currentHeight="currentHeight"
- @showDetail="menuComTSty"
- @backStations="backStations"
- />
- </div>
- </template>
- <script>
- import * as Cesium from "../../Cesium";
- import "../../Cesium/Widgets/widgets.css";
- import fjMYLonLatJson from "../fjLonLatJson/fj_MY.json"; //迈越风电场
- import fjWHZLonLatJson from "../fjLonLatJson/fj_WHZ.json"; //京能旺海庄
- import fjYPLLonLatJson from "../fjLonLatJson/fj_YPL.json"; //京能营盘梁
- import fjSMSLonLatJson from "../fjLonLatJson/fj_SMS.json"; //京能苏木山
- import allStationJson from "./allStationJson.json";
- import basicGeoJson from "../../assets/geoJson/basic.json";
- import comModelDialog from "@/components/comModelDialog.vue";
- import windView from "./windView.vue";
- import menuCom from "../menuCom.vue";
- import cloudJson from "/public/static/exportData/cloud/layer.json";
- import rainJson from "/public/static/exportData/rain/layer.json";
- import tempJson from "/public/static/exportData/tmp/layer.json";
- // import bw from "@/assets/windimgs/fanSvg/bw.svg"
- //风场展示图标
- import fc from "@/assets/windimgs/fanSvg/fc.png";
- //火电展示图标
- import hd from "@/assets/windimgs/fanSvg/hd.png";
- //光伏电站展示图标
- import gf from "@/assets/windimgs/fanSvg/gf.png";
- //故障
- import gz from "@/assets/windimgs/fanSvg/gz.svg";
- //待机
- import dj from "@/assets/windimgs/fanSvg/dj.svg";
- //检修
- import jx from "@/assets/windimgs/fanSvg/jx.svg";
- //限电
- import xd from "@/assets/windimgs/fanSvg/xd.svg";
- //离线
- import lx from "@/assets/windimgs/fanSvg/lx.svg";
- //受累
- import sl from "@/assets/windimgs/fanSvg/sl.svg";
- //动图使用柱子和扇叶
- import bwzhu from "@/assets/windimgs/fanSvg/bwzhu.svg";
- import bwshan from "@/assets/windimgs/fanSvg/bwshan.png";
- import windHome from "@/components/windHome/index.vue";
- import windPro from "@/components/windProDetail/windProblem.vue";
- import ModelUnpack from "@/components/modelUnpack.vue";
- import { WindLayer } from "cesium-wind";
- import windGridData from "./windGridData.json";
- import AdvancedBillboardGenerator from "@/tools/lightsign.js";
- export default {
- name: "windMap2D",
- components: {
- comModelDialog,
- windView,
- menuCom,
- windHome,
- windPro,
- ModelUnpack,
- },
- data() {
- return {
- loading: true,
- showAllWindFromStation: [],
- restLatLon: [
- {
- longitude: 114.48789,
- latitude: 35.32916,
- name: "MYFDC",
- },
- {
- longitude: 112.88355172,
- latitude: 40.46617836,
- name: "JNWHZ",
- },
- {
- longitude: 112.5270545,
- latitude: 40.35920334,
- name: "JNYPL",
- },
- {
- longitude: 112.69922452,
- latitude: 40.31857399,
- name: "JNSMS",
- },
- ],
- viewer: null,
- windLayer: null, // 风场图
- windLayerTimmer: null, // 风场图计时器
- cloudImagesLayer: [], // 卫星云图
- cloudLayer: null, // 卫星云图
- cloudintervalId: null,
- rainImagesLayer: [], // 降雨图
- rainLayer: null, // 降雨图
- rainintervalId: null, // 降雨图
- tempImagesLayer: [], //温度图
- temperatureLayer: null, //温度图
- tempintervalId: null, //温度图
- showcomModelDia: false,
- currentHeight: 0,
- modelVal: null,
- menuComTStyB: false,
- modelUnpackType: "fengji",
- windDrawer: false,
- windDrawerTitle: "",
- windDrawerHeader: "",
- showBasicMsg: false,
- showVideoMsg: false,
- showProblemMsg: false,
- showModelMsg: false,
- showWindDetail: true,
- allStationentitys: [],
- allWindEntitys: [],
- urlTiles: "/public/static/tiles/{z}/{x}/{y}.jpg",
- };
- },
- mounted() {
- this.initCesium();
- setTimeout(() => {
- this.loading = false;
- }, 1000);
- },
- methods: {
- async initCesium() {
- const box = document.getElementById("cesiumContainer");
- const viewer = new Cesium.Viewer(box, {
- geocoder: false, // 地址搜索控件
- homeButton: false, // 返回地图初始位置控件
- infoBox: false, // 地图默认的信息控件
- sceneModePicker: false, // 场景模式切换控件
- baseLayerPicker: false, // 底图切换控件
- navigationHelpButton: false, // 帮助控件
- animation: false, // 动画控制控件
- timeline: false, // 时间线控件
- fullscreenButton: false, // 全屏按钮控件
- // imageryProvider: true, // 是否显示 Cesium 默认地图的底图
- vrButton: false,
- selectionIndicator: false,
- shouldAnimate: true,
- });
- const imageryProvider = new Cesium.UrlTemplateImageryProvider({
- // minimumLevel: 11,
- maximumLevel: 18,
- // url: this.urlTiles,
- // url: "/static/ditu/{z}/{x}/{y}.png",
- url: "https://webst02.is.autonavi.com/appmaptile?style=6&x={x}&y={y}&z={z}",
- credit: "影像地图",
- });
- imageryProvider.alpha = 0.55; // 透明度
- imageryProvider.brightness = 1; // 亮度
- imageryProvider.contrast = 1; // 对比度
- viewer.imageryLayers.addImageryProvider(imageryProvider);
- viewer._cesiumWidget._creditContainer.style.display = "none";
- // this.csceneElliposid(viewer)
- this.viewer = viewer;
- // 展示场站
- // this.showAllStation(viewer)
- // 展示风机
- this.showWindFromStation(viewer);
- this.initGeoJsonData();
- },
- // 初始化 geoJson 数据
- async initGeoJsonData() {
- // 创建GeoJSON数据源
- await new Cesium.GeoJsonDataSource.load(basicGeoJson, {
- stroke: Cesium.Color.GRAY, // 边界线颜色
- fill: Cesium.Color.BLACK.withAlpha(0), // 填充颜色
- strokeWidth: 1, // 边界线宽度
- markerSymbol: "?", // 点要素的符号
- clampToGround: true, // 贴地
- }).then((dataSource) => {
- // 添加到视图
- this.viewer.dataSources.add(dataSource);
- var entities = dataSource.entities.values;
- for (let i = 0; i < entities.length; i++) {
- let entity = entities[i];
- entity.polygon.hierarchy.getValue(Cesium.JulianDate.now()).positions;
- //单独设置线条样式
- var positions = entity.polygon.hierarchy._value.positions;
- entity.polyline = {
- positions: positions,
- width: 1,
- outline: false,
- };
- }
- // 添加中文标签图层
- const labelLayer = new Cesium.LabelCollection();
- this.viewer.scene.primitives.add(labelLayer);
- const cities = [];
- basicGeoJson?.features?.forEach((ele) => {
- if (Array.isArray(ele.properties.centroid)) {
- const name = ele.properties.name;
- const lon = ele.properties.centroid[0];
- const lat = ele.properties.centroid[1];
- cities.push({ name, lon, lat });
- }
- });
- cities.forEach((city, index) => {
- labelLayer.add({
- id: index,
- name: "cityLabel",
- position: Cesium.Cartesian3.fromDegrees(city.lon, city.lat, 10),
- text: city.name,
- font: 'bold 14px "Microsoft YaHei", sans-serif',
- fillColor: Cesium.Color.fromCssColorString("#000"),
- outlineColor: Cesium.Color.WHITE,
- outlineWidth: 2,
- style: Cesium.LabelStyle.FILL_AND_OUTLINE,
- pixelOffset: new Cesium.Cartesian2(0, 0), // 设置为0
- horizontalOrigin: Cesium.HorizontalOrigin.CENTER, // 水平居中
- verticalOrigin: Cesium.VerticalOrigin.CENTER, // 垂直居中
- });
- });
- });
- },
- backStations() {
- this.showWindDetail = false;
- this.allWindEntitys.forEach(({ entity, handler }) => {
- this.viewer.entities.remove(entity); // 移除实体
- if (!handler.isDestroyed()) {
- handler.destroy(); // 销毁事件处理器(关键!)
- }
- });
- this.allWindEntitys = [];
- if (this.viewer && this.viewer.destroy) {
- this.viewer.destroy();
- this.viewer = null;
- }
- // this.initCesium();
- // this.showAllStation(this.viewer)
- },
- // 展示所有风场
- showAllStation(viewer) {
- allStationJson.station.forEach((e, index) => {
- if (e.energytype === "Wind") {
- this.showStationFn(viewer, e, index, fc);
- } else if (e.energytype === "Fire") {
- this.showStationFn(viewer, e, index, hd);
- } else {
- this.showStationFn(viewer, e, index, gf);
- }
- });
- this.resetAllStationViewport();
- },
- // 根据状态展示不同颜色风机贴图
- showStationFn(viewer, e, index, images) {
- const position = Cesium.Cartesian3.fromDegrees(e.longitude, e.latitude);
- const entity = viewer.entities.add({
- id: index,
- position, // 模型位置
- billboard: {
- image: images, // 也可以是 SVG 路径,如 'icon.svg'
- scale: 0.5,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- horizontalOrigin: Cesium.HorizontalOrigin.CENTER,
- // 模型贴地
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND,
- },
- label: {
- text: e.plantname,
- font: "14px sans-serif",
- fillColor: Cesium.Color.fromBytes(255, 255, 255),
- heightReference: Cesium.HeightReference.CLAMP_TO_GROUND,
- },
- });
- let that = this;
- const handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);
- handler.setInputAction(function (movement) {
- var position = movement.position;
- var pickedObject = viewer.scene.pick(position);
- if (pickedObject && pickedObject.id.id === index) {
- console.log("你点击了标签或模型!", entity);
- console.log("选中风场或新能源场", e.plantname);
- that.showWindDetail = true;
- that.allStationentitys.forEach(({ entity, handler }) => {
- viewer.entities.remove(entity); // 移除实体
- if (!handler.isDestroyed()) {
- handler.destroy(); // 销毁事件处理器(关键!)
- }
- });
- that.allStationentitys = [];
- that.showWindFromStation(viewer);
- }
- }, Cesium.ScreenSpaceEventType.LEFT_CLICK);
- that.allStationentitys.push({ entity, handler });
- },
- // 展示所选风场的风机
- showWindFromStation(viewer) {
- let stationName = this.$route.query.nameEn;
- let fjLonLatJson = [];
- if (stationName === "MYFDC") {
- fjLonLatJson = fjMYLonLatJson;
- } else if (stationName === "JNWHZ") {
- fjLonLatJson = fjWHZLonLatJson;
- } else if (stationName === "JNYPL") {
- fjLonLatJson = fjYPLLonLatJson;
- } else if (stationName === "JNSMS") {
- fjLonLatJson = fjSMSLonLatJson;
- }
- fjLonLatJson.data.forEach((e, index) => {
- if (e.status) {
- if (e.status === 1) {
- this.showStatuswind(viewer, e, dj);
- } else if (e.status === 2) {
- this.showStatuswind(viewer, e, gz);
- } else if (e.status === 3) {
- this.showStatuswind(viewer, e, jx);
- } else if (e.status === 4) {
- this.showStatuswind(viewer, e, xd);
- } else if (e.status === 5) {
- this.showStatuswind(viewer, e, lx);
- } else if (e.status === 6) {
- this.showStatuswind(viewer, e, sl);
- } else {
- //并网风机
- this.showAnimatewind(viewer, e);
- }
- }
- });
- this.resetWindViewport();
- },
- // 根据状态展示不同颜色风机贴图
- showStatuswind(viewer, e, type, index) {
- this.addSvg(
- viewer,
- type,
- e.longitude,
- e.latitude,
- e,
- Math.random().toFixed(4) * 10000
- );
- },
- // 风机柱与扇叶分开展示转动效果贴图
- showAnimatewind(viewer, e, index) {
- this.addSvgs(
- viewer,
- bwshan,
- e.longitude,
- e.latitude,
- e,
- Math.random().toFixed(3) * 1000
- );
- this.addSvg(
- viewer,
- bwzhu,
- e.longitude,
- e.latitude,
- e,
- Math.random().toFixed(3) * 2000
- );
- },
- //添加svg或png贴图
- addSvg(viewer, uri, lon, lat, val, index) {
- let that = this;
- let ids = that.generateUniqueId(val.id);
- const position = Cesium.Cartesian3.fromDegrees(lon, lat);
- // 使用高级灯牌生成器
- const advancedGenerator = new AdvancedBillboardGenerator();
- let statusItems = [];
- const statusArray = [
- { label: "风速", value: "10m/s" },
- { label: "状态", value: "测试" },
- { label: "转速", value: "1000p" },
- { label: "功率", value: "50kW" },
- // { label: "其他参数A", value: "...." },
- // { label: "其他参数B", value: "...." },
- // { label: "其他参数C", value: "...." },
- // { label: "其他参数D", value: "...." },
- // { label: "其他参数E", value: "...." },
- // { label: "其他参数F", value: "...." },
- ];
- // for (let i = 0; i <= this.randomNum(1, 9); i++) {
- // statusItems.push(statusArray[i]);
- // }
- statusItems = statusArray;
- console.log("statusItems====>>>>", statusItems);
- // const billboardImage = advancedGenerator.generateAdvancedBillboard({
- // title: val.name,
- // statusItems,
- // borderGradient: ["#00e5ff", "#2979ff"],
- // });
- // const entityxy = viewer.entities.add({
- // name: val.name,
- // position,
- // billboard: {
- // image: billboardImage,
- // scale: 1,
- // verticalOrigin: Cesium.VerticalOrigin.BOTTOM, // 原来已经是CENTER,现在改为BOTTOM
- // pixelOffset: new Cesium.Cartesian2(80, -50), // 原来是-20,现在改为30,向上移动
- // eyeOffset: new Cesium.Cartesian3(0, 0, 0), // 保持固定大小
- // // heightReference: Cesium.HeightReference.NONE,
- // },
- // });
- const btn = document.getElementById("windBtn");
- btn.addEventListener("click", function (event) {
- entityxy.show = !entityxy.show;
- });
- const entity = viewer.entities.add({
- id: ids,
- position, // 模型位置
- billboard: {
- image: uri, // 也可以是 SVG 路径,如 'icon.svg'
- scale: 0.5,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- horizontalOrigin: Cesium.HorizontalOrigin.CENTER,
- // 模型贴地
- // heightReference: Cesium.HeightReference.CLAMP_TO_GROUND,
- },
- // label: {
- // // text: val.name ? val.name : val.plantname,
- // text: `${val.name}\n风速: 10m/s\n状态: 测试`,
- // font: '14px sans-serif',
- // fillColor: Cesium.Color.fromBytes(255, 255, 255),
- // heightReference: Cesium.HeightReference.CLAMP_TO_GROUND,
- // pixelOffset: val.name === 'F10号风机' ? new Cesium.Cartesian2(50, -20) : new Cesium.Cartesian2(0, 20)
- // }
- });
- // 创建事件处理器
- const handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);
- handler.setInputAction(function (movement) {
- var position = movement.position;
- var pickedObject = viewer.scene.pick(position);
- if (pickedObject && pickedObject.id.id === ids) {
- console.log("你点击了标签或模型!", entity);
- console.log("标签或模型数据!", val);
- that.modelVal = val;
- // 找到实体,显示包含实体信息的弹框
- that.showRightClickPopup(position, val);
- return;
- }
- }, Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- this.allWindEntitys.push({ entity, handler });
- },
- randomNum(minNum, maxNum) {
- switch (arguments.length) {
- case 1:
- return parseInt(Math.random() * minNum + 1, 10);
- case 2:
- return parseInt(Math.random() * (maxNum - minNum + 1) + minNum, 10);
- default:
- return 0;
- }
- },
- //添加svg或png贴图
- addSvgs(viewer, uri, lon, lat, val, index) {
- let that = this;
- let ids = that.generateUniqueId(val.id);
- const position = Cesium.Cartesian3.fromDegrees(lon, lat);
- const entity = viewer.entities.add({
- id: ids,
- position, // 模型位置
- billboard: {
- image: uri, // 也可以是 SVG 路径,如 'icon.svg'
- scale: 0.5,
- pixelOffset: new Cesium.Cartesian2(0, -15),
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
- horizontalOrigin: Cesium.HorizontalOrigin.CENTER,
- // 模型贴地
- // heightReference: Cesium.HeightReference.CLAMP_TO_GROUND,
- // 核心:使用 CallbackProperty 实现旋转动画
- rotation: new Cesium.CallbackProperty(function (time) {
- // 每 3 秒转一圈(可调速度)
- const seconds = time.secondsOfDay;
- const angle = Cesium.Math.toRadians(((seconds % 3) * -360) / 3); // 每3秒一圈
- return angle;
- }, false),
- // 确保绕中心旋转
- rotationAlignment: Cesium.HeightReference.CENTER,
- alignedAxis: Cesium.Cartesian3.UNIT_Z,
- },
- });
- // 创建事件处理器
- const handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);
- handler.setInputAction(function (movement) {
- var position = movement.position;
- var pickedObject = viewer.scene.pick(position);
- if (pickedObject && pickedObject.id.id === ids) {
- console.log("你点击了标签或模型!", entity);
- console.log("标签或模型数据!", val);
- that.modelVal = val;
- // 找到实体,显示包含实体信息的弹框
- that.showRightClickPopup(position, val);
- return;
- }
- }, Cesium.ScreenSpaceEventType.RIGHT_CLICK);
- this.allWindEntitys.push({ entity, handler });
- },
- // 右键展示元素
- showRightClickPopup(screenPosition, val) {
- // 创建或获取弹框元素
- var popup = document.getElementById("rightClickPopup");
- if (!popup) {
- popup = document.createElement("div");
- popup.id = "rightClickPopup";
- popup.style.position = "absolute";
- // popup.style.backgroundColor = 'white';
- popup.style.border = "1px solid rgba(255, 255, 255, 0.2)";
- popup.style.borderRadius = "4px";
- popup.style.padding = "10px";
- popup.style.boxShadow = "0 2px 10px rgba(0,0,0,0.2)";
- popup.style.backdropFilter = `blur(10px)`;
- popup.style.zIndex = "1000";
- popup.style.pointerEvents = "auto"; // 确保弹框可交互
- // 添加一个最小宽度,避免内容过短
- popup.style.minWidth = "100px";
- // 可选:添加箭头指向点击点
- // 这需要更复杂的 CSS 或额外的 DOM 元素
- document.body.appendChild(popup);
- }
- // <span class="popup-menu-item" data-message-type="model" style="cursor:pointer">模型解构</span>
- let content = `
- <div style="display: flex;gap: 10px;flex-direction: column;text-align: center;color: #fff">
- <span class="popup-menu-item" data-message-type="basic" style="cursor:pointer">基本信息</span>
- <span class="popup-menu-item" data-message-type="video" style="cursor:pointer">视频监控</span>
- <span class="popup-menu-item" data-message-type="problem" style="cursor:pointer">故障详情</span>
- </div>
- `;
- // 设置弹框内容
- popup.innerHTML = content;
- // --- 关键修正:准确计算弹框位置 ---
- // 1. 获取 Cesium 画布 (Canvas) 相对于视口 (viewport) 的位置
- var canvas = this.viewer.scene.canvas;
- var canvasRect = canvas.getBoundingClientRect();
- // console.log('Canvas Rect:', canvasRect); // 调试用
- // 2. 计算弹框左上角在页面中的绝对 X 坐标
- // screenPosition.x 是相对于画布左上角的 X 偏移
- // canvasRect.left 是画布左上角相对于浏览器视口左上角的 X 偏移
- // window.pageXOffset 是页面水平滚动的距离
- var popupLeft = canvasRect.left + screenPosition.x + window.pageXOffset;
- // 3. 计算弹框左上角在页面中的绝对 Y 坐标
- var popupTop = canvasRect.top + screenPosition.y + window.pageYOffset;
- // --- 可选:添加偏移量,避免完全覆盖鼠标指针 ---
- // 例如,向下和向右偏移 10px
- var offsetX = 10;
- var offsetY = 10;
- popupLeft += offsetX;
- popupTop += offsetY;
- // --- 可选:边界检查,防止弹框超出屏幕 ---
- var popupWidth = popup.offsetWidth || 150; // 确保有宽度
- var popupHeight = popup.offsetHeight || 50; // 确保有高度
- var windowWidth = window.innerWidth;
- var windowHeight = window.innerHeight;
- // 如果弹框右边会超出窗口,则左移
- if (popupLeft + popupWidth > windowWidth) {
- popupLeft = windowWidth - popupWidth - 10; // 靠右留 10px 边距
- }
- // 如果弹框底边会超出窗口,则上移
- if (popupTop + popupHeight > windowHeight) {
- popupTop = windowHeight - popupHeight - 10; // 靠下留 10px 边距
- }
- // 如果左边超出 (不太可能,但安全起见)
- if (popupLeft < 0) popupLeft = 10;
- // 如果顶边超出
- if (popupTop < 0) popupTop = 10;
- // --- 设置最终位置 ---
- popup.style.left = popupLeft + "px";
- popup.style.top = popupTop + "px";
- // console.log('Popup Position:', { left: popupLeft, top: popupTop }); // 调试用
- // 显示弹框
- popup.style.display = "block";
- // --- 隐藏弹框的逻辑 (保持不变) ---
- function hidePopup(event) {
- // 检查点击是否发生在弹框内部,如果是,则不隐藏
- if (event && popup.contains(event.target)) {
- return;
- }
- popup.style.display = "none";
- document.removeEventListener("click", hidePopup);
- document.removeEventListener("keydown", keyDownHandler);
- }
- function keyDownHandler(event) {
- if (event.key === "Escape") {
- hidePopup();
- }
- }
- let that = this;
- that.showBasicMsg = false;
- that.showVideoMsg = false;
- that.showProblemMsg = false;
- that.showModelMsg = false;
- function popupMenuItemClick(event) {
- // 检查点击的是否是菜单项
- if (event.target.classList.contains("popup-menu-item")) {
- event.stopPropagation(); // 阻止冒泡,防止弹框立即关闭
- var messageType = event.target.dataset.messageType; // 获取 data-message-type
- console.log("点击了菜单项:", messageType);
- // 调用您的 showMessage 函数
- that.showMessage(messageType, val);
- hidePopup();
- // 可选:执行后关闭弹框
- // hideRightClickPopup();
- }
- }
- // 移除旧的监听器(避免重复绑定)
- document.removeEventListener("click", hidePopup);
- document.removeEventListener("click", popupMenuItemClick);
- document.removeEventListener("keydown", keyDownHandler);
- // 添加新的监听器
- document.addEventListener("click", hidePopup);
- document.addEventListener("click", popupMenuItemClick);
- document.addEventListener("keydown", keyDownHandler);
- },
- showMessage(type, val) {
- console.log("type===>>>", type);
- this.windDrawer = true;
- this.windDrawerHeader = val.name + "数据详情";
- if (type === "basic") {
- this.windDrawerTitle = "基础信息";
- this.showBasicMsg = true;
- } else if (type === "video") {
- this.windDrawerTitle = "视频监控";
- this.showVideoMsg = true;
- } else if (type === "problem") {
- this.windDrawerTitle = "故障查看";
- this.showProblemMsg = true;
- }
- // else {
- // this.windDrawerTitle = '模型解构'
- // this.showModelMsg = true
- // }
- },
- showwindmodel() {
- this.windDrawer = true;
- this.showBasicMsg = false;
- this.showVideoMsg = false;
- this.showProblemMsg = false;
- this.windDrawerHeader = "风机模型可视化解构说明";
- this.showModelMsg = true;
- },
- handleClose() {
- this.windDrawer = false;
- this.showBasicMsg = false;
- this.showVideoMsg = false;
- this.showProblemMsg = false;
- this.showModelMsg = false;
- },
- showComDia(val) {
- this.showcomModelDia = val;
- this.modelVal = null;
- },
- csceneElliposid(viewer) {
- let that = this;
- // 获取 scene 和 ellipsoid
- var scene = viewer.scene;
- var labels = viewer.scene.primitives.add(new Cesium.LabelCollection());
- // 创建 ScreenSpaceEventHandler
- var handler = new Cesium.ScreenSpaceEventHandler(scene.canvas);
- // 监听左键点击事件
- handler.setInputAction(async (click) => {
- // 获取点击位置的笛卡尔坐标
- var position = click.position;
- if (!position) return;
- // 使用 globe.pick 获取包含地形高度的坐标
- var ray = viewer.camera.getPickRay(position);
- var cartesian = viewer.scene.globe.pick(ray, viewer.scene);
- if (cartesian) {
- // 转换为地理坐标
- var cartographic = Cesium.Cartographic.fromCartesian(cartesian);
- var longitude = Cesium.Math.toDegrees(cartographic.longitude);
- var latitude = Cesium.Math.toDegrees(cartographic.latitude);
- var height = cartographic.height;
- // 格式化坐标
- var text = `经度: ${longitude.toFixed(6)}°\n纬度: ${latitude.toFixed(
- 6
- )}°`;
- // 创建一个标签
- var label = labels.add({
- position: cartesian,
- text: text,
- font: "14px monospace",
- fillColor: Cesium.Color.fromCssColorString("#1d70df"),
- // style: Cesium.LabelStyle.FILL_AND_OUTLINE,
- // outlineColor: Cesium.Color.BLACK,
- outlineWidth: 2,
- verticalOrigin: Cesium.VerticalOrigin.BOTTOM, // 标签在点的上方
- pixelOffset: new Cesium.Cartesian2(0, -20), // 向上偏移一点
- disableDepthTest: true, // 让标签始终可见(即使在地球背面)
- scale: 0.8,
- });
- // 5秒后移除标签
- setTimeout(function () {
- labels.remove(label);
- }, 5000);
- console.log(
- `点击坐标: ${longitude.toFixed(6)}, ${latitude.toFixed(
- 6
- )}, ${height.toFixed(2)}m`
- );
- }
- }, Cesium.ScreenSpaceEventType.LEFT_CLICK);
- },
- generateUniqueId(prefix = "id") {
- let idCounter = 0;
- return `${prefix}-${Date.now()}-${Math.random()
- .toString(36)
- .substr(2, 9)}-${idCounter++}`;
- },
- handleInitView() {
- if (this.showWindDetail) {
- this.resetWindViewport();
- } else {
- this.resetAllStationViewport();
- }
- },
- // 重置所有风场视角
- resetAllStationViewport() {
- this.viewer.camera.flyTo({
- destination: Cesium.Cartesian3.fromDegrees(
- 114.502778,
- 35.326667,
- 3000000
- ),
- orientation: {
- heading: Cesium.Math.toRadians(0),
- pitch: Cesium.Math.toRadians(-90),
- roll: 0.0,
- },
- duration: 3.0,
- });
- },
- // 重置风场中所有风机视角
- resetWindViewport() {
- let fromLon = this.$route.query.longitude * 1;
- let fromLat = this.$route.query.latitude * 1;
- let fromheight = this.$route.query.height * 1;
- let fromname = this.$route.query.nameEn;
- // 设置镜头到指定的经纬度(度)、高度(米)
- this.viewer.camera.setView({
- destination: Cesium.Cartesian3.fromDegrees(
- fromLon, // 经度 (degrees)
- fromLat, // 纬度 (degrees)
- fromheight // 高度 (meters)
- ),
- orientation: {
- heading: Cesium.Math.toRadians(0.0), // 偏航角 (方向,0 指向北方)
- pitch: Cesium.Math.toRadians(-90.0), // 俯仰角 (-90 是垂直向下)
- roll: 0.0, // 翻滚角
- },
- });
- // 目标位置:经度、纬度、高度
- // const targetLon = 114.48789;
- // const targetLat = 35.32916;
- let targetLon = null;
- let targetLat = null;
- this.restLatLon.forEach((it) => {
- if (it.name === fromname) {
- targetLon = it.longitude;
- targetLat = it.latitude;
- }
- });
- const targetHeight = 5000;
- const draggableHeightTolerance = 5000; // 允许拖拽的高度范围:20,000 ~ 30,000
- const minHeight = 5000; // 最低高度
- const maxHeight = 10000; // 最高高度
- const allowedOffsetDegrees = 0.2; // 允许拖拽的最大偏移(经纬度)
- const minLon = targetLon - allowedOffsetDegrees;
- const maxLon = targetLon + allowedOffsetDegrees;
- const minLat = targetLat - allowedOffsetDegrees;
- const maxLat = targetLat + allowedOffsetDegrees;
- let that = this;
- that.viewer.camera.flyTo({
- destination: Cesium.Cartesian3.fromDegrees(
- targetLon,
- targetLat,
- targetHeight
- ),
- orientation: {
- heading: Cesium.Math.toRadians(0),
- pitch: Cesium.Math.toRadians(-90),
- roll: 0.0,
- },
- duration: 3.0,
- complete: function () {
- console.log('飞入完成,启用拖拽限制逻辑');
- enableHeightBasedDragControl();
- }
- });
- // ===== 控制逻辑:根据高度决定是否允许拖拽 =====
- function enableHeightBasedDragControl() {
- that.viewer.scene.preUpdate.addEventListener(function (scene, time) {
- const camera = that.viewer.camera;
- const posCartographic = camera.positionCartographic;
- if (!posCartographic) return;
- const currentHeight = posCartographic.height;
- that.currentHeight = currentHeight;
- const currentLon = Cesium.Math.toDegrees(posCartographic.longitude);
- const currentLat = Cesium.Math.toDegrees(posCartographic.latitude);
- // === 第一步:限制相机高度不能超出 [10000, 100000] ===
- if (currentHeight < minHeight) {
- // 强制拉高到 minHeight,但保持当前水平视角
- const newPos = Cesium.Cartesian3.fromDegrees(
- currentLon,
- currentLat,
- minHeight
- );
- camera.setView({
- destination: newPos,
- orientation: {
- heading: camera.heading,
- pitch: camera.pitch,
- roll: camera.roll,
- },
- });
- return; // 避免后续逻辑冲突
- }
- if (currentHeight > maxHeight) {
- const newPos = Cesium.Cartesian3.fromDegrees(
- currentLon,
- currentLat,
- maxHeight
- );
- camera.setView({
- destination: newPos,
- orientation: {
- heading: camera.heading,
- pitch: camera.pitch,
- roll: camera.roll,
- },
- });
- return;
- }
- // if (currentHeight < (maxHeight-700000)) {
- // that.cancleAllLayer();
- // }
- // === 第二步:判断是否在“可拖拽高度区间” ===
- const isInDraggableRange =
- currentHeight >= targetHeight - draggableHeightTolerance &&
- currentHeight <= targetHeight + draggableHeightTolerance;
- if (isInDraggableRange) {
- // ✅ 允许拖拽,但限制在指定范围内
- const correctedLon = Cesium.Math.clamp(currentLon, minLon, maxLon);
- const correctedLat = Cesium.Math.clamp(currentLat, minLat, maxLat);
- if (
- Math.abs(correctedLon - currentLon) > 1e-8 ||
- Math.abs(correctedLat - currentLat) > 1e-8
- ) {
- // 越界了,纠正位置,保留当前高度和视角
- camera.setView({
- destination: Cesium.Cartesian3.fromDegrees(
- correctedLon,
- correctedLat,
- currentHeight
- ),
- orientation: {
- heading: camera.heading,
- pitch: camera.pitch,
- roll: camera.roll,
- },
- });
- }
- } else {
- // ❌ 不在可拖拽高度:禁止平移,强制回正到目标点
- const correctedPosition = Cesium.Cartesian3.fromDegrees(
- targetLon,
- targetLat,
- currentHeight // 保留当前缩放高度
- );
- camera.setView({
- destination: correctedPosition,
- orientation: {
- heading: camera.heading,
- pitch: camera.pitch,
- roll: camera.roll,
- },
- });
- }
- });
- }
- },
- coverOnChange(val) {
- if (val.value === "风场") {
- this.switchWindLayer(val.check);
- } else if (val.value === "云层") {
- this.switchCloudLayer(val.check);
- } else if (val.value === "降雨") {
- this.switchRainLayer(val.check);
- } else if (val.value === "温度") {
- this.switchTemperatureLayerr(val.check);
- }
- },
- // 提供控制函数以便在需要时停止循环
- stopCycling(intervalId) {
- if (intervalId) {
- clearInterval(intervalId);
- intervalId = null;
- console.log("循环已停止");
- }
- },
- // 切换风场图显隐
- switchWindLayer() {
- this.viewer.scene.screenSpaceCameraController.enableZoom = true;
- if (this.rainLayer || this.rainImagesLayer.length > 0) {
- this.removeRainLayer();
- this.stopCycling(this.rainintervalId);
- }
- if (this.cloudLayer || this.cloudImagesLayer.length > 0) {
- this.removeCloudLayer();
- this.stopCycling(this.cloudintervalId);
- }
- if (this.temperatureLayer || this.tempImagesLayer.length > 0) {
- this.removeTemperatureLayer();
- this.stopCycling(this.tempintervalId);
- }
- if (this.windLayer) {
- this.removeWindLayer();
- } else {
- this.showWindLayer();
- }
- },
- // 添加风场图
- async showWindLayer() {
- if (!this.windLayer) {
- this.windLayer = new WindLayer(windGridData, {
- particleSize: 2.0,
- particleOpacity: 0.6,
- particleSpeed: 0.01,
- maxVelocity: 25, // 风速最大值(用于颜色映射和速度缩放)
- minVelocity: 0, // 风速最小值阈值(低于此值不显示粒子)
- colorScale: [
- "rgb(36,104, 180)",
- "rgb(60,157, 194)",
- "rgb(128,205,193)",
- "rgb(151,218,168)",
- "rgb(198,231,181)",
- "rgb(238,247,217)",
- "rgb(255,238,159)",
- "rgb(252,217,125)",
- "rgb(255,182,100)",
- "rgb(252,150,75)",
- "rgb(250,112,52)",
- "rgb(245,64,32)",
- "rgb(237,45,28)",
- "rgb(220,24,32)",
- "rgb(180,0,35)",
- ], // 颜色强度缩放
- frameRate: 15,
- fadeOpacity: 0.995,
- particleAge: 150,
- maxAge: 60,
- globalAlpha: 0.8,
- velocityScale: 1 / 30, // 粒子移动速度缩放因子(控制动画快慢)
- paths: 500,
- lineWidth: 2,
- });
- this.windLayer.addTo(this.viewer);
- }
- },
- // 切换卫星云图显隐
- switchCloudLayer(val) {
- if (this.windLayer) {
- this.removeWindLayer();
- }
- if (this.rainLayer || this.rainImagesLayer.length > 0) {
- this.removeRainLayer();
- this.stopCycling(this.rainintervalId);
- }
- if (this.temperatureLayer || this.tempImagesLayer.length > 0) {
- this.removeTemperatureLayer();
- this.stopCycling(this.tempintervalId);
- }
- if (!val || this.cloudLayer || this.cloudImagesLayer.length > 0) {
- this.removeCloudLayer();
- this.stopCycling(this.cloudintervalId);
- } else {
- this.showCloudLayer();
- }
- },
- // 切换降雨图显隐
- switchRainLayer() {
- this.viewer.scene.screenSpaceCameraController.enableZoom = true;
- if (this.windLayer) {
- this.removeWindLayer();
- }
- if (this.cloudLayer || this.cloudImagesLayer.length > 0) {
- this.removeCloudLayer();
- this.stopCycling(this.cloudintervalId);
- }
- if (this.temperatureLayer || this.tempImagesLayer.length > 0) {
- this.removeTemperatureLayer();
- this.stopCycling(this.tempintervalId);
- }
- if (this.rainLayer || this.rainImagesLayer.length > 0) {
- this.removeRainLayer();
- this.stopCycling(this.rainintervalId);
- } else {
- this.showRainLayer();
- }
- },
- // 切换温度图显隐
- switchTemperatureLayerr() {
- this.viewer.scene.screenSpaceCameraController.enableZoom = true;
- if (this.windLayer) {
- this.removeWindLayer();
- }
- if (this.cloudLayer || this.cloudImagesLayer.length > 0) {
- this.removeCloudLayer();
- this.stopCycling(this.cloudintervalId);
- }
- if (this.rainLayer || this.rainImagesLayer.length > 0) {
- this.removeRainLayer();
- this.stopCycling(this.rainintervalId);
- }
- if (this.temperatureLayer || this.tempImagesLayer.length > 0) {
- this.removeTemperatureLayer();
- this.stopCycling(this.tempintervalId);
- } else {
- this.showTemperatureLayer();
- }
- },
- // 显示云图
- showCloudLayer() {
- const imageUrls = [];
- cloudJson.forEach((it) => {
- imageUrls.push("/public/static" + it.path);
- });
- this.showeveryTypeImagesLayer(
- imageUrls,
- this.cloudintervalId,
- this.cloudImagesLayer
- );
- },
- //显示降雨图
- showRainLayer() {
- const imageUrls = [];
- rainJson.forEach((it) => {
- imageUrls.push("/public/static" + it.path);
- });
- this.showeveryTypeImagesLayer(
- imageUrls,
- this.rainintervalId,
- this.rainImagesLayer
- );
- this.csceneElliposid(this.viewer, "rain");
- },
- //显示温度图
- showTemperatureLayer() {
- const imageUrls = [];
- tempJson.forEach((it) => {
- imageUrls.push("/public/static" + it.path);
- });
- this.showeveryTypeImagesLayer(
- imageUrls,
- this.tempintervalId,
- this.tempImagesLayer
- );
- this.csceneElliposid(this.viewer, "temp");
- },
- async showeveryTypeImagesLayer(imageUrls, intervalId, ImagesLayers) {
- // 存储所有图片图层的数组
- let imageLayers = [];
- // 当前显示的图片索引
- let currentImageIndex = -1; // 初始为-1,表示没有图片显示
- // 创建所有图片图层并添加到Viewer,初始时全部隐藏
- await imageUrls.forEach((url) => {
- const provider = new Cesium.SingleTileImageryProvider({
- url: url,
- // url: URL.createObjectURL(url),
- rectangle: Cesium.Rectangle.fromDegrees(-180.0, -90.0, 180.0, 90.0), // 全球覆盖
- tileWidth: 1440, // 根据你的图片实际宽度修改
- tileHeight: 721,
- // 如果你的图片只覆盖特定区域,请修改rectangle参数
- });
- const Layer = this.viewer.imageryLayers.addImageryProvider(provider);
- Layer.alpha = 0.8; // 透明度
- Layer.brightness = 1; // 亮度
- Layer.contrast = 1; // 对比度
- Layer.show = false; // 初始隐藏
- imageLayers.push(Layer);
- ImagesLayers.push(Layer);
- });
- function showNextImage() {
- // 隐藏当前图片
- if (currentImageIndex >= 0 && currentImageIndex < imageLayers.length) {
- imageLayers[currentImageIndex].show = false;
- }
- // 计算下一张图片的索引
- currentImageIndex = (currentImageIndex + 1) % imageLayers.length;
- // 显示下一张图片
- imageLayers[currentImageIndex].show = true;
- // imageLayers[currentImageIndex + 1].show = true;
- console.log("当前显示图片: " + imageUrls[currentImageIndex]);
- }
- // 设置切换间隔(毫秒),例如每5秒切换一次
- const intervalMs = 5000;
- intervalId = setInterval(showNextImage, intervalMs);
- // 初始显示第一张图片
- showNextImage();
- },
- // 移除风场图
- removeWindLayer() {
- if (this.windLayer) {
- // this.windLayer.destroy();
- this.windLayer.remove();
- this.windLayer = null;
- }
- },
- // 移除卫星云图
- removeCloudLayer() {
- if (this.cloudLayer) {
- this.tagMsg = null;
- this.viewer.imageryLayers.remove(this.cloudLayer);
- this.cloudLayer = null;
- }
- if (this.cloudImagesLayer.length > 0) {
- this.cloudImagesLayer.forEach((it) => {
- this.viewer.imageryLayers.remove(it);
- });
- this.cloudImagesLayer = [];
- }
- if (this.imageryProviderV) {
- this.viewer.imageryLayers.remove(this.imageryProviderV);
- this.imageryProviderV = null;
- }
- },
- // 移除降雨图
- removeRainLayer() {
- if (this.rainLayer) {
- this.tagMsg = null;
- this.viewer.imageryLayers.remove(this.rainLayer);
- this.rainLayer = null;
- this.setMapImageryProvider();
- this.handlerAction.removeInputAction(
- Cesium.ScreenSpaceEventType.LEFT_CLICK
- );
- }
- if (this.rainImagesLayer.length > 0) {
- this.rainImagesLayer.forEach((it) => {
- this.viewer.imageryLayers.remove(it);
- });
- this.rainImagesLayer = [];
- }
- if (this.imageryProviderV) {
- this.viewer.imageryLayers.remove(this.imageryProviderV);
- this.imageryProviderV = null;
- }
- },
- // 移除温度图
- removeTemperatureLayer() {
- if (this.temperatureLayer) {
- this.tagMsg = null;
- this.viewer.imageryLayers.remove(this.temperatureLayer);
- this.temperatureLayer = null;
- this.setMapImageryProvider();
- this.handlerAction.removeInputAction(
- Cesium.ScreenSpaceEventType.LEFT_CLICK
- );
- }
- if (this.tempImagesLayer.length > 0) {
- this.tempImagesLayer.forEach((it) => {
- this.viewer.imageryLayers.remove(it);
- });
- this.tempImagesLayer = [];
- }
- if (this.imageryProviderV) {
- this.viewer.imageryLayers.remove(this.imageryProviderV);
- this.imageryProviderV = null;
- }
- },
- //取消所有图层加载
- cancleAllLayer() {
- if (this.windLayer) {
- this.removeWindLayer();
- }
- if (this.rainLayer || this.rainImagesLayer.length > 0) {
- this.removeRainLayer();
- this.stopCycling(this.rainintervalId);
- }
- if (this.cloudLayer || this.cloudImagesLayer.length > 0) {
- this.removeCloudLayer();
- this.stopCycling(this.cloudintervalId);
- }
- if (this.temperatureLayer || this.tempImagesLayer.length > 0) {
- this.removeTemperatureLayer();
- this.stopCycling(this.tempintervalId);
- }
- },
- switchLayer() {
- this.$router.push({
- path: "/",
- });
- },
- menuComTSty(val) {
- this.menuComTStyB = val;
- },
- },
- };
- </script>
- <style lang="less" scoped>
- .dataLoading {
- width: 100vw;
- height: 100vh;
- background: rgba(0, 0, 0, 0.5);
- z-index: 999;
- position: fixed;
- .loadText {
- position: absolute;
- top: 50%;
- left: 50%;
- transform: translate(-50%, -50%);
- background: rgba(255, 255, 255, 0.7);
- padding: 15px 20px;
- border-radius: 6px;
- color: black;
- font-size: 14px;
- font-weight: bold;
- }
- }
- .mapBox {
- width: 100%;
- height: 100%;
- position: relative;
- box-sizing: content-box;
- overflow: hidden;
- .menuComT {
- position: fixed;
- bottom: 400px;
- left: 20px;
- }
- .menuComTSty {
- position: fixed;
- bottom: 20px;
- left: 20px;
- }
- }
- </style>
- <style lang="less">
- .el-overlay {
- background-color: transparent !important;
- .windModelDrawer {
- width: 80% !important;
- backdrop-filter: blur(15px) !important;
- background: rgba(255, 255, 255, 0.8) !important;
- border-radius: 10px 0 0 10px !important;
- .el-drawer__body {
- overflow: hidden;
- padding-top: 0;
- }
- }
- }
- .windDrawerCla {
- .line {
- display: flex;
- flex-direction: row;
- align-items: center;
- justify-content: space-between;
- width: 100%;
- margin-bottom: 10px;
- .leftContent {
- width: 242px;
- height: 41px;
- display: flex;
- align-items: center;
- background: url("@/assets/cesiumImg/title_left_bg.png") no-repeat;
- span {
- font-size: 16px;
- font-family: Microsoft YaHei;
- font-weight: 400;
- color: #ffffff;
- margin-left: 25px;
- }
- }
- }
- .jcxx,
- .gzck {
- height: 100%;
- }
- .spjk,
- .third {
- height: 80vh;
- }
- }
- </style>
|