1327 lines
54 KiB
Vue
Raw Normal View History

2023-06-06 10:46:36 +08:00
<template>
2023-07-05 13:56:04 +08:00
<div class="center">
<div style="width: 100%; height: 100%" id="cesiumContainer"></div>
<div class="rightWra">
<div class="farmlandHeader">
监测日期:&emsp;
<!-- <el-select-->
<!-- v-model="value"-->
<!-- popper-class="select_city"-->
<!-- class="m-2"-->
<!-- placeholder="Select"-->
<!-- @change="selectTime"-->
<!-- >-->
<!-- <el-option v-for="item in options" :key="item" :label="item" :value="item" />-->
<!-- </el-select>-->
<el-date-picker
popper-class="date_poper"
class="m-2" v-model="value" @change="selectTime"
format="YYYY 年 MM 月 DD 日" value-format="YYYY-MM-DD"
type="date" placeholder="选择日期"/>
</div>
<div class="rightTop">
<div class="title">
<span>预警信息发布</span>
2023-06-06 10:46:36 +08:00
</div>
2023-07-05 13:56:04 +08:00
<div class="farmlandDiv">
<div class="radioDiv">
预警范围
<el-radio-group @change="onclick()" v-model="radio1" class="ml-4">
<el-radio :label="5000" size="large">5km</el-radio>
<el-radio :label="10000" size="large">10km</el-radio>
</el-radio-group>
</div>
<div class="selectDiv">
站点名称:
<el-select v-model="zdmcValue" placeholder="请选择">
<el-option
v-for="item in zdmcList"
:key="item.msName"
:label="item.msName"
:value="item.msName"
>
</el-option>
</el-select>
</div>
<div class="selectDiv" style="margin-top: 10px">
预警情况:
<el-select v-model="warnValue" placeholder="请选择">
<el-option
v-for="item in warnList"
:key="item.flag"
:label="item.label"
:value="item.label"
>
</el-option>
</el-select>
</div>
<div class="btws">
<el-button class="bt1" @click="query">查询</el-button>
<el-button class="bt2">重置</el-button>
</div>
<el-table
:cell-style="{ textAlign: 'center' }"
:header-cell-style="{ 'text-align': 'center' }"
:data="SaveResultsDiv"
style="width: 100%"
max-height="470px"
@selection-change="handleSelectionChange"
>
<el-table-column type="selection" width="20"/>
<el-table-column prop="devCode" width="80" label="站点名称"/>
<el-table-column prop="warning" label="预警情况"/>
<el-table-column prop="name" width="80" label="联系人"/>
<el-table-column prop="telephone" label="联系电话"/>
</el-table>
<el-button
class="but"
type="primary"
:disabled="multipleSelection.length < 1"
@click="subText"
>
发布预警短信
</el-button>
2023-06-06 10:46:36 +08:00
</div>
2023-07-05 13:56:04 +08:00
</div>
<div class="rightFoldDiv" @click="rightFoldClick()">
<el-tooltip
:disabled="!rightWraFlag"
:show-arrow="false"
hide-after="0"
show-after="200"
class="box-item"
effect="dark"
content="收起"
placement="top"
>
<img v-if="rightWraFlag" src="@/assets/images/close1.png" alt=""/>
</el-tooltip>
<el-tooltip
:disabled="rightWraFlag"
:show-arrow="false"
hide-after="0"
show-after="200"
class="box-item"
effect="dark"
content="展开"
placement="top"
>
<img
class="imgrotate"
v-if="!rightWraFlag"
src="@/assets/images/close1.png"
alt=""
/>
</el-tooltip>
</div>
</div>
<div class="tool">
<span><img src="@/assets/images/LAYER.png" alt=""/></span>
<span><img src="@/assets/images/amplify.png" alt=""/></span>
<span><img src="@/assets/images/reduce.png" alt=""/></span>
<span><img src="@/assets/images/measure.png" alt=""/></span>
<span><img src="@/assets/images/face.png" alt=""/></span>
<span><img src="@/assets/images/position.png" alt=""/></span>
</div>
<div id="popup">
<div>
<div class="rowWra">
<span>设备</span>
<span>{{ regionName }}</span>
</div>
<div class="rowWra">
<span>经度</span>
<span>{{ popdata.msLongitude }}</span>
</div>
<div class="rowWra">
<span>纬度</span>
<span>{{ popdata.msLatitude }}</span>
</div>
</div>
<div class="cancel" @click="hiddenOverlayChart">X</div>
</div>
<div id="pop">
<div>
<div class="rowWra">
<span>设备</span>
<span>{{ regionName }}</span>
2023-06-06 10:46:36 +08:00
</div>
2023-07-05 13:56:04 +08:00
<div v-for="(item, index) in clickInfoMap.info" :key="index" class="rowWra">
<span>经度</span>
<span>{{ item.msLongitude }}</span>
<span>纬度</span>
<span>{{ item.msLatitude }}</span>
2023-06-06 10:46:36 +08:00
</div>
2023-07-05 13:56:04 +08:00
</div>
<div class="cancel" @click="hiddenOverlayChart">X</div>
</div>
<el-collapse class="legend" accordion>
<el-collapse-item name="1">
<template #title>图例</template>
<div class="mt-4">
<el-checkbox-group v-model="checkList" @change="change">
<el-checkbox
v-for="(value, item, key) in dic"
:key="key"
:style="{
2023-06-20 16:37:55 +08:00
backgroundColor: value.color,
border: `1px solid value.color`,
width: `100%`,
}"
2023-07-05 13:56:04 +08:00
:v-model="value.disabled"
:disabled="value.disabled"
:label="item"
/>
</el-checkbox-group>
</div>
</el-collapse-item>
</el-collapse>
<el-button v-if="flag" class="back_button" @click="back()">返回</el-button>
</div>
2023-04-16 22:33:44 +08:00
</template>
2023-06-06 10:46:36 +08:00
<script setup>
2023-07-05 13:56:04 +08:00
import {ref, onMounted, inject, reactive, watch} from 'vue';
import {ElMessage} from 'element-plus';
2023-06-06 10:46:36 +08:00
import * as echarts from 'echarts';
import TimeLine from '@/components/TimeLine/TimeLine.vue';
import moment from 'Moment';
2023-07-05 13:56:04 +08:00
import * as turf from '@turf/turf';
import {useEcharts} from '@/hooks/useEcharts';
import {ElLoading} from 'element-plus';
import ganhan1 from '@/assets/images/ganhan1.png';
import ganhan2 from '@/assets/images/ganhan2.png';
import ganhan3 from '@/assets/images/ganhan3.png';
import ganhan4 from '@/assets/images/ganhan4.png';
import ganhan0 from '@/assets/images/ganhan0.png';
import pun from '@/assets/images/personUnselected.png';
import pse from '@/assets/images/personSelected.png';
2023-06-06 10:46:36 +08:00
import {
2023-07-05 13:56:04 +08:00
getmeteorologicalFreeze,
getsendSms,
getmeteorologyEquipment, meteorologicalsPeople, meteorology, zdmc,
2023-06-20 16:37:55 +08:00
} from '@/api/meteorological/monitor/information.js';
2023-06-06 10:46:36 +08:00
import axios from 'axios';
import 'echarts-gl';
2023-07-05 13:56:04 +08:00
import {download} from '@/utils/request';
2023-06-20 16:37:55 +08:00
import qs from 'qs';
2023-06-06 10:46:36 +08:00
let viewer = ref(null);
2023-07-05 13:56:04 +08:00
const value = ref()
let Township = reactive({arr: [], brr: [], crr: []}); //街道
let clickInfoMap = ref({name: '', value: ''});
2023-06-06 10:46:36 +08:00
const formLandRef = ref([]);
const flag = ref(false);
let rightWraFlag = ref(false);
const checkList = ref(['false']);
const areaDiv = ref(null);
const value1 = ref('');
const options = ref([]);
let informationData = ref([]);
2023-07-05 13:56:04 +08:00
let clickInformationData = reactive({
lat: '',
lan: '',
name: ''
})
let peopleData = ref([]);
2023-06-06 10:46:36 +08:00
let windArr = ref([]);
let pressureArr = ref([]);
let typhoonTime = ref([]);
const SaveResultsDiv = ref([]);
2023-07-05 13:56:04 +08:00
const radio1 = ref(5000);
2023-06-20 16:37:55 +08:00
const multipleSelection = ref([]);
let popdata = ref({});
2023-07-05 13:56:04 +08:00
const circleLayer = ref([]);
const iconLayer = ref([]);
const personIconLayer = ref([]);
2023-06-06 10:46:36 +08:00
var baozi =
'
let dic = {
2023-07-05 13:56:04 +08:00
轻度干旱: {color: 'rgba(9, 187, 222, 1)', disabled: false},
中度干旱: {color: 'rgba(255, 235, 59, 1)', disabled: false},
严重干旱: {color: 'rgba(234, 165, 93, 1)', disabled: false},
特大干旱: {color: 'rgba(215, 25, 28, 1)', disabled: false},
2023-06-06 10:46:36 +08:00
};
2023-07-05 13:56:04 +08:00
const warnValue =ref()
function query(){
getmeteorology()
}
const warnList = [
{
label:'轻度干旱',
flag:1,
},
{
label:'中度干旱',
flag:2,
},
{
label:'严重干旱',
flag:3,
},
{
label:'特大干旱',
flag:4,
},
]
2023-06-06 10:46:36 +08:00
const rules = reactive({
2023-07-05 13:56:04 +08:00
power: [
{
required: true,
message: 'Please select Activity zone',
trigger: 'change',
},
],
count: [
{
required: true,
message: 'Please select Activity count',
trigger: 'change',
},
],
date1: [
{
type: 'date',
required: true,
message: 'Please pick a date',
trigger: 'change',
},
],
date2: [
{
type: 'date',
required: true,
message: 'Please pick a time',
trigger: 'change',
},
],
type: [
{
type: 'array',
required: true,
message: 'Please select at least one activity type',
trigger: 'change',
},
],
resource: [
{
required: true,
message: 'Please select activity resource',
trigger: 'change',
},
],
desc: [{required: true, message: 'Please input activity form', trigger: 'blur'}],
2023-06-06 10:46:36 +08:00
});
watch(
() => value1.value,
val => {
2023-07-05 13:56:04 +08:00
let startTime = moment(value1.value[0]).format('YYYY-MM-DD')
? moment(value1.value[0]).format('YYYY-MM-DD ')
: '';
let endTime = moment(value1.value[1]).format('YYYY-MM-DD')
? moment(value1.value[1]).format('YYYY-MM-DD')
: '';
2023-06-06 10:46:36 +08:00
}
);
2023-07-05 13:56:04 +08:00
function getIcon(val) {
if (val === '轻度干旱') return ganhan1
if (val === '中度干旱') return ganhan2
if (val === '严重干旱') return ganhan3
if (val === '特大干旱') return ganhan4
if (val === '无灾害') return ganhan0
}
const getYesterday = () => {
let d = new Date()
d.setDate(d.getDate() - 1)
return d
}
2023-06-06 10:46:36 +08:00
//行政区划数据
var data = {
2023-07-05 13:56:04 +08:00
title: [],
2023-06-06 10:46:36 +08:00
};
2023-07-05 13:56:04 +08:00
let map = ref(null);
const cun = () => {
layers = new ol.layer.Tile({
source: new ol.source.TileSuperMapRest({
url: 'http://36.134.44.75:8090/iserver/services/map-huangdaoqu_bianjie/rest/maps/huangdaoqu_village@huangdaoqu_bianjie',
//rasterfunction: new SuperMap.NDVIParameter({ redIndex: 0, nirIndex: 2 }),
cacheEnabled: false,
}),
name: 'huangdaoqu_village',
projection: 'EPSG:4326', //3857
zIndex: 9999,
});
map.addLayer(layers);
// var layersArray = map.getLayers();
// layersArray.insertAt(999, layers);
};
const zhen = () => {
var layer = new ol.layer.Tile({
source: new ol.source.TileSuperMapRest({
url: 'http://36.134.44.75:8090/iserver/services/map-huangdaoqu_bianjie/rest/maps/huangdaoqu_town@huangdaoqu_bianjie',
//rasterfunction: new SuperMap.NDVIParameter({ redIndex: 0, nirIndex: 2 }),
cacheEnabled: false,
}),
projection: 'EPSG:4326', //3857
zIndex: 9999,
});
map.addLayer(layer);
};
let layers = ref(null); //村
2023-06-06 10:46:36 +08:00
// 组件挂载完成后执行
onMounted(() => {
2023-07-05 13:56:04 +08:00
value.value = getYesterday().toJSON().substr(0, 10);
//地图
initMap();
meteorologicals()
let rightWra = document.querySelector('.rightWra');
rightWra.style.transform = 'translate(107%,0)';
2023-06-06 10:46:36 +08:00
});
2023-07-05 13:56:04 +08:00
let alterData = ref([]);
let newArr = ref([]);
const zdmcList = ref([])
const zdmcValue = ref('')
function getmeteorology() {
meteorology({data: value.value, alertRange: radio1.value, flag: 1,msName:zdmcValue.value,warning:warnValue.value}).then(res=>{
SaveResultsDiv.value=res.data
})
}
getmeteorology()
function getZdmc() {
zdmc().then(res => {
zdmcList.value = res.data
})
}
getZdmc()
2023-06-06 10:46:36 +08:00
function initMap() {
2023-07-05 13:56:04 +08:00
var parentElement = document.querySelector('.center');
var mapContainer = document.getElementById('cesiumContainer');
map = new ol.Map({
target: 'cesiumContainer',
controls: [],
view: new ol.View({
center: [119.86763411957472, 35.88435182141938],
zoom: 11,
projection: 'EPSG:4326',
}),
layers: [
new ol.layer.Tile({
source: new ol.source.Tianditu({
layerType: 'img',
key: '1d109683f4d84198e37a38c442d68311',
2023-06-06 10:46:36 +08:00
}),
2023-07-05 13:56:04 +08:00
}),
],
});
cun();
zhen();
const infoOverlay = new ol.Overlay({
element: document.createElement('div'), // 创建一个用于显示信息的div元素
positioning: 'bottom-center', // 设置覆盖层相对于锚点的位置
offset: [0, -10], // 设置偏移量以便覆盖层不会遮挡图标
stopEvent: false, // 允许地图事件继续传播(例如,缩放和拖动)
});
//滚轮控制村级矢量
map.on('moveend', function (e) {
var zoom = map.getView().getZoom(); //获取当前地图的缩放级别
if (zoom >= 13) {
layers.setVisible(true); //显示图层
} else {
layers.setVisible(false);
}
});
map.on('singleclick', function (e) {
alterData = ref([]);
const pixel = map.getEventPixel(e.originalEvent);
var coodinate = e.coordinate;
var lon = coodinate[0];
var lat = coodinate[1];
var view = map.getView();
var zoom = map.getView().getZoom();
view.animate({
center: [lon, lat],
duration: 1000,
2023-06-06 10:46:36 +08:00
});
2023-07-05 13:56:04 +08:00
newArr.value.forEach(item => {
if (layersDic[item]) {
QueryData(
e,
layersDic[item].setOf,
`http://192.168.0.113:8090/iserver/services/${layersDic[item].name}/rest/maps/${layersDic[item].setOf}`,
item
);
} else if (layersGbz[item]) {
QueryData(
e,
layersGbz[item].setOf,
`http://192.168.0.113:8090/iserver/services/${layersGbz[item].name}/rest/maps/${layersGbz[item].setOf}`,
item
);
}
2023-06-06 10:46:36 +08:00
});
2023-07-05 13:56:04 +08:00
map.forEachFeatureAtPixel(pixel, (feature, layer) => {
// 获取Feature的其他属性例如自定义属性'id'
const featureId = feature.get('id');
const featureType = feature.get('type');
// 将覆盖层添加到地图
map.addOverlay(infoOverlay);
if (featureType === '1') {
for (const i in informationData.value) {
if (featureId === informationData.value[i].msName) {
clickInformationData.name = featureId
clickInformationData.lon = informationData.value[i].msLongitude
clickInformationData.lat = informationData.value[i].msLatitude
}
}
infoOverlay.setPosition(feature.getGeometry().getCoordinates());
// 设置覆盖层的内容
infoOverlay.getElement().innerHTML = `
<div class="info-window" style="padding: 10px 20px 10px 20px;background: rgba(2, 31, 26, 0.6);">
<span class="close-btn" style="color:white;display: flex;justify-content: end;cursor:pointer;" >X</span>
<div style="color:white;font-size: 18px">
<div style="margin-top: 10px"><span>名称:</span><span>${clickInformationData.name}</span></div>
<div style="margin-top: 10px"><span>经度:</span><span>${clickInformationData.lon}</span></div>
<div style="margin-top: 10px"><span>维度:</span><span>${clickInformationData.lat}</span></div>
</div>
</div>
`;
// 为关闭按钮添加点击事件监听器
const closeButton = infoOverlay.getElement().querySelector('.close-btn');
if (closeButton) {
closeButton.addEventListener('click', () => {
// 隐藏覆盖层
infoOverlay.setPosition(undefined);
});
}
} else if (featureType === '0') {
for (const i in peopleData.value) {
if (featureId === peopleData.value[i].contacts) {
clickInformationData.name = featureId
clickInformationData.phone = peopleData.value[i].phone
clickInformationData.region = peopleData.value[i].region
}
}
infoOverlay.setPosition(feature.getGeometry().getCoordinates());
// 设置覆盖层的内容
infoOverlay.getElement().innerHTML = `
<div class="info-window" style="padding: 10px 20px 10px 20px;background: rgba(2, 31, 26, 0.6);">
<span class="close-btn" style="color:white;display: flex;justify-content: end;cursor:pointer;" >X</span>
<div style="color:white;font-size: 18px">
<div style="margin-top: 10px"><span>姓名:</span><span>${clickInformationData.name}</span></div>
<div style="margin-top: 10px"><span>手机:</span><span>${clickInformationData.phone}</span></div>
<div style="margin-top: 10px"><span>位置:</span><span>${clickInformationData.region}</span></div>
</div>
</div>
`;
// 为关闭按钮添加点击事件监听器
const closeButton = infoOverlay.getElement().querySelector('.close-btn');
if (closeButton) {
closeButton.addEventListener('click', () => {
// 隐藏覆盖层
infoOverlay.setPosition(undefined);
map.getLayers().forEach(function (layer) {
if (layer instanceof ol.layer.Vector) {
let fea = layer.getSource().getFeatures()[0]
if (fea.get('type') === '0') {
fea.setStyle(new ol.style.Style({
image: new ol.style.Icon({
src: pun,
scale: 0.5 // 图标的缩放比例
})
}))
2023-06-20 16:37:55 +08:00
}
2023-07-05 13:56:04 +08:00
}
2023-06-20 16:37:55 +08:00
});
2023-07-05 13:56:04 +08:00
});
2023-06-20 16:37:55 +08:00
}
2023-04-16 22:33:44 +08:00
2023-07-05 13:56:04 +08:00
//切换图片
feature.setStyle(new ol.style.Style({
image: new ol.style.Icon({
src: pse,
scale: 0.5 // 图标的缩放比例
})
}))
map.getLayers().forEach(function (layer) {
if (layer instanceof ol.layer.Vector) {
let fea = layer.getSource().getFeatures()[0]
if (fea.get('type') === '0' && fea !== feature) {
fea.setStyle(new ol.style.Style({
image: new ol.style.Icon({
src: pun,
scale: 0.5 // 图标的缩放比例
})
}))
}
}
2023-06-06 10:46:36 +08:00
});
2023-07-05 13:56:04 +08:00
}
2023-06-06 10:46:36 +08:00
});
2023-07-05 13:56:04 +08:00
});
// 监听父元素大小变化
var resizeObserver = new ResizeObserver(function (entries) {
entries.forEach(function (entry) {
// 获取父元素的新大小
var newWidth = entry.contentRect.width;
var newHeight = entry.contentRect.height;
// 调整地图容器的大小
mapContainer.style.width = newWidth + 'px';
mapContainer.style.height = newHeight + 'px';
// 重新渲染地图
map.updateSize();
2023-06-06 10:46:36 +08:00
});
2023-07-05 13:56:04 +08:00
});
// 开始监听父元素大小变化
resizeObserver.observe(parentElement);
2023-06-06 10:46:36 +08:00
}
//折叠
function rightFoldClick() {
2023-07-05 13:56:04 +08:00
rightWraFlag.value = !rightWraFlag.value;
if (rightWraFlag.value) {
let rightWra = document.querySelector('.rightWra');
rightWra.style.transform = 'translate(0,0)';
} else {
let rightWra = document.querySelector('.rightWra');
rightWra.style.transform = 'translate(107%,0)';
}
2023-06-06 10:46:36 +08:00
}
2023-06-20 16:37:55 +08:00
const onclick = () => {
2023-07-05 13:56:04 +08:00
//选择范围
// getmeteorologicalFreezes();
meteorologicals()
2023-06-20 16:37:55 +08:00
};
2023-07-05 13:56:04 +08:00
const meteorologicals = () => {
for (const i in circleLayer.value) {
map.removeLayer(circleLayer.value[i]);
}
circleLayer.value = []
for (const i in iconLayer.value) {
map.removeLayer(iconLayer.value[i]);
}
iconLayer.value = []
for (const i in personIconLayer.value) {
map.removeLayer(personIconLayer.value[i]);
}
personIconLayer.value = []
getmeteorologyEquipment({flag: 1, data: value.value}).then(res => {
informationData.value = res.data
for (const i in informationData.value) {
const centerLonLat = [parseFloat(informationData.value[i].msLongitude),
parseFloat(informationData.value[i].msLatitude)];
const radius = radio1.value / map.getView().getProjection().getMetersPerUnit(); // 将半径从米转换为度EPSG:4326
const circleGeometry = new ol.geom.Circle(centerLonLat, radius);
// 创建一个矢量图层
circleLayer.value[i] = new ol.layer.Vector({
source: new ol.source.Vector({
features: [
new ol.Feature({
geometry: circleGeometry
})
]
}),
style: new ol.style.Style({
// fill: new ol.style.Fill({
// color: 'rgba(255,255,255,0.5)'
// }),
stroke: new ol.style.Stroke({
color: 'rgb(255,255,0)', // 设置红色边框
width: 2
}),
})
});
// 添加矢量图层到地图
map.addLayer(circleLayer.value[i]);
// 创建一个点几何对象使用EPSG:4326投影坐标
const iconPointGeometry = new ol.geom.Point(centerLonLat);
// 创建一个Feature并将其几何对象设置为刚创建的点
const iconFeature = new ol.Feature({
geometry: iconPointGeometry,
id: informationData.value[i].msName,
type: informationData.value[i].flag
});
// 设置Feature的样式包括图标
iconFeature.setStyle(new ol.style.Style({
image: new ol.style.Icon({
src: getIcon(informationData.value[i].warning),
scale: 0.5 // 图标的缩放比例
})
}));
// 创建一个矢量图层并将Feature添加到该图层
iconLayer.value[i] = new ol.layer.Vector({
source: new ol.source.Vector({
features: [iconFeature]
})
});
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
map.addLayer(iconLayer.value[i]);
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
})
meteorologicalsPeople().then(res => {
peopleData.value = res.data
for (const i in peopleData.value) {
const centerLonLat = [parseFloat(peopleData.value[i].latitude),
parseFloat(peopleData.value[i].longitude)];
const iconPointGeometry = new ol.geom.Point(centerLonLat);
// 创建一个Feature并将其几何对象设置为刚创建的点
const iconFeature = new ol.Feature({
geometry: iconPointGeometry,
id: peopleData.value[i].contacts,
type: peopleData.value[i].flag
});
// 设置Feature的样式包括图标
iconFeature.setStyle(new ol.style.Style({
image: new ol.style.Icon({
src: pun,
scale: 0.5 // 图标的缩放比例
2023-06-06 10:46:36 +08:00
})
2023-07-05 13:56:04 +08:00
}));
personIconLayer.value[i] = new ol.layer.Vector({
source: new ol.source.Vector({
features: [iconFeature]
2023-06-06 10:46:36 +08:00
})
2023-07-05 13:56:04 +08:00
});
map.addLayer(personIconLayer.value[i]);
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
})
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
const selectTime = (val) => {
//选择时间
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
meteorologicals()
// getmeteorologicalFreezes();
};
const subText = () => {
//发送短信
getsendSms({meteorologicalStations: multipleSelection.value}).then(res => {
console.log(res.data);
});
};
const handleSelectionChange = val => {
multipleSelection.value = val;
};
/*------------------接口--------------------*/
const getmeteorologicalFreezes = () => {
getmeteorologicalFreeze({
monitoringTime: value.value,
alertRange: radio1.value,
flag: '1',
}).then(res => {
SaveResultsDiv.value = res.data;
});
};
2023-06-20 16:37:55 +08:00
2023-04-16 22:33:44 +08:00
</script>
2023-06-06 10:46:36 +08:00
<style lang="scss" scoped>
$height: calc(100vh - 100px);
2023-04-16 22:33:44 +08:00
2023-06-06 10:46:36 +08:00
.center {
2023-07-05 13:56:04 +08:00
width: 100%;
height: 100%;
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
.imgrotate {
transform: rotate(180deg);
}
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
.title {
width: 100%;
height: 45px;
background: url('@/assets/images/title.png');
background-repeat: no-repeat;
background-size: 110% 100%;
color: #fff;
font-size: 18px;
font-weight: 700;
line-height: 45px;
padding-left: 46px;
display: flex;
cursor: pointer;
align-items: center;
justify-content: space-between;
:deep(.el-input__wrapper) {
width: 100px;
border-radius: 30px;
border: 1px solid rgba(23, 194, 180, 1);
background: rgba(41, 255, 255, 0.1);
height: 34px;
}
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
span {
width: 80%;
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
background: linear-gradient(
180deg,
rgba(255, 255, 255, 1) 33.33%,
rgba(41, 255, 219, 1) 100%
);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
}
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
p {
width: 120px;
height: 25px;
border-radius: 20px;
font-size: 14px;
background: linear-gradient(
180deg,
rgba(16, 111, 111, 1) 0%,
rgba(47, 214, 214, 1) 100%
);
border: 1.5px solid rgba(23, 194, 180, 1);
display: flex;
justify-content: center;
align-items: center;
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
}
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
2023-06-06 10:46:36 +08:00
.frame {
2023-07-05 13:56:04 +08:00
:deep(.el-table__cell) {
color: #333;
}
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
2023-06-06 10:46:36 +08:00
.rightWra {
2023-07-05 13:56:04 +08:00
position: absolute;
top: 10px;
right: 20px;
width: 23%;
height: $height;
opacity: 1;
display: flex;
flex-direction: column;
align-items: center;
background: rgba(2, 31, 26, 0.85);
box-shadow: inset 0px 0px 15px 6px rgba(41, 255, 255, 0.5);
transition: transform 1s;
.farmlandHeader {
display: flex;
font-size: 18px;
font-weight: 400;
letter-spacing: 0px;
align-items: center;
color: rgba(255, 255, 255, 1);
margin: 20px 0;
padding: 0 10px;
::v-deep .m-2 {
.el-input__wrapper {
box-shadow: none;
border-radius: 4px;
background: transparent linear-gradient(
180deg,
rgba(38, 212, 191, 0.5) 0%,
rgba(43, 186, 186, 0.5) 25.69%,
rgba(45, 165, 181, 0.5) 66.67%,
rgba(54, 111, 168, 0.5) 100%
);
border: 1px solid rgba(137, 211, 245, 1);
}
:deep(.el-input__inner) {
color: #fff;
}
}
}
.rightFoldDiv {
width: 30px;
height: 30px;
2023-06-06 10:46:36 +08:00
position: absolute;
2023-07-05 13:56:04 +08:00
left: -8%;
top: 50%;
transform: translate(0, -50%);
font-size: 30px;
color: #ccc;
}
.rightTop {
width: 100%;
height: 88%;
2023-06-06 10:46:36 +08:00
opacity: 1;
display: flex;
flex-direction: column;
2023-07-05 13:56:04 +08:00
justify-content: flex-start;
2023-06-06 10:46:36 +08:00
align-items: center;
2023-07-05 13:56:04 +08:00
.farmlandDiv {
// background: rgba(255, 255, 255, 0.05);
display: flex;
width: 95%;
flex-direction: column;
padding: 5px 10px 5px 10px;
color: rgba(255, 255, 255, 1);
height: 100%;
:deep(.el-table--fit) {
height: 90%;
}
.but {
width: 100px;
margin: 10px auto;
}
.radioDiv {
2023-06-06 10:46:36 +08:00
display: flex;
align-items: center;
2023-07-05 13:56:04 +08:00
justify-content: flex-start;
}
.selectDiv {
.el-select{
::v-deep .el-input__wrapper{
box-shadow: none;
border-radius: 4px;
background: transparent linear-gradient(
2023-06-06 10:46:36 +08:00
180deg,
rgba(38, 212, 191, 0.5) 0%,
rgba(43, 186, 186, 0.5) 25.69%,
rgba(45, 165, 181, 0.5) 66.67%,
rgba(54, 111, 168, 0.5) 100%
2023-07-05 13:56:04 +08:00
);
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
border: none;
}
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
}
.btws{
display: flex;
justify-content: space-around;
align-items: center;
margin-top: 10px;
margin-bottom: 10px;
.el-button{
color:white;
border-radius: 4px;
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
border: 1.5px solid rgba(23, 194, 180, 1);
}
.bt1{
background: linear-gradient(180deg, rgba(16, 111, 111, 1) 0%, rgba(47, 214, 214, 1) 100%);
}
.bt2{
background: rgba(22, 94, 102, 1);
}
}
:deep(.el-table tr) {
background-color: transparent;
}
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
:deep(.el-table) {
--el-table-border-color: none;
color: rgba(255, 255, 255, 1);
}
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
:deep(.el-table--enable-row-hover .el-table__body tr:hover > td.el-table__cell) {
background-color: revert;
}
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
.Crops {
display: flex;
width: 100%;
margin-bottom: 10px;
font-size: 14px;
font-weight: 400;
height: 31px;
flex-direction: row;
align-items: center;
justify-content: space-around;
opacity: 1;
background: linear-gradient(
90deg,
rgba(21, 173, 148, 0.1) 0%,
rgba(21, 173, 148, 0) 100%
);
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
div {
display: flex;
align-items: center;
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
}
.el-checkbox-group {
display: flex;
flex-direction: column;
}
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
:deep(.ones) {
2023-06-06 10:46:36 +08:00
width: 100%;
2023-07-05 13:56:04 +08:00
height: 170px;
2023-06-06 10:46:36 +08:00
display: flex;
flex-direction: column;
justify-content: flex-start;
2023-07-05 13:56:04 +08:00
align-items: flex-start;
--el-table-tr-bg-color: null;
--el-table-border-color: null;
2023-06-06 10:46:36 +08:00
font-size: 14px;
font-weight: 400;
letter-spacing: 0px;
line-height: 0px;
color: rgba(255, 255, 255, 1);
2023-07-05 13:56:04 +08:00
}
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
.ProgressBar {
width: 100%;
height: 9px;
opacity: 1;
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
}
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
.rightbottom {
width: 100%;
height: 490px;
2023-06-06 10:46:36 +08:00
opacity: 1;
display: flex;
flex-direction: column;
justify-content: flex-start;
2023-07-05 13:56:04 +08:00
align-items: center;
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
.ASdivision {
display: flex;
justify-content: center;
width: 95%;
flex-direction: column;
padding: 5px 10px 5px 10px;
color: rgba(255, 255, 255, 1);
height: 40%;
:deep(.el-table tr) {
background-color: transparent;
}
:deep(.el-table) {
--el-table-border-color: none;
color: rgba(255, 255, 255, 1);
}
:deep(.el-table--enable-row-hover .el-table__body tr:hover > td.el-table__cell) {
background-color: revert;
}
.Crops {
2023-06-06 10:46:36 +08:00
display: flex;
2023-07-05 13:56:04 +08:00
width: 100%;
2023-06-20 16:37:55 +08:00
margin-bottom: 10px;
2023-07-05 13:56:04 +08:00
font-size: 14px;
font-weight: 400;
height: 31px;
flex-direction: row;
align-items: center;
justify-content: space-around;
opacity: 1;
background: linear-gradient(
90deg,
rgba(21, 173, 148, 0.1) 0%,
rgba(21, 173, 148, 0) 100%
);
2023-06-20 16:37:55 +08:00
2023-07-05 13:56:04 +08:00
div {
display: flex;
align-items: center;
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
}
2023-06-20 16:37:55 +08:00
2023-07-05 13:56:04 +08:00
.el-checkbox-group {
display: flex;
flex-direction: column;
}
:deep(.ones) {
width: 100%;
height: 170px;
display: flex;
flex-direction: column;
justify-content: flex-start;
align-items: flex-start;
--el-table-tr-bg-color: null;
--el-table-border-color: null;
font-size: 14px;
font-weight: 400;
letter-spacing: 0px;
line-height: 0px;
2023-06-06 10:46:36 +08:00
color: rgba(255, 255, 255, 1);
2023-07-05 13:56:04 +08:00
}
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
}
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
:deep(.el-input__wrapper) {
opacity: 1;
border-radius: 4px;
// background: rgba(22, 94, 102, 1);
// border: 1px solid rgba(4, 153, 153, 1);
// box-shadow: 0px 3px 9px 0px rgba(0, 0, 0, 0.25);dsawe
width: 70%;
.el-input__inner {
color: white;
}
}
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
.legend {
position: absolute;
right: 25%;
bottom: 7%;
width: 129px;
border: 1px solid rgba(4, 153, 153, 1);
// height: 50px;
:deep(.el-collapse-item__header) {
background: rgba(2, 31, 26, 0.6);
color: rgba(255, 255, 255, 1);
text-align: center;
padding: 0 30px;
font-size: 14px;
}
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
--el-collapse-content-bg-color {
background: rgba(2, 31, 26, 0.6);
}
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
:deep(.el-collapse-item__content) {
background: rgba(2, 31, 26, 0.6);
padding: 0 10px;
padding-bottom: 10px;
}
--el-collapse-border-color: none;
--el-collapse-content-bg-color: none;
// opacity: 1;
// border-radius: 4px;
// background: rgba(2, 31, 26, 0.6);
// display: flex;
// flex-direction: column;
// justify-content: flex-start;
// align-items: center;
// padding: 10px 10px 10px 10px;
p {
margin: 10px;
font-size: 14px;
font-weight: 400;
letter-spacing: 0px;
line-height: 0px;
color: rgba(255, 255, 255, 1);
text-align: center;
}
.mt-4 {
.el-checkbox {
height: 30px;
width: 100%;
margin-bottom: 2px;
padding-left: 10px;
font-size: 14px;
font-weight: 400;
letter-spacing: 0px;
line-height: 0px;
color: rgba(255, 255, 255, 1);
text-align: left;
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
}
:deep(.el-checkbox__label) {
color: black;
}
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
.tool {
position: absolute;
right: 30%;
top: 8%;
width: 30px;
height: 280px;
opacity: 1;
display: flex;
flex-direction: column;
justify-content: flex-start;
align-items: flex-start;
display: none;
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
#popup {
border-radius: 5px;
background: rgba(2, 31, 26, 1);
display: none;
// justify-content: flex-start;
// align-items: flex-end;
padding: 30px 8px 20px 8px;
border: 2px solid rgba(4, 153, 153, 1);
.rowWra {
display: flex;
margin-bottom: 10px;
justify-content: space-between;
& > span:nth-child(1) {
font-weight: 400;
letter-spacing: 0px;
color: rgba(255, 255, 255, 1);
// margin-top: 20px;
line-height: 24px;
// width: 3em;
// font-size: 14px;
margin-right: 10px;
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
& > span:nth-child(2) {
color: rgba(255, 255, 255, 1);
width: 179px;
height: 24px;
opacity: 1;
border-radius: 2px;
background: rgba(217, 231, 255, 0.2);
display: flex;
justify-content: center;
align-items: center;
padding: 2px 10px 2px 10px;
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
}
.cancel {
position: absolute;
right: 10px;
top: 5px;
color: rgba(255, 255, 255, 1);
cursor: pointer;
}
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
#pop {
border-radius: 5px;
background: rgba(2, 31, 26, 1);
display: none;
// justify-content: flex-start;
// align-items: flex-end;
padding: 30px 8px 20px 8px;
.cancel {
position: absolute;
right: 10px;
top: 5px;
color: rgba(255, 255, 255, 1);
cursor: pointer;
}
2023-06-06 10:46:36 +08:00
2023-07-05 13:56:04 +08:00
& > div {
display: flex;
margin-bottom: 10px;
& > div:nth-child(1) {
font-weight: 400;
letter-spacing: 0px;
color: rgba(255, 255, 255, 1);
// margin-top: 20px;
line-height: 24px;
margin-right: 10px;
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
& > div:nth-child(2) {
color: rgba(255, 255, 255, 1);
width: 129px;
height: 24px;
opacity: 1;
border-radius: 2px;
background: rgba(217, 231, 255, 0.2);
display: flex;
justify-content: center;
align-items: center;
padding: 2px 10px 2px 10px;
// margin-top: 20px;
}
}
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
.back_button {
position: absolute;
right: 30%;
top: 20px;
2023-06-06 10:46:36 +08:00
}
2023-07-05 13:56:04 +08:00
</style>
<style lang="scss">
//.date_poper {
// background: linear-gradient(180deg,
// rgba(38, 212, 191, 0.5) 0%,
// rgba(43, 186, 186, 0.5) 25.69%,
// rgba(45, 165, 181, 0.5) 66.67%,
// rgba(54, 111, 168, 0.5) 100%) !important;
// color: white;
// .el-picker-panel__body{
// background: linear-gradient(180deg,
// rgba(38, 212, 191, 0.5) 0%,
// rgba(43, 186, 186, 0.5) 25.69%,
// rgba(45, 165, 181, 0.5) 66.67%,
// rgba(54, 111, 168, 0.5) 100%) !important;
// color: white;
// }
//}
2023-06-06 10:46:36 +08:00
</style>