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">
|
|
|
|
|
监测日期: 
|
|
|
|
|
<!-- <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>
|