Files
Agriculture-front-end/src/views/index.vue
2023-07-04 10:08:33 +08:00

5847 lines
268 KiB
Vue
Executable File
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<template>
<div class="fatherDiv">
<div class="centerBox">
<div ref="cesiumContainer" style="width: 100%; height: 100%" id="cesiumContainer"></div>
<div class="leftWra">
<div class="leftTop">
<div class="title">
<span>设备类型选择</span>
<p @click="ShowAll">展示全部</p>
</div>
<div class="types">
<div width="100%" class="types_left">
<img width="90" src="@/assets/images/insect.png" alt="" />
<p
@click="
e => {
sporeClick(e);
}
"
:class="brightFlag == 1 || brightFlag == 4 ? 'sele_types' : ''"
>
智能孢子仪
</p>
</div>
<div width="100%" class="types_center">
<img width="90" src="@/assets/images/spore.png" alt="" />
<p
@click="
e => {
insectClick(e);
}
"
:class="brightFlag == 2 || brightFlag == 4 ? 'sele_types' : ''"
>
虫情监测仪
</p>
</div>
<div width="100%" class="types_right">
<img width="90" src="@/assets/images/soil.png" alt="" />
<p
@click="
e => {
soilClick(e);
}
"
:class="brightFlag == 3 || brightFlag == 4 ? 'sele_types' : ''"
>
土壤墒情土质
</p>
</div>
</div>
</div>
<div v-if="brightFlag == 4 || brightFlag == 1" class="leftbottom">
<div class="title">
<span>智能孢子监测数据</span>
<p @click="bugarrsVisible">
历史数据 &nbsp;
<img
src="@/assets/icons/svg/downloads.svg"
style="width: 14px; height: 14px; cursor: pointer"
/>
</p>
</div>
<div class="tableDiv">
<el-table
max-height="100%"
height="100%"
:data="tableData.arrs"
stripe
style="width: 100%"
:header-cell-style="{ 'text-align': 'center' }"
:cell-style="{ 'text-align': 'center' }"
>
<el-table-column width="90" prop="devCode" label="设备编号" />
<el-table-column prop="pictureTime" label="监测时间">
<template #default="scope">
<div>{{ handleDate(scope.row.pictureTime) }}</div>
<div>{{ handleTime(scope.row.pictureTime) }}</div>
</template>
</el-table-column>
<el-table-column
class="red"
prop="warning"
width="52"
:filters="[
{ text: '有', value: '有' },
{ text: '无', value: '无' },
]"
:filter-method="filterHandler"
label="预警情况"
>
<template #default="scope">
<span
v-if="scope.row.warning === '有'"
style="
background-color: rgba(255, 62, 57, 1);
padding: 2px 12px 2px 12px;
border-radius: 2px;
"
>
{{ scope.row.warning }}
</span>
<span
v-else
style="
background-color: rgba(9, 222, 133, 1);
padding: 2px 12px 2px 12px;
border-radius: 2px;
"
>
{{ scope.row.warning }}
</span>
</template>
</el-table-column>
<el-table-column prop="picturePath" label="照片">
<template #default="scope">
<div v-if="scope.row.warning === '无'">
<image-preview
append-to-body
style="width: 60px; height: 60px"
:src="scope.row.picturePath"
:zoom-rate="1.2"
fit="cover"
>
<div slot="error" class="image-slot">
<i class="el-icon-picture-outline"></i>
</div>
</image-preview>
</div>
<div v-if="scope.row.warning === '有'">
<el-image
style="width: 60px; height: 60px"
:src="scope.row.picturePath"
:fit="fit"
/>
</div>
</template>
</el-table-column>
</el-table>
</div>
</div>
<div v-if="brightFlag == 2" class="leftbottom">
<div class="title">
<span>实时监测数据</span>
<p @click="bugarrsVisibles">
历史数据 &nbsp;
<img
src="@/assets/icons/svg/downloads.svg"
style="width: 14px; height: 14px; cursor: pointer"
/>
</p>
</div>
<div class="tableDiv">
<el-table
@cell-click="cellClick"
max-height="100%"
height="100%"
:data="bugarrtime"
stripe
style="width: 100%"
:header-cell-style="{ 'text-align': 'center' }"
:cell-style="{ 'text-align': 'center' }"
>
<el-table-column width="90" prop="devCode" label="设备编号" />
<el-table-column prop="pictureTime" label="监测时间">
<template #default="scope">
<div>{{ handleDate(scope.row.pictureTime) }}</div>
<div>{{ handleTime(scope.row.pictureTime) }}</div>
</template>
</el-table-column>
<el-table-column
class="red"
prop="warning"
width="52"
:filters="[
{ text: '有', value: '有' },
{ text: '无', value: '无' },
]"
:filter-method="filterHandler"
label="预警情况"
>
<template #default="scope">
<span
v-if="scope.row.warning === '有'"
style="
background-color: rgba(255, 62, 57, 1);
padding: 2px 12px 2px 12px;
border-radius: 2px;
"
>
{{ scope.row.warning }}
</span>
<span
v-else
style="
background-color: rgba(9, 222, 133, 1);
padding: 2px 12px 2px 12px;
border-radius: 2px;
"
>
{{ scope.row.warning }}
</span>
</template>
</el-table-column>
<el-table-column prop="picturePath" label="照片">
<template #default="scope">
<div v-if="scope.row.warning === '无'">
<image-preview
append-to-body
style="width: 60px; height: 60px"
:src="scope.row.picturePath"
:zoom-rate="1.2"
fit="cover"
>
<div slot="error" class="image-slot">
<i class="el-icon-picture-outline"></i>
</div>
</image-preview>
</div>
<div v-if="scope.row.warning === '有'">
<el-image
style="width: 60px; height: 60px"
:src="scope.row.picturePath"
:fit="fit"
/>
</div>
</template>
</el-table-column>
</el-table>
</div>
</div>
<div v-if="brightFlag == 3" class="leftbottom">
<div class="title">
<span>设备监测信息列表</span>
<p @click="bugarrsVisibless">
历史数据 &nbsp;
<img
src="@/assets/icons/svg/downloads.svg"
style="width: 14px; height: 14px; cursor: pointer"
/>
</p>
</div>
<div class="tableDiv">
<el-table
max-height="100%"
height="100%"
:data="soilAll"
stripe
style="width: 100%"
:header-cell-style="{ 'text-align': 'center' }"
:cell-style="{ 'text-align': 'center' }"
>
<el-table-column label="监测数值" type="expand">
<template #default="props">
<div class="selectdiv" m="4">
<p>
0cm湿度:
<span
v-if="
props.row.soilHumidity1 < 5 ||
props.row.soilHumidity1 > 60
"
style="color: red"
>
{{ props.row.soilHumidity1 }}
</span>
<span v-else>{{ props.row.soilHumidity1 }}</span>
</p>
<p>
-10cm湿度:
<span
v-if="
props.row.soilHumidity2 < 0 ||
props.row.soilHumidity2 > 30
"
style="color: red"
>
{{ props.row.soilHumidity2 }}
</span>
<span v-else>{{ props.row.soilHumidity2 }}</span>
</p>
<p>
-20cm湿度:
<span
v-if="
props.row.soilHumidity3 < 0 ||
props.row.soilHumidity3 > 30
"
style="color: red"
>
{{ props.row.soilHumidity3 }}
</span>
<span v-else>{{ props.row.soilHumidity3 }}</span>
</p>
<p>
-30cm湿度:
<span
v-if="
props.row.soilHumidity4 < 0 ||
props.row.soilHumidity4 > 40
"
style="color: red"
>
{{ props.row.soilHumidity4 }}
</span>
<span v-else>{{ props.row.soilHumidity4 }}</span>
</p>
<p>
-40cm湿度:
<span
v-if="
props.row.soilHumidity5 < 0 ||
props.row.soilHumidity5 > 40
"
style="color: red"
>
{{ props.row.soilHumidity5 }}
</span>
<span v-else>{{ props.row.soilHumidity5 }}</span>
</p>
<p>
0cm温度:
<span
v-if="
props.row.soilTemperature1 < -10 ||
props.row.soilTemperature1 > 40
"
style="color: red"
>
{{ props.row.soilTemperature1 }}
</span>
<span v-else>{{ props.row.soilTemperature1 }}</span>
</p>
<p>
-10cm温度:
<span
v-if="
props.row.soilTemperature2 < -5 ||
props.row.soilTemperature2 > 40
"
style="color: red"
>
{{ props.row.soilTemperature2 }}
</span>
<span v-else>{{ props.row.soilTemperature2 }}</span>
</p>
<p>
-20cm温度:
<span
v-if="
props.row.soilTemperature3 < 0 ||
props.row.soilTemperature3 > 30
"
style="color: red"
>
{{ props.row.soilTemperature3 }}
</span>
<span v-else>{{ props.row.soilTemperature3 }}</span>
</p>
<p>
-30cm温度:
<span
v-if="
props.row.soilTemperature4 < 0 ||
props.row.soilTemperature4 > 30
"
style="color: red"
>
{{ props.row.soilTemperature4 }}
</span>
<span v-else>{{ props.row.soilTemperature4 }}</span>
</p>
<p>
-40cm温度:
<span
v-if="
props.row.soilTemperature5 < 0 ||
props.row.soilTemperature5 > 30
"
style="color: red"
>
{{ props.row.soilTemperature5 }}
</span>
<span v-else>{{ props.row.soilTemperature5 }}</span>
</p>
<p>
PH值:
<span
v-if="
props.row.soilPh < 5.5 || props.row.soilPh > 7.5
"
style="color: red"
>
{{ props.row.soilPh }}
</span>
<span v-else>{{ props.row.soilPh }}</span>
</p>
<p>
EC值:
<span
v-if="
props.row.soilEc < 0 || props.row.soilEc > 0.2
"
style="color: red"
>
{{ props.row.soilEc }}
</span>
<span>{{ props.row.soilEc }}</span>
</p>
</div>
</template>
</el-table-column>
<el-table-column width="90" prop="devCode" label="设备编号" />
<el-table-column
class="red"
prop="warning"
width="52"
:filters="[
{ text: '有', value: '有' },
{ text: '无', value: '无' },
]"
:filter-method="filterHandler"
label="预警情况"
>
<template #default="scope">
<span
v-if="scope.row.warning === '有'"
style="
background-color: rgba(255, 62, 57, 1);
padding: 2px 12px 2px 12px;
border-radius: 2px;
"
>
{{ scope.row.warning }}
</span>
<span
v-else
style="
background-color: rgba(9, 222, 133, 1);
padding: 2px 12px 2px 12px;
border-radius: 2px;
"
>
{{ scope.row.warning }}
</span>
</template>
</el-table-column>
<el-table-column prop="dataTime" label="监测时间">
<template #default="scope">
<div>{{ handleDate(scope.row.dataTime) }}</div>
<div>{{ handleTime(scope.row.dataTime) }}</div>
</template>
</el-table-column>
</el-table>
</div>
</div>
<div class="leftFoldDiv" @click="leftFoldClick()">
<el-tooltip
class="box-item"
:show-arrow="false"
:disabled="leftWraFlag"
hide-after="0"
show-after="200"
effect="dark"
content="展开"
placement="top"
>
<img v-if="!leftWraFlag" src="@/assets/images/close1.png" alt="" />
</el-tooltip>
<el-tooltip
:disabled="!leftWraFlag"
:show-arrow="false"
class="box-item"
show-after="200"
hide-after="0"
effect="dark"
content="收起"
placement="top"
>
<img
class="imgrotate"
v-if="leftWraFlag"
src="@/assets/images/close1.png"
alt=""
/>
</el-tooltip>
</div>
</div>
<div class="rightWra" v-show="brightFlags">
<div class="rightTop">
<div class="title">
<span>墒情、土质监测数据</span>
</div>
<div ref="farmlandDiv" class="farmlandDiv"></div>
<div ref="Phdiv" class="Phdiv"></div>
<div class="depth">
<p :class="active == '1' ? 'SelectedDiv' : ''" @click="depthclick(1)">
0cm
</p>
<p :class="active == '2' ? 'SelectedDiv' : ''" @click="depthclick(2)">
-10cm
</p>
<p :class="active == '3' ? 'SelectedDiv' : ''" @click="depthclick(3)">
-20cm
</p>
<p :class="active == '4' ? 'SelectedDiv' : ''" @click="depthclick(4)">
-30cm
</p>
<p :class="active == '5' ? 'SelectedDiv' : ''" @click="depthclick(5)">
-40cm
</p>
</div>
<div ref="soilDiv" class="soilDiv"></div>
</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="bottom_center" v-show="bottomFlags">
<div class="left_bottom">
<div class="title">
<span>设备照片</span>
</div>
<div class="imgdiv">
<img
src="https://img.js.design/assets/img/641d73b4634e77963ddc9e3c.png#34e63fa85ea624d67ab959d24318b0e9"
alt=""
/>
</div>
</div>
<div class="right_bottom">
<div class="title">
<span>虫情监测数据</span>
<p @click="bugarrsVisibles">
历史数据 &nbsp;
<img
src="@/assets/icons/svg/downloads.svg"
style="width: 14px; height: 14px; cursor: pointer"
/>
</p>
</div>
<div class="tableDiv">
<el-table
max-height="100%"
height="100%"
:data="bugarr"
stripe
style="width: 100%"
:header-cell-style="{ 'text-align': 'center' }"
:cell-style="{ 'text-align': 'center' }"
@cell-click="cellClick"
>
<el-table-column width="90" prop="devCode" label="设备编号" />
<el-table-column prop="pictureTime" label="监测时间">
<template #default="scope">
<div>{{ handleDate(scope.row.pictureTime) }}</div>
<div>{{ handleTime(scope.row.pictureTime) }}</div>
</template>
</el-table-column>
<el-table-column
class="red"
prop="warning"
width="52"
:filters="[
{ text: '有', value: '有' },
{ text: '无', value: '无' },
]"
:filter-method="filterHandler"
label="预警情况"
>
<template #default="scope">
<span
v-if="scope.row.warning === '有'"
style="
background-color: rgba(255, 62, 57, 1);
padding: 2px 12px 2px 12px;
border-radius: 2px;
"
>
{{ scope.row.warning }}
</span>
<span
v-else
style="
background-color: rgba(9, 222, 133, 1);
padding: 2px 12px 2px 12px;
border-radius: 2px;
"
>
{{ scope.row.warning }}
</span>
</template>
</el-table-column>
<el-table-column prop="picturePath" label="照片">
<template #default="scope">
<div v-if="scope.row.warning === '无'">
<image-preview
append-to-body
style="width: 60px; height: 60px"
:src="scope.row.picturePath"
:zoom-rate="1.2"
fit="cover"
>
<div slot="error" class="image-slot">
<i class="el-icon-picture-outline"></i>
</div>
</image-preview>
</div>
<div v-if="scope.row.warning === '有'">
<el-image
style="width: 60px; height: 60px"
:src="scope.row.picturePath"
:fit="fit"
/>
</div>
</template>
</el-table-column>
</el-table>
</div>
</div>
<div class="bottonFold" @click="bottomFoldClick">
<el-tooltip
:disabled="bottomFold"
:show-arrow="false"
hide-after="0"
show-after="200"
class="box-item"
effect="dark"
content="展开"
placement="top"
>
<img v-if="!bottomFold" src="@/assets/images/open2.png" alt="" />
</el-tooltip>
<el-tooltip
:disabled="!bottomFold"
:show-arrow="false"
hide-after="0"
show-after="200"
class="box-item"
effect="dark"
content="收起"
placement="top"
>
<img
class="imgrotate"
v-if="bottomFold"
src="@/assets/images/open2.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" class="ol-popup">
<div class="pophead" style="width: 100%; height: 0px">
<div
id="popup-title"
style="
font: bold 15px sans-serif;
align: left;
position: absolute;
top: 5px;
left: 8px;
color: #000000;
"
></div>
<a
href="#"
id="popup-closer"
class="ol-popup-closer"
style="color: #8e908c"
></a>
</div>
<div id="popup-content" style="padding: 10px"></div>
</div>
<div id="pop">
<div class="content">
<div>
设备:
<p>{{ popdata.dev_code }}</p>
</div>
<div>
经度:
<p>{{ popdata.msLongitude }}</p>
</div>
<div>
纬度:
<p>{{ popdata.msLatitude }}</p>
</div>
<div>
设备状况:
<p>
<span
style="background-color: rgba(67, 207, 124, 1)"
v-if="popdata.equipment == '正常'"
>
{{ popdata.equipment }}
</span>
<span style="background: red" v-else>{{ popdata.equipment }}</span>
</p>
</div>
</div>
<div class="cancel" @click="hiddenOverlayChart">X</div>
</div>
<el-button v-if="flag" class="back_button" @click="back()">返回</el-button>
<el-dialog destroy-on-close v-model="visible" :show-close="false">
<template #header="{ close, titleId, titleClass }">
<div class="my-header">
<h4 :id="titleId" :class="titleClass">历史数据查询</h4>
<div class="buttonbox">
<el-button type="primary" @click="query">
<span style="vertical-align: middle">查询</span>
</el-button>
<el-button type="primary" @click="ondownload()">
<span style="vertical-align: middle">下载</span>
</el-button>
<el-button type="primary" @click="resetting">
<span style="vertical-align: middle">重置</span>
</el-button>
&emsp;
<el-icon style="cursor: pointer" @click="close"><Close /></el-icon>
</div>
</div>
</template>
<div class="select_div">
<div class="slele_time">
<div class="time_on">
开始时间:
<el-date-picker v-model="value1" type="datetime" placeholder="请选择" />
</div>
&emsp;
<div class="time_end">
结束时间:
<el-date-picker v-model="value2" type="datetime" placeholder="请选择" />
</div>
&emsp;
<div class="flag">
预警情况:
<el-select v-model="value3" class="m-2" placeholder="请选择">
<el-option
v-for="item in flagarr"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</div>
</div>
<div class="device">
<el-select v-model="deviceValue" class="m-2" placeholder="请选择">
<el-option
popper-class="device_item"
v-for="item in options"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</div>
</div>
<div class="tableDiv">
<el-table
:header-cell-style="{ 'text-align': 'center' }"
:cell-style="{ 'text-align': 'center' }"
:data="pagingarr"
stripe
style="width: 100%"
>
<el-table-column prop="id" label="编号" />
<el-table-column prop="devCode" label="设备号" />
<el-table-column prop="pictureTime" label="监测时间" />
<el-table-column class="red" prop="warning" width="52" label="预警情况">
<template #default="scope">
<span
v-if="scope.row.warning === '有'"
style="
background-color: rgba(255, 62, 57, 1);
padding: 2px 12px 2px 12px;
border-radius: 2px;
"
>
{{ scope.row.warning }}
</span>
<span
v-else
style="
background-color: rgba(9, 222, 133, 1);
padding: 5px 10px;
border-radius: 2px;
"
>
{{ scope.row.warning }}
</span>
</template>
</el-table-column>
<el-table-column prop="picturePath" label="照片">
<template #default="scope">
<div v-if="scope.row.warning === '无'">
<image-preview
append-to-body
style="width: 60px; height: 60px"
:src="scope.row.picturePath"
:zoom-rate="1.2"
fit="cover"
>
<div slot="error" class="image-slot">
<i class="el-icon-picture-outline"></i>
</div>
</image-preview>
</div>
<div v-if="scope.row.warning === '有'">
<el-image
style="width: 60px; height: 60px"
:src="scope.row.picturePath"
:fit="fit"
/>
</div>
</template>
</el-table-column>
</el-table>
<div class="block">
<el-pagination
background
layout="prev, pager, next"
:current-page="currentPage"
:page-size="pageSize"
@current-change="handleCurrentChange"
:total="tableData.arr.length"
/>
</div>
</div>
</el-dialog>
<el-dialog destroy-on-close v-model="visibles" :show-close="false">
<template #header="{ close, titleId, titleClass }">
<div class="my-header">
<h4 :id="titleId" :class="titleClass">历史数据查询</h4>
<div class="buttonbox">
<el-button type="primary" @click="querys">
<span style="vertical-align: middle">查询</span>
</el-button>
<el-button type="primary" @click="ondownload2">
<span style="vertical-align: middle">下载</span>
</el-button>
<el-button @click="resettings" type="primary">
<span style="vertical-align: middle">重置</span>
</el-button>
&emsp;
<el-icon style="cursor: pointer" @click="close"><Close /></el-icon>
</div>
</div>
</template>
<div class="select_div">
<div class="slele_time">
<div class="time_on">
开始时间:
<el-date-picker v-model="value1" type="datetime" placeholder="请选择" />
</div>
&emsp;
<div class="time_end">
结束时间:
<el-date-picker v-model="value2" type="datetime" placeholder="请选择" />
</div>
&emsp;
<div class="flag">
预警情况:
<el-select v-model="value3" class="m-2" placeholder="请选择">
<el-option
v-for="item in flagarr"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</div>
</div>
<div class="device">
<el-select v-model="deviceValue" class="m-2" placeholder="请选择">
<el-option
popper-class="device_item"
v-for="item in options"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</div>
</div>
<div class="tableDiv">
<el-table
:header-cell-style="{ 'text-align': 'center' }"
:cell-style="{ 'text-align': 'center' }"
:data="bugarrs"
stripe
style="width: 100%"
@cell-click="cellClick"
>
<el-table-column prop="id" label="编号" />
<el-table-column prop="devCode" label="设备号" />
<el-table-column prop="pictureTime" label="监测时间" />
<el-table-column class="red" prop="warning" width="52" label="预警情况">
<template #default="scope">
<span
v-if="scope.row.warning === '有'"
style="
background-color: rgba(255, 62, 57, 1);
padding: 2px 12px 2px 12px;
border-radius: 2px;
"
>
{{ scope.row.warning }}
</span>
<span
v-else
style="
background-color: rgba(9, 222, 133, 1);
padding: 5px 10px;
border-radius: 2px;
"
>
{{ scope.row.warning }}
</span>
</template>
</el-table-column>
<el-table-column prop="picturesMark2O1List" label="害虫名称">
<template #default="scope">
<span
v-for="(item, index) in scope.row.picturesMark2O1List"
:key="index"
>
{{
scope.row.picturesMark2O1List.length > 0
? item.pestName
: '无'
}},
</span>
</template>
</el-table-column>
<el-table-column prop="pictureTime" label="害虫个数">
<template #default="scope">
<span>{{ scope.row.picturesMark2O1List.length }}</span>
</template>
</el-table-column>
<el-table-column prop="picturePath" label="照片">
<template #default="scope">
<div v-if="scope.row.warning === '无'">
<image-preview
append-to-body
style="width: 60px; height: 60px"
:src="scope.row.picturePath"
:zoom-rate="1.2"
fit="cover"
>
<div slot="error" class="image-slot">
<i class="el-icon-picture-outline"></i>
</div>
</image-preview>
</div>
<div v-if="scope.row.warning === '有'">
<el-image
style="width: 60px; height: 60px"
:src="scope.row.picturePath"
:fit="fit"
/>
</div>
</template>
</el-table-column>
</el-table>
<div class="block">
<el-pagination
background
layout="prev, pager, next"
:current-page="currentPage"
:page-size="pageSize"
@current-change="handleCurrentChanges"
:total="bugarr.length"
/>
</div>
</div>
</el-dialog>
<el-dialog destroy-on-close v-model="visibless" :show-close="false">
<template #header="{ close, titleId, titleClass }">
<div class="my-header">
<h4 :id="titleId" :class="titleClass">土壤历史数据查询</h4>
<div class="buttonbox">
<el-button type="primary" @click="queryss">
<span style="vertical-align: middle">查询</span>
</el-button>
<el-button type="primary" @click="ondownload3">
<span style="vertical-align: middle">下载</span>
</el-button>
<el-button @click="resettingss" type="primary">
<span style="vertical-align: middle">重置</span>
</el-button>
&emsp;
<el-icon style="cursor: pointer" @click="close"><Close /></el-icon>
</div>
</div>
</template>
<div class="select_div">
<div class="slele_time">
<div class="time_on">
开始时间:
<el-date-picker v-model="value1" type="datetime" placeholder="请选择" />
</div>
&emsp;
<div class="time_end">
结束时间:
<el-date-picker v-model="value2" type="datetime" placeholder="请选择" />
</div>
&emsp;
<div class="flag">
预警情况:
<el-select v-model="value3" class="m-2" placeholder="请选择">
<el-option
v-for="item in flagarr"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</div>
</div>
<div class="device">
<el-select v-model="deviceValue" class="m-2" placeholder="请选择">
<el-option
popper-class="device_item"
v-for="item in options"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</div>
</div>
<div class="tableDiv">
<el-table
:header-cell-style="{ 'text-align': 'center' }"
:cell-style="{ 'text-align': 'center' }"
:data="soilArr"
stripe
style="width: 100%"
>
<el-table-column prop="dataTime" label="日期" />
<el-table-column prop="soilTemperature1" label="0cm温度" />
<el-table-column prop="soilTemperature2" label="-10cm温度" />
<el-table-column prop="soilTemperature3" label="-20cm温度" />
<el-table-column prop="soilTemperature4" label="-30cm温度" />
<el-table-column prop="soilTemperature5" label="-40温度" />
<el-table-column prop="soilHumidity1" width="80" label="0cm湿度(%rh)" />
<el-table-column prop="soilHumidity2" label="-10cm湿度" />
<el-table-column prop="soilHumidity3" label="-20cm湿度" />
<el-table-column prop="soilHumidity4" label="-30cm湿度" />
<el-table-column prop="soilHumidity5" label="-40cm湿度" />
<el-table-column prop="soilPh" width="70" label="PH值ph" />
<el-table-column prop="soilEc" width="70" label="EC值(S/cm)" />
<el-table-column class="red" prop="warning" width="52" label="预警情况">
<template #default="scope">
<span
v-if="scope.row.warning === '有'"
style="
background-color: rgba(255, 62, 57, 1);
padding: 2px 12px 2px 12px;
border-radius: 2px;
"
>
{{ scope.row.warning }}
</span>
<span
v-else
style="
background-color: rgba(9, 222, 133, 1);
padding: 2px 12px 2px 12px;
border-radius: 2px;
"
>
{{ scope.row.warning }}
</span>
</template>
</el-table-column>
</el-table>
<div class="block">
<el-pagination
background
layout="prev, pager, next"
:current-page="currentPage"
:page-size="pageSize"
@current-change="handleCurrentChangess"
:total="soilAll.length"
/>
</div>
</div>
</el-dialog>
<div class="modelDiv">
<el-dialog destroy-on-close v-model="dialogTableVisible" title="预警情况">
<image-preview
append-to-body
:src="gridData.picturePath"
:zoom-rate="1.2"
fit="cover"
>
<div slot="error" class="image-slot">
<i class="el-icon-picture-outline"></i>
</div>
</image-preview>
<!-- <el-image :src="gridData.picturePath">
<template #placeholder>
<div class="image-slot">
Loading
<span class="dot">...</span>
</div>
</template>
</el-image> -->
<div class="center">
<div class="header">识别结果</div>
<div v-for="(item, index) in gridArr" :key="index">
<span>害虫名称:{{ index }}</span>
<span>害虫个数:{{ item }}</span>
</div>
</div>
</el-dialog>
</div>
</div>
<div class="tabulation">
<el-tabs v-model="activeName" class="demo-tabs" @tab-click="handleClick">
<el-tab-pane label="全部" name="全部"></el-tab-pane>
<el-tab-pane label="智能孢子仪" name="智能孢子仪" />
<el-tab-pane label="虫情监测仪" name="虫情监测仪" />
<el-tab-pane label="土壤墒情、土质" name="土壤墒情、土质" />
</el-tabs>
<div class="tabulationCente">
<div class="left">
<p>
当前选择
<span style="color: rgba(100, 195, 164, 1)">{{ label2 }}</span>
</p>
<el-tree
:data="devicesArr"
:props="defaultProps"
@node-click="handleNodeClick"
/>
</div>
<div class="freckle">
<div class="searchDiv">
<el-form :inline="true" :model="formInline" class="demo-form-inline">
<el-form-item style="width: 180px" label="预警情况:">
<el-select
popper-class="selectCity"
v-model="formInline.flag"
placeholder="请选择"
>
<el-option label="有" value="有" />
<el-option label="无" value="无" />
</el-select>
</el-form-item>
<el-form-item style="width: 300px" label="监测时间:">
<el-date-picker
v-model="value1"
type="daterange"
range-separator="➡️"
start-placeholder="开始日期"
end-placeholder="结束日期"
/>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit">查询</el-button>
<el-button plain @click="resetForm">重置</el-button>
<el-button v-if="!operate" type="primary" text @click="dowcity">
<img src="@/assets/images/dow.png" alt="" />
下载
</el-button>
</el-form-item>
</el-form>
<div class="modeDiv" @click="SwitchMode">
<div :class="SwitchFlag ? 'Selected' : ''">表格模式</div>
<div :class="SwitchFlag ? '' : 'Selecteds'">图表模式</div>
</div>
</div>
<div class="chartModeFather">
<div class="tableBox" v-show="SwitchFlag">
<el-table
:data="tableNewData"
:header-cell-style="{ 'text-align': 'center' }"
:cell-style="{ 'text-align': 'center' }"
header-row-class-name="tabth"
height="80%"
highlight-current-row
>
<el-table-column fixed="left" width="160" label="监测时间">
<template #default="scope">
<span v-if="label3 == '土壤墒情、土质'">
{{ scope.row.dataTime }}
</span>
<span v-if="label3 !== '土壤墒情、土质'">
{{ scope.row.pictureTime }}
</span>
</template>
</el-table-column>
<el-table-column class="red" label="预警情况">
<template #default="scope">
<span
v-if="scope.row.warning === '有'"
style="
background-color: rgba(255, 62, 57, 1);
color: rgba(255, 255, 255, 1);
padding: 2px 12px 2px 12px;
border-radius: 2px;
"
>
{{ scope.row.warning }}
</span>
<span
v-else
style="
background-color: rgba(9, 222, 133, 1);
padding: 2px 12px 2px 12px;
color: rgba(255, 255, 255, 1);
border-radius: 2px;
"
>
{{ scope.row.warning }}
</span>
</template>
</el-table-column>
<el-table-column
v-for="(item, index) in tableItem"
:key="index"
:label="item.lable"
width="120"
>
<template #default="scope">
<div v-if="label3 == '虫情监测仪'">
<span
v-if="scope.row.warning === '有'"
style="color: red"
>
<span
v-for="(value, key) in scope.row.obj"
:key="key"
>
{{ key }}{{ value }}只
<br />
</span>
<!-- {{
scope.row.picturesMark2O1List[0].pestName +
':' +
scope.row.picturesMark2O1List.length
}}个 -->
</span>
<span v-else>
{{ scope.row.warning }}
</span>
</div>
<div v-if="label3 == '土壤墒情、土质'">
<span
v-if="
scope.row.style &&
scope.row.style.includes(item.value)
"
style="color: red"
>
{{ scope.row[item.value] }}
</span>
<span v-else>
{{ scope.row[item.value] }}
</span>
</div>
</template>
</el-table-column>
<el-table-column label="操作">
<template #default="scope">
<span
style="color: rgba(100, 195, 164, 1); cursor: pointer"
@click="onDetail(scope.row)"
>
查看详情
</span>
</template>
</el-table-column>
</el-table>
<div class="example-pagination-block">
共{{ tabulation.length }}条
<el-pagination
background
layout="prev, pager, next"
:total="tabulation.length"
:current-page="tabulationcurrentPage"
:page-size="tabulationpageSize"
@current-change="tabulationCurrentChange"
/>
</div>
</div>
<div v-show="!SwitchFlag" class="chartMode">
<div v-if="label3 == '土壤墒情、土质'" class="depth">
<p
:class="active == '1' ? 'SelectedDiv' : ''"
@click="depthclick(1)"
>
0cm
</p>
<p
:class="active == '2' ? 'SelectedDiv' : ''"
@click="depthclick(2)"
>
-10cm
</p>
<p
:class="active == '3' ? 'SelectedDiv' : ''"
@click="depthclick(3)"
>
-20cm
</p>
<p
:class="active == '4' ? 'SelectedDiv' : ''"
@click="depthclick(4)"
>
-30cm
</p>
<p
:class="active == '5' ? 'SelectedDiv' : ''"
@click="depthclick(5)"
>
-40cm
</p>
<p
:class="active == '6' ? 'SelectedDiv' : ''"
@click="depthclick(6)"
>
EC值
</p>
<p
:class="active == '7' ? 'SelectedDiv' : ''"
@click="depthclick(7)"
>
PH值
</p>
</div>
<div
v-show="label3 == '土壤墒情、土质'"
ref="chartModeDiv"
class="chartModeDiv"
></div>
<div class="tableBoxs" v-if="label3 !== '土壤墒情、土质'">
<div class="insectDiv">
<el-row class="gutters" :gutter="40">
<el-col
v-for="(item, index) in tableNewData"
:key="index"
:span="6"
>
<el-card :body-style="{ padding: '0px' }">
<div class="ins">
<image-preview
append-to-body
:src="item.picturePath"
:zoom-rate="1.2"
fit="cover"
>
<div slot="error" class="image-slot">
<i class="el-icon-picture-outline"></i>
</div>
</image-preview>
<span
v-if="item.warning == '无'"
style="
background-color: rgba(67, 207, 124, 1);
"
class="yj"
>
无预警
</span>
<span
v-if="item.warning == '有'"
style="background-color: red"
class="yj"
>
有预警
</span>
</div>
<div style="font-size: 12px">
<div class="bottom">
<time class="time">
{{ item.pictureTime }}
</time>
</div>
<br />
<span
style="color: red"
v-if="item.warning == '有'"
>
<span
v-for="(value, key) in item.obj"
:key="key"
>
{{ key }}:{{ value }}只
<br />
</span>
</span>
<span
style="color: rgba(67, 207, 124, 1)"
v-if="item.warning == '无'"
>
正常
</span>
</div>
</el-card>
</el-col>
</el-row>
</div>
<div class="example-pagination-block">
共{{ tabulation.length }}条
<el-pagination
background
layout="prev, pager, next"
:total="tabulation.length"
:current-page="tabulationcurrentPage"
:page-size="tabulationpageSize"
@current-change="tabulationCurrentChange"
/>
</div>
</div>
</div>
</div>
</div>
<div class="centent">
<div class="arrow" @click="foldClick">
<p v-if="!flags">
<img style="width: 300%" src="@/assets/images/shouhui.png" />
</p>
<p v-if="flags">
<img style="width: 300%" src="@/assets/images/zhankai.png" />
</p>
</div>
</div>
<div v-show="!flags" class="cesiumContainersDiv">
<div id="cesiumContainers" class="detailed"></div>
<div id="pops">
<div class="content">
<div>
设备:
<p>{{ popdata.dev_code }}</p>
</div>
<div>
经度:
<p>{{ popdata.msLongitude }}</p>
</div>
<div>
纬度:
<p>{{ popdata.msLatitude }}</p>
</div>
<div>
设备状况:
<p>
<span
style="background-color: rgba(67, 207, 124, 1)"
v-if="popdata.equipment == '正常'"
>
{{ popdata.equipment }}
</span>
<span style="background: red" v-else>
{{ popdata.equipment }}
</span>
</p>
</div>
</div>
<div class="cancel" @click="hiddenOverlayCharts">X</div>
</div>
</div>
</div>
<el-dialog
v-model="DetailVisible"
title="监测结果详情"
width="35%"
:before-close="handleClose"
>
<div v-if="label3 !== '土壤墒情、土质'" class="rowContent">
<div class="rowContentTop">
<div class="rowContentchildren">
<p>
{{ DetailArr.devCode }}
<span
v-if="DetailArr.warning == '有'"
style="background: rgba(212, 48, 48, 1)"
>
有预警
</span>
<span
v-if="DetailArr.warning == '无'"
style="background: rgba(67, 207, 124, 1)"
>
无预警
</span>
</p>
<span>{{ DetailArr.pictureTime }}</span>
</div>
<div v-if="DetailArr.warning == '有'">
<span v-if="label3 == '虫情监测仪'">
<span v-for="(value, key) in DetailArr.obj" :key="key">
{{ key }}:{{ value }}只,
</span>
</span>
</div>
</div>
<image-preview
v-if="label3 !== '土壤墒情、土质'"
append-to-body
:src="`${DetailArr.picturePath}`"
:zoom-rate="1.2"
fit="cover"
>
<div slot="error" class="image-slot">
<i class="el-icon-picture-outline"></i>
</div>
</image-preview>
</div>
<div class="rowContent_bottom" v-if="label3 == '土壤墒情、土质'">
<div class="rowContentTop">
<div class="rowContentchildren">
<p>
<span
style="
font-size: 16px;
font-weight: 700;
color: rgba(100, 195, 164, 1);
margin-left: 0;
"
>
土壤墒情
</span>
<span
v-if="DetailArr.warning == '有'"
style="background: rgba(212, 48, 48, 1)"
>
有预警
</span>
<span
v-if="DetailArr.warning == '无'"
style="background: rgba(67, 207, 124, 1)"
>
无预警
</span>
</p>
<span>{{ DetailArr.dataTime }}</span>
</div>
<div v-if="DetailArr.warning == '有'">
<span
v-for="(item, index) in DetailArr.style"
:key="index"
style="font-size: 16px; font-weight: 00"
>
&emsp;
{{ dictionary[item] }} :
<span style="color: red; font-size: 18px; font-weight: 700">
{{ DetailArr[item] }}
</span>
</span>
</div>
</div>
<p style="margin-left: 15px; font-size: 16px; font-weight: 700">土壤湿度</p>
<div class="rowContentTop">
<div>
<div class="rowContentTopChildren">
<div>
0cm湿度(℃):
<span
style="
color: rgba(67, 207, 124, 1);
font-size: 18px;
font-weight: 700;
"
v-if="
DetailArr.soilHumidity1 >= 5 ||
DetailArr.soilHumidity1 <= 60
"
>
{{ DetailArr.soilHumidity1 }}
</span>
<span
style="
color: rgba(212, 48, 48, 1);
font-size: 18px;
font-weight: 700;
"
v-else
>
{{ DetailArr.soilHumidity1 }}
</span>
</div>
<div>
-10cm湿度(℃):
<span
style="
color: rgba(67, 207, 124, 1);
font-size: 18px;
font-weight: 700;
"
v-if="
DetailArr.soilHumidity2 >= 0 ||
DetailArr.soilHumidity2 <= 30
"
>
{{ DetailArr.soilHumidity2 }}
</span>
<span
style="
color: rgba(212, 48, 48, 1);
font-size: 18px;
font-weight: 700;
"
v-else
>
{{ DetailArr.soilHumidity2 }}
</span>
</div>
<div>
-20cm湿度(℃):
<span
style="
color: rgba(67, 207, 124, 1);
font-size: 18px;
font-weight: 700;
"
v-if="
DetailArr.soilHumidity3 >= 0 ||
DetailArr.soilHumidity3 <= 30
"
>
{{ DetailArr.soilHumidity3 }}
</span>
<span
style="
color: rgba(212, 48, 48, 1);
font-size: 18px;
font-weight: 700;
"
v-else
>
{{ DetailArr.soilHumidity3 }}
</span>
</div>
<div>
-30cm湿度(℃):
<span
style="
color: rgba(67, 207, 124, 1);
font-size: 18px;
font-weight: 700;
"
v-if="
DetailArr.soilHumidity4 >= 0 ||
DetailArr.soilHumidity4 <= 40
"
>
{{ DetailArr.soilHumidity4 }}
</span>
<span
style="
color: rgba(212, 48, 48, 1);
font-size: 18px;
font-weight: 700;
"
v-else
>
{{ DetailArr.soilHumidity4 }}
</span>
</div>
<div>
-40cm湿度(℃):
<span
style="
color: rgba(67, 207, 124, 1);
font-size: 18px;
font-weight: 700;
"
v-if="
DetailArr.soilHumidity5 >= 0 ||
DetailArr.soilHumidity5 <= 40
"
>
{{ DetailArr.soilHumidity5 }}
</span>
<span
style="
color: rgba(212, 48, 48, 1);
font-size: 18px;
font-weight: 700;
"
v-else
>
{{ DetailArr.soilHumidity5 }}
</span>
</div>
</div>
</div>
</div>
<p style="margin-left: 15px; font-size: 16px; font-weight: 700">土壤温度</p>
<div class="rowContentTop">
<div>
<div class="rowContentTopChildren">
<div>
0cm温度(℃):
<span
style="
color: rgba(67, 207, 124, 1);
font-size: 18px;
font-weight: 700;
"
v-if="
DetailArr.soilTemperature1 >= -10 &&
DetailArr.soilTemperature1 <= 40
"
>
{{ DetailArr.soilTemperature1 }}
</span>
<span
style="
color: rgba(212, 48, 48, 1);
font-size: 18px;
font-weight: 700;
"
v-else
>
{{ DetailArr.soilTemperature1 }}
</span>
</div>
<div>
-10cm温度(℃):
<span
style="
color: rgba(67, 207, 124, 1);
font-size: 18px;
font-weight: 700;
"
v-if="
DetailArr.soilTemperature2 >= -5 &&
DetailArr.soilTemperature2 <= 40
"
>
{{ DetailArr.soilTemperature2 }}
</span>
<span
style="
color: rgba(212, 48, 48, 1);
font-size: 18px;
font-weight: 700;
"
v-else
>
{{ DetailArr.soilTemperature2 }}
</span>
</div>
<div>
-20cm温度(℃):
<span
style="
color: rgba(67, 207, 124, 1);
font-size: 18px;
font-weight: 700;
"
v-if="
DetailArr.soilTemperature3 >= 0 &&
DetailArr.soilTemperature3 <= 30
"
>
{{ DetailArr.soilTemperature3 }}
</span>
<span
style="
color: rgba(212, 48, 48, 1);
font-size: 18px;
font-weight: 700;
"
v-else
>
{{ DetailArr.soilTemperature3 }}
</span>
</div>
<div>
-30cm温度(℃):
<span
style="
color: rgba(67, 207, 124, 1);
font-size: 18px;
font-weight: 700;
"
v-if="
DetailArr.soilTemperature4 >= 0 &&
DetailArr.soilTemperature4 <= 30
"
>
{{ DetailArr.soilTemperature4 }}
</span>
<span
style="
color: rgba(212, 48, 48, 1);
font-size: 18px;
font-weight: 700;
"
v-else
>
{{ DetailArr.soilTemperature4 }}
</span>
</div>
<div>
-40cm温度(℃):
<span
style="
color: rgba(67, 207, 124, 1);
font-size: 18px;
font-weight: 700;
"
v-if="
DetailArr.soilTemperature5 >= 0 &&
DetailArr.soilTemperature5 <= 30
"
>
{{ DetailArr.soilTemperature5 }}
</span>
<span
style="
color: rgba(212, 48, 48, 1);
font-size: 18px;
font-weight: 700;
"
v-else
>
{{ DetailArr.soilTemperature5 }}
</span>
</div>
</div>
</div>
</div>
<p style="margin-left: 15px; font-size: 16px; font-weight: 700">土质</p>
<div class="rowContentTop">
<div>
<div class="rowContentTopChildren">
<div>
土壤EC值:
<span
style="
color: rgba(67, 207, 124, 1);
font-size: 18px;
font-weight: 700;
"
v-if="DetailArr.soilEc >= 0 && DetailArr.soilEc <= 0.2"
>
{{ DetailArr.soilEc }}
</span>
<span
style="
color: rgba(212, 48, 48, 1);
font-size: 18px;
font-weight: 700;
"
v-else
>
{{ DetailArr.soilEc }}
</span>
</div>
<div>
土壤PH值:
<span
style="
color: rgba(67, 207, 124, 1);
font-size: 18px;
font-weight: 700;
"
v-if="DetailArr.soilPh > 5.5 && DetailArr.soilPh < 7.5"
>
{{ DetailArr.soilPh }}
</span>
<span
style="
color: rgba(212, 48, 48, 1);
font-size: 18px;
font-weight: 700;
"
v-else
>
{{ DetailArr.soilPh }}
</span>
</div>
</div>
</div>
</div>
</div>
</el-dialog>
</div>
</div>
</template>
<script setup>
import { ref, onMounted, inject, reactive, watch } from 'vue';
import * as echarts from 'echarts';
import TimeLine from '@/components/TimeLine/TimeLine.vue';
import { downLoadFile } from '@/utils/download.js';
import { useEcharts } from '@/hooks/useEcharts';
// import MapInit from '.././components/tiandituapi/tianditu_api.js'
import { getarea, getTownship, getvillage, getareas, dow } from '@/api/crops/classify.js';
import {
getSpore,
getfindAllSoil,
getinsect,
getsporeEquipment,
detectionLightsEquipment,
getsporeEquipmentCondition,
getequipmentCondition,
geteqLightEquipmentCondition,
soilEquipment,
getdeviceNumber,
getfindAllSoilTb,
} from '@/api/pestis/pestis.js';
import axios from 'axios';
import 'echarts-gl';
import moment from 'Moment';
import { useRouter } from 'vue-router';
import 'leaflet/dist/leaflet.css';
import L from 'leaflet';
import iconShadow from '/img/marker/mark.png';
let map = L.Map;
const router = useRouter();
const visible = ref(false); //孢子历史数据弹框
const visibles = ref(false); //历史数据弹框
const url = '@/assets/images/shouhui.png';
let flags = ref(false);
const visibless = ref(false);
let dialogTableVisible = ref(false);
let viewer = ref(null);
let viewers = ref(null);
let viewers2 = ref(null);
let viewers3 = ref(null);
let viewers4 = ref(null);
const cesiumContainer = ref(null);
const farmlandDiv = ref(null);
const Phdiv = ref(null);
const soilDiv = ref(null);
const value = ref('370211');
let Township = reactive({ arr: [], brr: [], crr: [] }); //街道
let OptionArr = reactive({ arr: [] });
const clickInfoMap = ref({ name: '', value: '' });
let soilAll = ref([]);
const insectarr = ref([]);
const formLandRef = ref([]);
const flag = ref(false);
let brightFlag = ref('4');
let brightFlags = ref(true);
let bottomFlags = ref(true);
let leftWraFlag = ref(true);
let rightWraFlag = ref(true);
let bottomFold = ref(true);
let label1 = ref('');
let label2 = ref('');
let label3 = ref('');
const value1 = ref(''); //开始时间
const value2 = ref(''); //结束时间
let value3 = ref(''); //结束时间
let devicesArr = ref([]); //全部设备编号
let Site = ref([]); //站点标号
let SwitchFlag = ref(true);
let seachData = ref({});
let tableNewData = ref([]);
let tabulation = ref([]); //列表模式
let tableItem = ref([]);
let DetailVisible = ref(false);
let center = '';
let nums = ref(0);
const flagarr = ref([
{
value: '有',
label: '有',
},
{
value: '无',
label: '无',
},
]);
const deviceValue = ref(''); //设备选择
let currentPage = ref(1); //当前页
let pageSize = ref(5); //每页条数
let pagingarr = ref([]); //孢子当前页
let bugarr = ref([]); //孢子总条数
let bugarrs = ref([]); //虫情当前页
let bugarrtime = ref([]); //最近三天虫情
let soilArr = ref([]); //土壤当前页
let EcTimeArr = ref([]); //ec时间
let EcArr = ref([]); //ec值
let PhArr = ref([]); //ph值
let active = ref('1'); //厘米高亮
let temperature = ref([]); //温度集合
let temperature1 = ref([]); //温度集合
let temperature2 = ref([]); //温度集合
let temperature3 = ref([]); //温度集合
let temperature4 = ref([]); //温度集合
let temperature5 = ref([]); //温度集合
let humidity = ref([]); //湿度集合
let humidity1 = ref([]); //湿度集合
let humidity2 = ref([]); //湿度集合
let humidity3 = ref([]); //湿度集合
let humidity4 = ref([]); //湿度集合
let humidity5 = ref([]); //湿度集合
let soilPh = ref([]);
let soilEc = ref([]);
let popdata = ref({});
let gridData = ref([]);
const chartModeDiv = ref(null);
let tabulationcurrentPage = ref(1); //列表当前页
let tabulationpageSize = ref(12); //每页条数
const activeName = ref('全部'); //tabs
let DetailArr = ref([]);
let gridArr = ref({});
const dictionary = ref({
soilTemperature1: '0cm温度',
soilTemperature2: '-10cm温度',
soilTemperature3: '-20cm温度',
soilTemperature4: '-30cm温度',
soilTemperature5: '-40cm温度',
soilHumidity1: '0cm湿度(%)',
soilHumidity2: '-10cm湿度(%)',
soilHumidity3: '-20cm湿度(%)',
soilHumidity4: '-30cm湿度(%)',
soilHumidity5: '-40cm湿度(%)',
soilPh: 'PH值(ph)',
soilEc: 'EC值(S/cm)',
});
let layers = ref(null); //村
let iconLayer = ref(null);
//搜索
let formInline = ref({
yearMonth: '',
flag: '',
divisions: '',
});
var baozi =
'';
var chong =
'';
var tu =
'';
//创建多个icon
const options = ref([
{
value: 'dev10101',
label: 'dev10101',
},
{
value: 'dev20101',
label: 'dev20101',
},
]);
watch(
() => Township.arr,
val => {
console.log('val:', val);
}
);
//行政区划数据
var data = {
title: [],
};
let dd = {
小麦: [],
玉米: [],
大豆: [],
地瓜: [],
花生: [],
蓝莓: [],
茶叶: [],
马铃薯: [],
白菜和萝卜: [],
其他: [],
};
//表格数据
let tableData = reactive({ arr: [], arrs: [] });
// 组件挂载完成后执行
onMounted(() => {
initonMounted();
});
function initonMounted() {
/*------------地图---------------- */
// initMap();
initmap();
/*------------请求---------------- */
getSporestime(); //孢子
getsporeEquipmentConditions(); //孢子设备信息
getfindAllSoils(); //土壤
getinsects(); //虫情
getaArea(); //面积
initLeafletMap();
// getTownships();
getdeviceNumbers('0'); //所有设备列表
farmland();
Ph();
soil();
DefaultList(); //默认显示列表模式
localStorage.setItem(router.currentRoute.value.path, false);
}
onUpdated(() => {
if (localStorage.getItem(router.currentRoute.value.path) == 'true') {
document.querySelector('.mode').innerText = '列表模式';
window.document.querySelector('#screenfull').style.display = 'block';
} else {
document.querySelector('.mode').innerText = '地图模式';
window.document.querySelector('#screenfull').style.display = 'none';
}
});
/*-------------地图------------------------*/
let maps = ref(null);
function initmap() {
maps = new ol.Map({
target: 'cesiumContainer',
controls: ol.control
.defaults({
attributionOptions: {
collapsed: true,
},
})
.extend([new ol.supermap.control.Logo(), new ol.control.ScaleLine()]),
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',
}),
}),
//注记
// new ol.layer.Tile({
// source: new ol.source.Tianditu({
// layerType: 'img',
// isLabel: true,
// key: '1d109683f4d84198e37a38c442d68311',
// }),
// }),
],
});
cun();
zhen();
//滚轮控制村级矢量
maps.on('moveend', function (e) {
var zoom = maps.getView().getZoom(); //获取当前地图的缩放级别
if (zoom >= 13) {
layers.setVisible(true); //显示图层
} else {
layers.setVisible(false);
}
});
alter();
}
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,
});
maps.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,
});
maps.addLayer(layer);
};
// 位置图标显示
let positionLayer = null;
let iconStyle = null;
let iconFeature = null;
let vectorSource = null;
const positionIcon = (center, img, name) => {
iconFeature = new ol.Feature({
geometry: new ol.geom.Point(center),
name: name,
population: 4000,
rainfall: 500,
});
iconStyle = new ol.style.Style({
image: new ol.style.Icon({
anchor: [0.5, 46],
scale: 0.4,
anchorXUnits: 'fraction',
anchorYUnits: 'pixels',
src: img,
}),
});
iconFeature.setStyle(iconStyle);
vectorSource = new ol.source.Vector({
features: [iconFeature],
});
positionLayer = new ol.layer.Vector({
source: vectorSource,
});
maps.addLayer(positionLayer);
};
// 创建弹框 overlay
const alter = () => {
var container = document.getElementById('popup');
//拿到弹出框内容元素
var content = document.getElementById('popup-content');
//拿到弹出框关闭元素
var popupCloser = document.getElementById('popup-closer');
//创建弹出框容器
var overlay1 = new ol.Overlay({
//设置弹出框的容器
element: container,
//是否自动平移,即假如标记在屏幕边缘,弹出时自动平移地图使弹出框完全可见
autoPan: true,
autoPanAnimation: {
duration: 250,
//当Popup超出地图边界时为了Popup全部可见地图移动的速度.
},
});
//点击图标显示自定义弹出框
maps.on('click', function (e) {
console.log(e.coordinate);
var pixel = maps.getEventPixel(e.originalEvent);
maps.forEachFeatureAtPixel(pixel, function (feature) {
var attr = feature.getProperties();
console.log(attr);
content.innerHTML =
'<div>' +
'<p>设备名称: ' +
attr.name +
'</p>' +
'<p>经度:' +
attr.geometry.flatCoordinates[0] +
'</p>' +
'<p>纬度:' +
attr.geometry.flatCoordinates[1] +
'</p>' +
'</div>';
overlay1.setPosition(attr.geometry.flatCoordinates);
maps.addOverlay(overlay1);
});
});
//关闭弹出框操作
popupCloser.addEventListener('click', function () {
overlay1.setPosition(undefined);
});
};
const initLeafletMap = () => {
map = L.map('cesiumContainers', {
center: [36.4, 119.166326], // 地图中心
zoom: 7, //缩放比列
zoomControl: false, //禁用 + - 按钮
doubleClickZoom: false, // 禁用双击放大
attributionControl: false, // 移除右下角leaflet标识
});
// 渲染底图
L.tileLayer(
'http://t0.tianditu.com/DataServer?T=img_w&tk=5956e6519f2bb0ae8e57bc834298c9f1&x={x}&y={y}&l={z}'
).addTo(map);
L.tileLayer(
'http://t0.tianditu.com/DataServer?T=cia_w&tk=5956e6519f2bb0ae8e57bc834298c9f1&x={x}&y={y}&l={z}'
).addTo(map);
L.Util.requestAnimFrame(map.invalidateSize, map, !1, map._container); //解决首次加载不完全问题
};
let townZuowu = ref({ label: [] }); //镇的作物
const DefaultList = () => {
document.querySelector('.mode').innerText = '地图模式';
window.document.querySelector('.tabulation').style.display = 'block';
window.document.querySelector('.centerBox').style.display = 'none';
window.document.querySelector('#screenfull').style.display = 'none';
};
//智能孢子捕捉点击
const sporeClick = e => {
brightFlag.value = '1';
brightFlags.value = false;
bottomFlags.value = false;
getsporeEquipmentConditions();
};
//虫情监测点击事件
const insectClick = e => {
brightFlag.value = '2';
brightFlags.value = false;
bottomFlags.value = false;
geteqLightEquipmentConditions();
};
//土壤点击事件
const soilClick = e => {
brightFlag.value = '3';
brightFlags.value = true;
bottomFlags.value = false;
getequipmentConditions();
getfindAllSoils();
};
//展示全部
const ShowAll = () => {
brightFlag.value = '4';
bottomFlags.value = true;
brightFlags.value = true;
getsporeEquipmentConditions();
};
//孢子切换当前页的容量
const handleCurrentChange = val => {
currentPage.value = val;
pagingarr.value = insectarr.value.slice(
(currentPage.value - 1) * pageSize.value,
(currentPage.value - 1) * pageSize.value + pageSize.value
);
};
//列表模式模式切换
const SwitchMode = () => {
SwitchFlag.value = !SwitchFlag.value;
const statInfo = chartModeDiv.value; // 获取图表元素
statInfo.style.width = document.querySelector('.chartModeFather').offsetWidth + 'px'; //初始化echarts图表宽度
statInfo.style.height = document.querySelector('.chartModeFather').offsetHeight - 100 + 'px';
console.log(document.querySelector('.chartModeFather').offsetWidth);
const myChart = echarts.init(statInfo);
// 设置宽度自适应
window.addEventListener('resize', () => {
statInfo.style.width = document.querySelector('.chartModeFather').offsetWidth + 'px';
statInfo.style.height =
document.querySelector('.chartModeFather').offsetHeight - 100 + 'px';
myChart.resize();
});
chartModes();
};
//创建ICON构造函数相当于继承于ICON可以重新设置属性
var LeafIcon = L.Icon.extend({
options: {
// shadowUrl: './icon/leaf-shadow.png', //阴影地址
iconSize: [50, 50], //图标宽高
shadowSize: [50, 64], //阴影宽高
iconAnchor: [22, 94], //图标锚点
shadowAnchor: [4, 62], //阴影锚点
popupAnchor: [0, -86], //弹出框弹出位置,相对于图标锚点
},
});
//创建多个icon
var greenIcon = new LeafIcon({
iconUrl: iconShadow,
});
const handleNodeClick = (data, node, data1, data2) => {
value1.value = '';
formInline.value.flag = '';
if (!data.children) {
let oriFatherId = node.parent.data;
label1.value = oriFatherId.label;
label2.value = data.label;
console.log(oriFatherId);
console.log(label2.value);
console.log(node.parent);
console.log(nums.value);
if (nums.value == '0') {
oriFatherId.children.forEach(item => {
console.log(item.label, label2.value);
if (item.label == label2.value) {
label3.value = label1.value;
}
});
} else {
// console.log(oriFatherId[0].children[0],label2.value);
// oriFatherId[0].children.forEach(item => {
// if (item.label == label2.value) {
// label3.value = item.label;
// }
// });
console.log(nums.value);
if (nums.value == '1') {
label3.value = '智能孢子仪';
} else if (nums.value == '2') {
label3.value = '虫情监测仪';
} else if (nums.value == '3') {
label3.value = '土壤墒情、土质';
}
}
if (label3.value == '智能孢子仪') {
getSpore({ equipment: label2.value, whetherToDownload: true }).then(res => {
tabulation.value = res.data;
tableNewData.value = res.data.slice(
(tabulationcurrentPage.value - 1) * tabulationpageSize.value,
(tabulationcurrentPage.value - 1) * tabulationpageSize.value +
tabulationpageSize.value
);
tableItem.value = [];
});
// if (viewers.entities) {
// viewers.entities.removeAll();
// }
getsporeEquipmentCondition().then(res => {
townZuowu.label = res.data;
// 创建一个Entity对象加图片
res.data.forEach((item, index) => {
center = L.latLng(item.msLatitude, item.msLongitude);
map.setView(center, 17);
L.marker([item.msLatitude, item.msLongitude], { icon: greenIcon })
.addTo(map)
.bindPopup(
`<b>智能孢子仪</b><br><br>经度:${item.msLongitude}<br><br>纬度:${item.msLatitude}`
)
.openPopup();
});
});
} else if (label3.value == '虫情监测仪') {
getinsect({ equipment: label2.value, whetherToDownload: true }).then(res => {
tabulation.value = res.data;
res.data.forEach(item => {
if (item.warning == '有') {
item.pestName = item.picturesMark2O1List[0].pestName;
res.data.forEach(i => {
let arr = {};
i.picturesMark2O1List.forEach(item => {
console.log(item);
if (!arr[item.pestName]) {
arr[item.pestName] = 1;
} else {
arr[item.pestName] += 1;
}
});
i['obj'] = arr;
});
}
});
tableNewData.value = res.data.slice(
(tabulationcurrentPage.value - 1) * tabulationpageSize.value,
(tabulationcurrentPage.value - 1) * tabulationpageSize.value +
tabulationpageSize.value
);
tableItem.value = [
{
lable: '预警值',
value: 'picturesMark201List',
},
];
});
// if (viewers.entities) {
// viewers.entities.removeAll();
// }
geteqLightEquipmentCondition().then(res => {
console.log(res.data);
townZuowu.label = res.data;
// 创建一个Entity对象加图片
res.data.forEach((item, index) => {
center = L.latLng(item.msLatitude, item.msLongitude);
map.setView(center, 17);
L.marker([item.msLatitude, item.msLongitude], { icon: greenIcon })
.addTo(map)
.bindPopup(
`<b>虫情监测仪</b><br><br>经度:${item.msLongitude}<br><br>纬度:${item.msLatitude}`
)
.openPopup();
});
});
} else if (label3.value == '土壤墒情、土质') {
getfindAllSoil({ equipment: label2.value, whetherToDownload: true }).then(res => {
tabulation.value = res.data;
res.data.forEach(item => {
item['style'] = [];
if (item.warning == '有') {
item.limitExceeded.forEach(i => {
for (const key in i) {
if (key !== 'eqSoilId') {
if (i[key] != null) {
item['style'].push(key);
}
}
}
});
}
});
tableNewData.value = res.data.slice(
(tabulationcurrentPage.value - 1) * tabulationpageSize.value,
(tabulationcurrentPage.value - 1) * tabulationpageSize.value +
tabulationpageSize.value
);
tableItem.value = [
{
lable: '0cm湿度(%)',
value: 'soilHumidity1',
},
{
lable: '-10cm湿度(%)',
value: 'soilHumidity2',
},
{
lable: '-20cm湿度(%)',
value: 'soilHumidity3',
},
{
lable: '-30cm湿度(%)',
value: 'soilHumidity4',
},
{
lable: '-40cm湿度(%)',
value: 'soilHumidity5',
},
{
lable: '0cm温度',
value: 'soilTemperature1',
},
{
lable: '-10cm温度',
value: 'soilTemperature2',
},
{
lable: '-20cm温度',
value: 'soilTemperature3',
},
{
lable: '-30cm温度',
value: 'soilTemperature4',
},
{
lable: '-40cm温度',
value: 'soilTemperature5',
},
{
lable: '-30cm温度',
value: 'soilTemperature4',
},
{
lable: '-40cm温度',
value: 'soilTemperature5',
},
{
lable: 'PH值(ph)',
value: 'soilPh',
},
{
lable: 'EC值(S/cm)',
value: 'soilEc',
},
];
});
// if (viewers.entities) {
// viewers.entities.removeAll();
// }
getequipmentCondition().then(res => {
townZuowu.label = res.data;
// 创建一个Entity对象加图片
res.data.forEach((item, index) => {
center = L.latLng(item.msLatitude, item.msLongitude);
map.setView(center, 17);
L.marker([item.msLatitude, item.msLongitude], { icon: greenIcon })
.addTo(map)
.bindPopup(
`<b>土壤墒情、土质</b><br><br>经度:${item.msLongitude}<br><br>纬度:${item.msLatitude}`
)
.openPopup();
});
});
}
}
};
//用经纬度控制视角
const angle = item => {
let params = {
lon: item.msLongitude,
lat: item.msLatitude,
alt: 10000,
heading: Cesium.Math.toRadians(0.0),
pitch: Cesium.Math.toRadians(-90.0),
roll: 0.0,
range: 0,
};
// viewers.camera.flyTo({
// // fromDegrees()将经纬度和高程转换为世界坐标
// destination: Cesium.Cartesian3.fromDegrees(params.lon, params.lat, params.alt),
// orientation: {
// // 指向
// heading: params.heading,
// // 视角
// pitch: params.pitch,
// roll: params.roll,
// },
// });
};
const onSubmit = () => {
console.log(label3.value);
if (label3.value == '智能孢子仪') {
getSpore({
startTime: value1.value[0]
? moment(value1.value[0]).format('YYYY-MM-DD HH:mm:ss')
: null,
endTime: value1.value[1] ? moment(value1.value[1]).format('YYYY-MM-DD HH:mm:ss') : null,
early: formInline.value.flag,
equipment: label2.value,
whetherToDownload: false,
}).then(res => {
tabulation.value = res.data;
tableNewData.value = res.data.slice(
(tabulationcurrentPage.value - 1) * tabulationpageSize.value,
(tabulationcurrentPage.value - 1) * tabulationpageSize.value +
tabulationpageSize.value
);
});
} else if (label3.value == '虫情监测仪') {
getinsect({
startTime: value1.value[0]
? moment(value1.value[0]).format('YYYY-MM-DD HH:mm:ss')
: null,
endTime: value1.value[1] ? moment(value1.value[1]).format('YYYY-MM-DD HH:mm:ss') : null,
early: formInline.value.flag,
equipment: label2.value,
whetherToDownload: false,
}).then(res => {
res.data.forEach(item => {
if (item.warning == '有') {
item.pestName = item.picturesMark2O1List[0].pestName;
res.data.forEach(i => {
let arr = {};
i.picturesMark2O1List.forEach(item => {
if (!arr[item.pestName]) {
arr[item.pestName] = 1;
} else {
arr[item.pestName] += 1;
}
});
i['obj'] = arr;
});
}
});
tabulation.value = res.data;
tableNewData.value = res.data.slice(
(tabulationcurrentPage.value - 1) * tabulationpageSize.value,
(tabulationcurrentPage.value - 1) * tabulationpageSize.value +
tabulationpageSize.value
);
console.log(tableNewData.value);
});
} else if (label3.value == '土壤墒情、土质') {
EcTimeArr.value = [];
EcArr.value = [];
PhArr.value = [];
temperature.value = [];
temperature1.value = [];
temperature2.value = [];
temperature3.value = [];
temperature4.value = [];
temperature5.value = [];
humidity.value = [];
humidity1.value = [];
humidity2.value = [];
humidity3.value = [];
humidity4.value = [];
humidity5.value = [];
soilPh.value = [];
soilEc.value = [];
getfindAllSoilTb({
startTime: value1.value[0]
? moment(value1.value[0]).format('YYYY-MM-DD HH:mm:ss')
: null,
endTime: value1.value[1] ? moment(value1.value[1]).format('YYYY-MM-DD HH:mm:ss') : null,
early: formInline.value.flag,
equipment: label2.value,
}).then(res => {
let arr = res.data.reverse();
arr.forEach((item, index) => {
EcTimeArr.value.push(item.dataTime);
EcArr.value.push(item.soilEc);
PhArr.value.push(Number(item.soilPh));
temperature.value.push(item.soilTemperature1);
temperature1.value.push(item.soilTemperature1);
temperature2.value.push(item.soilTemperature2);
temperature3.value.push(item.soilTemperature3);
temperature4.value.push(item.soilTemperature4);
temperature5.value.push(item.soilTemperature5);
humidity.value.push(item.soilHumidity1);
humidity1.value.push(item.soilHumidity1);
humidity2.value.push(item.soilHumidity2);
humidity3.value.push(item.soilHumidity3);
humidity4.value.push(item.soilHumidity4);
humidity5.value.push(item.soilHumidity5);
soilPh.value.push(item.soilPh);
soilEc.value.push(item.soilEc);
});
const statInfo = chartModeDiv.value; // 获取图表元素
statInfo.style.width = document.querySelector('.chartModeFather').offsetWidth + 'px'; //初始化echarts图表宽度
statInfo.style.height =
document.querySelector('.chartModeFather').offsetHeight - 100 + 'px';
const myChart = echarts.init(statInfo);
// 设置宽度自适应
window.addEventListener('resize', () => {
statInfo.style.width =
document.querySelector('.chartModeFather').offsetWidth + 'px';
statInfo.style.height =
document.querySelector('.chartModeFather').offsetHeight - 100 + 'px';
myChart.resize();
});
chartModes();
});
getfindAllSoil({
startTime: value1.value[0]
? moment(value1.value[0]).format('YYYY-MM-DD HH:mm:ss')
: null,
endTime: value1.value[1] ? moment(value1.value[1]).format('YYYY-MM-DD HH:mm:ss') : null,
early: formInline.value.flag,
equipment: label2.value,
whetherToDownload: false,
}).then(res => {
res.data.forEach(item => {
item['style'] = [];
if (item.warning == '有') {
item.limitExceeded.forEach(i => {
for (const key in i) {
if (key !== 'eqSoilId') {
if (i[key] != null) {
item['style'].push(key);
}
}
}
});
}
});
tabulation.value = res.data;
tableNewData.value = res.data.slice(
(tabulationcurrentPage.value - 1) * tabulationpageSize.value,
(tabulationcurrentPage.value - 1) * tabulationpageSize.value +
tabulationpageSize.value
);
// res.data.forEach((item, index) => {
// // EcTimeArr.value.push(item.dataTime);
// EcArr.value.push(item.soilEc);
// PhArr.value.push(Number(item.soilPh));
// // temperature.value.push(item.soilTemperature1);
// temperature1.value.push(item.soilTemperature1);
// temperature2.value.push(item.soilTemperature2);
// temperature3.value.push(item.soilTemperature3);
// temperature4.value.push(item.soilTemperature4);
// temperature5.value.push(item.soilTemperature5);
// // humidity.value.push(item.soilHumidity1);
// humidity1.value.push(item.soilHumidity1);
// humidity2.value.push(item.soilHumidity2);
// humidity3.value.push(item.soilHumidity3);
// humidity4.value.push(item.soilHumidity4);
// humidity5.value.push(item.soilHumidity5);
// soilPh.value.push(item.soilPh);
// soilEc.value.push(item.soilEc);
// });
const statInfo = chartModeDiv.value; // 获取图表元素
statInfo.style.width = document.querySelector('.chartModeFather').offsetWidth + 'px'; //初始化echarts图表宽度
statInfo.style.height =
document.querySelector('.chartModeFather').offsetHeight - 100 + 'px';
const myChart = echarts.init(statInfo);
// 设置宽度自适应
window.addEventListener('resize', () => {
statInfo.style.width =
document.querySelector('.chartModeFather').offsetWidth + 'px';
statInfo.style.height =
document.querySelector('.chartModeFather').offsetHeight - 100 + 'px';
myChart.resize();
});
chartModes();
});
}
};
const tabulationCurrentChange = val => {
tabulationcurrentPage.value = val;
tableNewData.value = tabulation.value.slice(
(tabulationcurrentPage.value - 1) * tabulationpageSize.value,
(tabulationcurrentPage.value - 1) * tabulationpageSize.value + tabulationpageSize.value
);
};
//查看详情
const onDetail = row => {
DetailVisible.value = true;
DetailArr.value = row;
if (label3 == '虫情监测仪') {
DetailArr['pestName'] = row.picturesMark2O1List[0].pestName;
}
let arr = [];
if (label3 == '土壤墒情、土质') {
console.log(DetailArr.limitExceeded);
}
console.log(DetailArr);
};
//虫情切换当前页的容量
const handleCurrentChanges = val => {
currentPage.value = val;
bugarrs.value = bugarr.value.slice(
(currentPage.value - 1) * pageSize.value,
(currentPage.value - 1) * pageSize.value + pageSize.value
);
};
//土壤切换当前页的容量
const handleCurrentChangess = val => {
currentPage.value = val;
soilArr.value = soilAll.value.slice(
(currentPage.value - 1) * pageSize.value,
(currentPage.value - 1) * pageSize.value + pageSize.value
);
};
//详情
const cellClick = (row, column, cell, event) => {
let arr = {};
row.picturesMark2O1List.forEach(item => {
console.log(item);
if (!arr[item.pestName]) {
arr[item.pestName] = 1;
} else {
arr[item.pestName] += 1;
}
});
gridArr.value = arr;
gridData.value = row;
if (row.picturesMark2O1List.length > 0) {
dialogTableVisible.value = true;
}
};
//tabs
const foldClick = () => {
flags.value = !flags.value;
setTimeout(() => {
const statInfo = chartModeDiv.value; // 获取图表元素
statInfo.style.width = document.querySelector('.chartModeFather').offsetWidth + 'px'; //初始化echarts图表宽度
statInfo.style.height = document.querySelector('.chartModeFather').offsetHeight - 50 + 'px';
const myChart = echarts.init(statInfo);
// 设置宽度自适应
window.addEventListener('resize', () => {
statInfo.style.width = document.querySelector('.chartModeFather').offsetWidth + 'px';
statInfo.style.height =
document.querySelector('.chartModeFather').offsetHeight - 50 + 'px';
myChart.resize();
});
chartModes();
}, 20);
};
//深度切换
const depthclick = item => {
active.value = item;
switch (item) {
case 1:
temperature = temperature1;
humidity = humidity1;
break;
case 2:
temperature = temperature2;
humidity = humidity2;
break;
case 3:
temperature = temperature3;
humidity = humidity3;
break;
case 4:
temperature = temperature4;
humidity = humidity4;
break;
case 5:
temperature = temperature5;
humidity = humidity5;
break;
case 6:
temperature = soilEc;
humidity = [];
break;
case 7:
temperature = soilPh;
humidity = [];
break;
default:
break;
}
if (localStorage.getItem(router.currentRoute.value.path) == 'true') {
soil();
} else {
chartModes();
}
};
//孢子查询数据
const query = () => {
getSpore({
startTime: value1.value ? time(value1) : null,
endTime: value2.value ? time(value2) : null,
early: value3.value,
equipment: deviceValue.value,
}).then(res => {
tableData.arr = res.data;
insectarr.value = res.data;
pagingarr.value = res.data.slice(
(currentPage.value - 1) * pageSize.value,
(currentPage.value - 1) * pageSize.value + pageSize.value
);
});
};
//虫情询数据
const querys = () => {
getinsect({
startTime: value1.value ? time(value1) : null,
endTime: value2.value ? time(value2) : null,
early: value3.value,
equipment: deviceValue.value,
}).then(res => {
bugarr.value = res.data;
// bugarrs.value=res.data
bugarrs.value = res.data.slice(
(currentPage.value - 1) * pageSize.value,
(currentPage.value - 1) * pageSize.value + pageSize.value
);
});
};
//土壤查询数据
const queryss = () => {
getfindAllSoil({
startTime: value1.value ? time(value1) : null,
endTime: value2.value ? time(value2) : null,
early: value3.value,
equipment: deviceValue.value,
}).then(res => {
soilAll.value = res.data;
// bugarrs.value=res.data
soilArr.value = res.data.slice(
(currentPage.value - 1) * pageSize.value,
(currentPage.value - 1) * pageSize.value + pageSize.value
);
});
};
//下载
const ondownload = () => {
getSpore({
startTime: value1.value ? time(value1) : '',
endTime: value2.value ? time(value2) : '',
equipment: deviceValue.value,
early: value3.value,
whetherToDownload: true,
}).then(res => {
downLoadFile(res.data[res.data.length - 1].excelPath);
});
};
const ondownload2 = () => {
getinsect({
startTime: value1.value ? time(value1) : '',
endTime: value2.value ? time(value2) : '',
equipment: deviceValue.value,
early: value3.value,
whetherToDownload: true,
}).then(res => {
downLoadFile(res.data[res.data.length - 1].excelPath);
});
};
const ondownload3 = () => {
getfindAllSoil({
startTime: value1.value ? time(value1) : '',
endTime: value2.value ? time(value2) : '',
equipment: deviceValue.value,
early: value3.value,
whetherToDownload: true,
}).then(res => {
downLoadFile(res.data[res.data.length - 1].excelPath);
});
};
const dowcity = () => {
console.log(tabulation);
if (label3.value == '智能孢子仪') {
getSpore({ equipment: label2.value, whetherToDownload: true }).then(res => {
downLoadFile(res.data[res.data.length - 1].excelPath);
});
} else if (label3.value == '虫情监测仪') {
getinsect({ equipment: label2.value, whetherToDownload: true }).then(res => {
downLoadFile(res.data[res.data.length - 1].excelPath);
});
} else if (label3.value == '土壤墒情、土质') {
getfindAllSoil({ equipment: label2.value, whetherToDownload: true }).then(res => {
downLoadFile(res.data[res.data.length - 1].excelPath);
});
}
};
//重置
const resetting = () => {
value1.value = '';
value2.value = '';
value3.value = '';
deviceValue.value = '';
getSpores();
};
const resetForm = () => {
value1.value = '';
formInline.value.flag = '';
if (label3.value == '智能孢子仪') {
getSpore({ equipment: label2.value, whetherToDownload: false }).then(res => {
tabulation.value = res.data;
tableNewData.value = res.data.slice(
(tabulationcurrentPage.value - 1) * tabulationpageSize.value,
(tabulationcurrentPage.value - 1) * tabulationpageSize.value +
tabulationpageSize.value
);
});
} else if (label3.value == '虫情监测仪') {
getinsect({ equipment: label2.value, whetherToDownload: false }).then(res => {
res.data.forEach(item => {
if (item.warning == '有') {
item.pestName = item.picturesMark2O1List[0].pestName;
res.data.forEach(i => {
let arr = {};
i.picturesMark2O1List.forEach(item => {
console.log(item);
if (!arr[item.pestName]) {
arr[item.pestName] = 1;
} else {
arr[item.pestName] += 1;
}
});
i['obj'] = arr;
});
}
});
tabulation.value = res.data;
tableNewData.value = res.data.slice(
(tabulationcurrentPage.value - 1) * tabulationpageSize.value,
(tabulationcurrentPage.value - 1) * tabulationpageSize.value +
tabulationpageSize.value
);
});
} else if (label3.value == '土壤墒情、土质') {
getfindAllSoil({ equipment: label2.value, whetherToDownload: false }).then(res => {
tabulation.value = res.data;
tableNewData.value = res.data.slice(
(tabulationcurrentPage.value - 1) * tabulationpageSize.value,
(tabulationcurrentPage.value - 1) * tabulationpageSize.value +
tabulationpageSize.value
);
});
getfindAllSoil({
startTime: moment(new Date()).add('year', 0).format('YYYY-MM-DD'),
endTime: moment().format('YYYY-MM-DD HH:mm:ss'),
whetherToDownload: true,
}).then(res => {
tabulation.value = res.data;
tableNewData.value = res.data.slice(
(tabulationcurrentPage.value - 1) * tabulationpageSize.value,
(tabulationcurrentPage.value - 1) * tabulationpageSize.value +
tabulationpageSize.value
);
});
getfindAllSoilTb({
startTime: value1.value[0]
? moment(value1.value[0]).format('YYYY-MM-DD HH:mm:ss')
: null,
endTime: value1.value[1] ? moment(value1.value[1]).format('YYYY-MM-DD HH:mm:ss') : null,
early: formInline.value.flag,
equipment: label2.value,
}).then(res => {
let arr = res.data.reverse();
arr.forEach((item, index) => {
EcTimeArr.value.push(item.dataTime);
EcArr.value.push(item.soilEc);
PhArr.value.push(Number(item.soilPh));
temperature.value.push(item.soilTemperature1);
temperature1.value.push(item.soilTemperature1);
temperature2.value.push(item.soilTemperature2);
temperature3.value.push(item.soilTemperature3);
temperature4.value.push(item.soilTemperature4);
temperature5.value.push(item.soilTemperature5);
humidity.value.push(item.soilHumidity1);
humidity1.value.push(item.soilHumidity1);
humidity2.value.push(item.soilHumidity2);
humidity3.value.push(item.soilHumidity3);
humidity4.value.push(item.soilHumidity4);
humidity5.value.push(item.soilHumidity5);
soilPh.value.push(item.soilPh);
soilEc.value.push(item.soilEc);
});
const statInfo = chartModeDiv.value; // 获取图表元素
statInfo.style.width = document.querySelector('.chartModeFather').offsetWidth + 'px'; //初始化echarts图表宽度
statInfo.style.height =
document.querySelector('.chartModeFather').offsetHeight - 100 + 'px';
const myChart = echarts.init(statInfo);
// 设置宽度自适应
window.addEventListener('resize', () => {
statInfo.style.width =
document.querySelector('.chartModeFather').offsetWidth + 'px';
statInfo.style.height =
document.querySelector('.chartModeFather').offsetHeight - 100 + 'px';
myChart.resize();
});
chartModes();
});
}
};
const resettings = () => {
value1.value = '';
value2.value = '';
value3.value = '';
deviceValue.value = '';
getinsect().then(res => {
bugarr.value = res.data;
// bugarrs.value=res.data
bugarrs.value = res.data.slice(
(currentPage.value - 1) * pageSize.value,
(currentPage.value - 1) * pageSize.value + pageSize.value
);
});
};
const resettingss = () => {
value1.value = '';
value2.value = '';
value3.value = '';
deviceValue.value = '';
getfindAllSoil().then(res => {
bugarr.value = res.data;
// bugarrs.value=res.data
bugarrs.value = res.data.slice(
(currentPage.value - 1) * pageSize.value,
(currentPage.value - 1) * pageSize.value + pageSize.value
);
});
};
//格式化时间
const time = value => {
const dateObj = new Date(value.value);
// 分别获取年、月、日、小时、分钟、秒数
const year = dateObj.getFullYear();
const month = dateObj.getMonth() + 1; // 月份从0开始需要加1
const date = dateObj.getDate();
const hours = dateObj.getHours();
const minutes = dateObj.getMinutes();
const seconds = dateObj.getSeconds();
// 将年、月、日、小时、分钟、秒数拼接成字符串,中间用-和:分隔
const formattedDate = `${year}-${month.toString().padStart(2, '0')}-${date
.toString()
.padStart(2, '0')} ${hours.toString().padStart(2, '0')}:${minutes
.toString()
.padStart(2, '0')}:${seconds.toString().padStart(2, '0')}`;
return formattedDate;
};
//弹框
const bugarrsVisible = () => {
currentPage.value = 1;
visible.value = true;
getSpores();
(value1.value = ''), (value2.value = ''), (deviceValue.value = '');
getsporeEquipment().then(res => {
options.value = res.data;
});
};
const bugarrsVisibles = () => {
currentPage.value = 1;
visibles.value = true;
(value1.value = ''), (value2.value = ''), (deviceValue.value = '');
// getinsects();
// detectionLightsEquipment().then(res => {
// options.value = res.data;
// });
getinsect().then(res => {
currentPage.value = 1;
bugarr.value = res.data;
// bugarrs.value=res.data
bugarrs.value = res.data.slice(
(currentPage.value - 1) * pageSize.value,
(currentPage.value - 1) * pageSize.value + pageSize.value
);
});
};
const bugarrsVisibless = () => {
visibless.value = true;
(value1.value = ''), (value2.value = ''), (deviceValue.value = '');
soilEquipment().then(res => {
options.value = res.data;
});
};
const filterHandler = (value, row, column) => {
const property = column['property'];
return row[property] === value;
};
const handleDate = timestamp => {
var date = new Date(timestamp); //时间戳为10位需*1000时间戳为13位的话不需乘1000
var Y = date.getFullYear() + '-';
var M = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1) + '-';
var D = date.getDate() < 10 ? '0' + date.getDate() : date.getDate();
return Y + M + D;
};
const handleTime = timestamp => {
var date = new Date(timestamp); //时间戳为10位需*1000时间戳为13位的话不需乘1000
var h = (date.getHours() < 10 ? '0' + date.getHours() : date.getHours()) + ':';
var m = (date.getMinutes() < 10 ? '0' + date.getMinutes() : date.getMinutes()) + ':';
var s = date.getSeconds() < 10 ? '0' + date.getSeconds() : date.getSeconds();
return h + m + s;
};
let XZQDM = '';
//折叠
function leftFoldClick() {
leftWraFlag.value = !leftWraFlag.value;
if (leftWraFlag.value) {
let leftWra = document.querySelector('.leftWra');
leftWra.style.transform = 'translate(0,0)';
} else {
let leftWra = document.querySelector('.leftWra');
leftWra.style.transform = 'translate(-107%,0)';
}
}
function rightFoldClick() {
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)';
}
}
function bottomFoldClick() {
bottomFold.value = !bottomFold.value;
if (bottomFold.value) {
console.log(111);
let bottom_center = document.querySelector('.bottom_center');
bottom_center.style.transform = 'translate(0,0)';
} else {
let bottom_center = document.querySelector('.bottom_center');
bottom_center.style.transform = 'translate(0,107%)';
}
}
//tabs
const handleClick = (tab, event) => {
tableItem.value = [];
value1.value = '';
formInline.value.flag = '';
if (tab.paneName == '全部') {
getdeviceNumbers('0'); //所有设备列表
} else if (tab.paneName == '智能孢子仪') {
getdeviceNumbers('1'); //所有设备列表
} else if (tab.paneName == '虫情监测仪') {
tableItem.value = [
{
lable: '预警值',
value: 'picturesMark201List',
},
];
getdeviceNumbers('2'); //所有设备列表
} else if (tab.paneName == '土壤墒情、土质') {
tableItem.value = [
{
lable: '0cm湿度(%)',
value: 'soilHumidity1',
},
{
lable: '-10cm湿度(%)',
value: 'soilHumidity2',
},
{
lable: '-20cm湿度(%)',
value: 'soilHumidity3',
},
{
lable: '-30cm湿度(%)',
value: 'soilHumidity4',
},
{
lable: '-40cm湿度(%)',
value: 'soilHumidity5',
},
{
lable: '0cm温度',
value: 'soilTemperature1',
},
{
lable: '-10cm温度',
value: 'soilTemperature2',
},
{
lable: '-20cm温度',
value: 'soilTemperature3',
},
{
lable: '-30cm温度',
value: 'soilTemperature4',
},
{
lable: '-40cm温度',
value: 'soilTemperature5',
},
{
lable: '-30cm温度',
value: 'soilTemperature4',
},
{
lable: '-40cm温度',
value: 'soilTemperature5',
},
{
lable: 'PH值(ph)',
value: 'soilPh',
},
{
lable: 'EC值(S/cm)',
value: 'soilEc',
},
];
getdeviceNumbers('3'); //所有设备列表
}
};
/*------------------接口--------------------*/
//站点标号
//全部设备列表
const getdeviceNumbers = num => {
devicesArr.value = [];
// if (viewers.entities) {
// viewers.entities.removeAll();
// }
getdeviceNumber({ flag: num }).then(res => {
nums.value = num;
if (num == 0) {
label2.value = res.data[0].children[0].children[0].label;
label3.value = res.data[0].children[0].label;
} else {
label2.value = res.data[0].children[0].label;
}
if (num == '1') {
label3.value = '智能孢子仪';
} else if (num == '2') {
label3.value = '虫情监测仪';
} else if (num == '3') {
label3.value = '土壤墒情、土质';
}
res.data.forEach(item => {
devicesArr.value.push(item);
tableNewData.value = res.data.slice(
(tabulationcurrentPage.value - 1) * tabulationpageSize.value,
(tabulationcurrentPage.value - 1) * tabulationpageSize.value +
tabulationpageSize.value
);
});
onSubmit();
if (num == 1 || num == 0) {
getsporeEquipmentCondition().then(res => {
townZuowu.label = res.data;
// 创建一个Entity对象加图片
res.data.forEach((item, index) => {
center = L.latLng(item.msLatitude, item.msLongitude);
map.setView(center, 17);
L.marker([item.msLatitude, item.msLongitude], { icon: greenIcon })
.addTo(map)
.bindPopup(
`<b>智能孢子仪</b><br><br>经度:${item.msLongitude}<br><br>纬度:${item.msLatitude}`
)
.openPopup();
});
});
} else if (num == 2) {
geteqLightEquipmentCondition().then(res => {
townZuowu.label = res.data;
// 创建一个Entity对象加图片
res.data.forEach((item, index) => {
center = L.latLng(item.msLatitude, item.msLongitude);
map.setView(center, 17);
L.marker([item.msLatitude, item.msLongitude], { icon: greenIcon })
.addTo(map)
.bindPopup(
`<b>虫情监测仪</b><br><br>经度:${item.msLongitude}<br><br>纬度:${item.msLatitude}`
)
.openPopup();
});
});
} else if (num == 3) {
getequipmentCondition().then(res => {
townZuowu.label = res.data;
// 创建一个Entity对象加图片
res.data.forEach((item, index) => {
center = L.latLng(item.msLatitude, item.msLongitude);
map.setView(center, 17);
L.marker([item.msLatitude, item.msLongitude], { icon: greenIcon })
.addTo(map)
.bindPopup(
`<b>土壤墒情、土质</b><br><br>经度:${item.msLongitude}<br><br>纬度:${item.msLatitude}`
)
.openPopup();
});
});
}
});
};
//孢子
const getSpores = () => {
getSpore().then(res => {
tableData.arr = res.data;
tableData.arrs = res.data;
insectarr.value = res.data;
pagingarr.value = res.data.slice(
(currentPage.value - 1) * pageSize.value,
(currentPage.value - 1) * pageSize.value + pageSize.value
);
});
};
//最近三天孢子
const getSporestime = () => {
getSpore({
startTime: moment().subtract(3, 'days').startOf('day').format('YYYY-MM-DD HH:mm:ss'),
endTime: moment().format('YYYY-MM-DD HH:mm:ss'),
}).then(res => {
tableData.arrs = res.data;
insectarr.value = res.data;
pagingarr.value = res.data.slice(
(currentPage.value - 1) * pageSize.value,
(currentPage.value - 1) * pageSize.value + pageSize.value
);
});
};
//
//孢子设备信息
const getsporeEquipmentConditions = () => {
getsporeEquipmentCondition().then(res => {
townZuowu.label = res.data;
if (positionLayer) {
maps.removeLayer(positionLayer);
}
// 创建一个Entity对象加图片
res.data.forEach((item, index) => {
console.log(item);
positionIcon([item.msLongitude, item.msLatitude], chong, item.dev_code);
});
});
};
//土壤
const getfindAllSoils = () => {
getfindAllSoil().then(res => {
soilAll.value = res.data;
});
getfindAllSoil({
startTime: moment(new Date()).add('year', 0).format('YYYY-MM-DD'),
endTime: moment().format('YYYY-MM-DD HH:mm:ss'),
}).then(res => {
soilArr.value = soilAll.value.slice(
(currentPage.value - 1) * pageSize.value,
(currentPage.value - 1) * pageSize.value + pageSize.value
);
res.data.forEach((item, index) => {
EcTimeArr.value.push(item.dataTime);
EcArr.value.push(item.soilEc);
PhArr.value.push(Number(item.soilPh));
temperature.value.push(item.soilTemperature1);
temperature1.value.push(item.soilTemperature1);
temperature2.value.push(item.soilTemperature2);
temperature3.value.push(item.soilTemperature3);
temperature4.value.push(item.soilTemperature4);
temperature5.value.push(item.soilTemperature5);
humidity.value.push(item.soilHumidity1);
humidity1.value.push(item.soilHumidity1);
humidity2.value.push(item.soilHumidity2);
humidity3.value.push(item.soilHumidity3);
humidity4.value.push(item.soilHumidity4);
humidity5.value.push(item.soilHumidity5);
});
farmland();
Ph();
soil();
});
};
//土壤设备信息
const getequipmentConditions = () => {
if (viewer.entities) {
viewer.entities.removeAll();
}
getequipmentCondition().then(res => {
townZuowu.label = res.data;
if (positionLayer) {
maps.removeLayer(positionLayer);
}
// // 创建一个Entity对象加图片
res.data.forEach((item, index) => {
positionIcon([item.msLongitude, item.msLatitude], tu, item.dev_code);
});
});
};
//虫子
const getinsects = () => {
getinsect({
startTime: moment().subtract(3, 'days').startOf('day').format('YYYY-MM-DD HH:mm:ss'),
endTime: moment().format('YYYY-MM-DD HH:mm:ss'),
}).then(res => {
console.log(res.data);
bugarr.value = res.data;
bugarrtime.value = res.data;
bugarrs.value = res.data.slice(
(currentPage.value - 1) * pageSize.value,
(currentPage.value - 1) * pageSize.value + pageSize.value
);
});
};
//虫情设备信息
const geteqLightEquipmentConditions = () => {
geteqLightEquipmentCondition().then(res => {
townZuowu.label = res.data;
// 创建一个Entity对象加图片
if (positionLayer) {
maps.removeLayer(positionLayer);
}
res.data.forEach((item, index) => {
positionIcon([item.msLongitude, item.msLatitude], baozi, item.dev_code);
});
});
};
//镇
const getTownships = () => {
getTownship().then(res => {
Township.arr = res.features;
Township.arr.unshift({
bbox: [119.5091, 35.5671, 120.3285, 36.1455],
properties: {
XZDM: '370211',
XZMC: '全部',
},
});
let arr = [...res.features];
let brr = [];
arr.splice(0, 1);
arr.forEach(item => {
brr.push(item.properties.XZMC);
});
data.title = [...Object.values(brr)];
});
};
//面积
const getaArea = () => {
getareas().then(res => {
Township.crr = res.features;
data.title.forEach((item, index) => {
let town = res.features.map(i => {
if (item === i.properties.town) {
return i.properties;
}
});
Object.keys(dd).forEach(it => {
const index = town.findIndex(a => a && a.crop === it);
if (index > -1) {
dd[it].push(town[index].Shape_Area);
} else {
dd[it].push(null);
}
});
});
});
};
/*-------------echarts--------------*/
var baozi =
'';
var chong =
'';
var tu =
'';
function farmland() {
const farmlandDivIntance = echarts.init(farmlandDiv.value);
var option = {
grid: {
top: '15%',
left: '17%',
right: '7%',
bottom: '14%',
},
legend: {
data: ['EC值'],
inactiveColor: 'rgba(92,200,255,0.35)',
icon: 'roundRect',
top: 0,
right: 0,
itemWidth: 20,
itemHeight: 7,
textStyle: {
color: '#FFF',
},
show: true,
},
dataZoom: [
{
// start: 0,//默认为0
// end: 100,//默认为100
type: 'slider',
show: false,
zoomLock: true, //禁止拉伸
// xAxisIndex: [0],
handleSize: 0, //滑动条的 左右2个滑动条的大小
startValue: 0, // 初始显示值
endValue: 6, // 结束显示值
height: 10, //组件高度
left: '5%', //左边的距离
right: '4%', //右边的距离
bottom: 5, //底边的距离
borderColor: '#000',
fillerColor: '#269cdb',
borderRadius: 5,
backgroundColor: '#33384b', //两边未选中的滑动条区域的颜色
showDataShadow: false, //是否显示数据阴影 默认auto
showDetail: false, //即拖拽时候是否显示详细数值信息 默认true
realtime: true, //是否实时更新
filterMode: 'filter',
},
//下面这个属性是里面拖到
{
type: 'inside',
show: true,
// xAxisIndex: [0],
start: 1, //默认为1
end: 100, //默认为100
},
],
tooltip: {
show: true,
},
xAxis: {
data: EcTimeArr._rawValue,
axisLine: {
lineStyle: {
color: 'transparent', //底部边框颜色
},
},
axisLabel: {
//x轴文字的配置
show: true,
interval: 1, //使x轴文字显示全
textStyle: {
color: 'rgba(219, 225, 255, 1)',
},
formatter: function (params) {
var newParamsName = '';
var paramsNameNumber = params.length;
var provideNumber = 10; //一行显示几个字
var rowNumber = Math.ceil(paramsNameNumber / provideNumber);
if (paramsNameNumber > provideNumber) {
for (var p = 0; p < rowNumber; p++) {
var tempStr = '';
var start = p * provideNumber;
var end = start + provideNumber;
if (p == rowNumber - 1) {
tempStr = params.substring(start, paramsNameNumber);
} else {
tempStr = params.substring(start, end) + '\n';
}
newParamsName += tempStr;
}
} else {
newParamsName = params;
}
return newParamsName;
},
},
},
yAxis: [
{
name: 'EC值(mS/cm) ',
nameTextStyle: {
color: 'rgba(255, 255, 255, 0.8)',
fontSize: 14,
},
type: 'value',
splitLine: {
show: true,
lineStyle: {
color: 'rgba(255,255,255,0.2)', //网格线的颜色
width: 1,
type: 'solid',
},
},
axisLine: {
show: false,
lineStyle: {
color: 'transparent', //左边框颜色
},
},
axisLabel: {
show: true,
fontSize: 12,
textStyle: {
color: '#ADD6FF', //左文字颜色
},
},
},
],
series: [
{
name: 'EC值',
type: 'bar',
barWidth: 20,
showBackground: true,
backgroundStyle: {
color: 'rgba(255, 255, 255, 0.3)',
},
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
// color: '#00FFE3',//渐变1
color: 'rgba(43, 224, 152, 1)', //渐变1
},
{
offset: 1,
// color: '#4693EC',//渐变2
color: 'rgba(185, 250, 224, 1)', //渐变2
},
]),
},
},
data: EcArr._rawValue,
z: 0,
zlevel: 0,
// label: {
// show: true,
// position: 'top',
// fontSize: 14,
// color: '#fff', //柱状顶部文字颜色
// formatter: function (params) {
// return '20%';
// },
// },
},
{
type: 'pictorialBar',
barWidth: 20,
itemStyle: {
normal: {
color: 'rgba(2, 31, 26, 0.85)', //数据的间隔颜色
},
},
symbolRepeat: 'fixed',
symbolMargin: 3,
symbol: 'rect',
symbolSize: [30, 4],
symbolPosition: 'end',
symbolOffset: [0, 0],
data: EcArr._rawValue,
z: 1,
zlevel: 0,
tooltip: {
show: false,
},
},
],
};
farmlandDivIntance.on('click', function (params) {
console.log(params.name);
});
option && farmlandDivIntance.setOption(option, { notMerge: true, grid: { bottom: 20 } });
useEcharts(farmlandDivIntance, option);
}
function Ph() {
const PhDivIntance = echarts.init(Phdiv.value);
let dataC1 = PhArr._rawValue;
let dataC2 = [20, 30, 60, 40, 50, 30];
let dataC3 = [20, 30, 60, 40, 50, 30];
let xData = EcTimeArr._rawValue;
var fontColor = '#30eee9';
let option = {
backgroundColor: 'transparent',
grid: {
left: '15%',
right: '7%',
top: '15%',
bottom: '17%',
},
tooltip: {
trigger: 'axis',
axisPointer: {
type: 'shadow',
lineStyle: {
color: '#57617B',
},
},
},
dataZoom: [
{
// start: 0,//默认为0
// end: 100,//默认为100
type: 'slider',
zoomLock: true, //禁止拉伸
show: false,
// xAxisIndex: [0],
handleSize: 0, //滑动条的 左右2个滑动条的大小
startValue: 0, // 初始显示值
endValue: 6, // 结束显示值
height: 10, //组件高度
left: '5%', //左边的距离
right: '4%', //右边的距离
bottom: 5, //底边的距离
borderColor: '#000',
fillerColor: '#269cdb',
borderRadius: 5,
backgroundColor: '#33384b', //两边未选中的滑动条区域的颜色
showDataShadow: false, //是否显示数据阴影 默认auto
showDetail: false, //即拖拽时候是否显示详细数值信息 默认true
realtime: true, //是否实时更新
filterMode: 'filter',
},
//下面这个属性是里面拖到
{
type: 'inside',
show: true,
// xAxisIndex: [0],
start: 1, //默认为1
end: 100, //默认为100
},
],
xAxis: {
type: 'category',
axisLine: {
show: true,
lineStyle: {
color: 'rgba(255, 255, 255, 0.7)',
},
},
offset: 12,
axisTick: {
show: false,
alignWithLabel: true,
lineStyle: {
color: '#dddddd',
},
},
axisLabel: {
//x轴文字的配置
// show: true,
interval: 1, //使x轴文字显示全
textStyle: {
color: 'rgba(219, 225, 255, 1)',
},
formatter: function (params) {
var newParamsName = '';
var paramsNameNumber = params.length;
var provideNumber = 10; //一行显示几个字
var rowNumber = Math.ceil(paramsNameNumber / provideNumber);
if (paramsNameNumber > provideNumber) {
for (var p = 0; p < rowNumber; p++) {
var tempStr = '';
var start = p * provideNumber;
var end = start + provideNumber;
if (p == rowNumber - 1) {
tempStr = params.substring(start, paramsNameNumber);
} else {
tempStr = params.substring(start, end) + '\n';
}
newParamsName += tempStr;
}
} else {
newParamsName = params;
}
return newParamsName;
},
},
data: xData,
},
yAxis: {
name: 'PH值(ph)',
type: 'value',
axisLine: {
show: false,
lineStyle: {
color: '#dddddd',
},
},
splitLine: {
show: true,
lineStyle: {
color: 'rgba(255,255,255,0.2)', //网格线的颜色
width: 1,
type: 'solid',
},
},
axisTick: {
show: false,
},
axisLabel: {
fontSize: 16,
},
boundaryGap: ['20%', '20%'],
},
series: [
{
name: '',
type: 'line',
stack: '总量',
smooth: true,
symbol: 'none',
showSymbol: false,
symbolSize: 8,
itemStyle: {
normal: {
areaStyle: {
//color: '#94C9EC'
color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [
{
offset: 0.4,
color: 'rgba(163, 198, 255, 0.4)',
},
{
offset: 1,
color: 'rgba(163, 198, 255, 0.01)',
},
]),
},
},
},
markPoint: {
itemStyle: {
normal: {
color: 'red',
},
},
},
data: dataC1,
},
],
};
useEcharts(PhDivIntance, option);
}
function soil() {
const soilDivIntance = echarts.init(soilDiv.value);
var time = EcTimeArr._rawValue;
var sportData = humidity.value;
var sportTime = temperature.value;
let option = {
// backgroundColor: '#2C313E',
// legend: {
// icon: 'rect',
// top: 7,
// left: 'center',
// itemWidth: 20,
// itemHeight: 10,
// itemGap: 30,
// textStyle: {
// color: 'rgba(255, 255, 255, 0.7)',
// },
// },
tooltip: {
trigger: 'axis',
},
grid: {
top: '15%',
left: '5%',
right: '7%',
bottom: '15%',
containLabel: true,
},
dataZoom: [
{
// start: 0,//默认为0
// end: 100,//默认为100
type: 'slider',
zoomLock: true, //禁止拉伸
show: false,
// xAxisIndex: [0],
handleSize: 0, //滑动条的 左右2个滑动条的大小
startValue: 0, // 初始显示值
endValue: 6, // 结束显示值
height: 10, //组件高度
left: '5%', //左边的距离
right: '4%', //右边的距离
bottom: 5, //底边的距离
borderColor: '#000',
fillerColor: '#269cdb',
borderRadius: 5,
backgroundColor: '#33384b', //两边未选中的滑动条区域的颜色
showDataShadow: false, //是否显示数据阴影 默认auto
showDetail: false, //即拖拽时候是否显示详细数值信息 默认true
realtime: true, //是否实时更新
filterMode: 'filter',
},
//下面这个属性是里面拖到
{
type: 'inside',
show: true,
// xAxisIndex: [0],
start: 1, //默认为1
end: 100, //默认为100
},
],
xAxis: [
{
type: 'category',
data: time,
axisLine: {
show: false,
},
axisLabel: {
textStyle: {
color: 'rgba(255, 255, 255, 0.7)',
},
interval: 1, //使x轴文字显示全
formatter: function (params) {
var newParamsName = '';
var paramsNameNumber = params.length;
var provideNumber = 10; //一行显示几个字
var rowNumber = Math.ceil(paramsNameNumber / provideNumber);
if (paramsNameNumber > provideNumber) {
for (var p = 0; p < rowNumber; p++) {
var tempStr = '';
var start = p * provideNumber;
var end = start + provideNumber;
if (p == rowNumber - 1) {
tempStr = params.substring(start, paramsNameNumber);
} else {
tempStr = params.substring(start, end) + '\n';
}
newParamsName += tempStr;
}
} else {
newParamsName = params;
}
return newParamsName;
},
},
boundaryGap: false,
axisTick: {
//坐标轴刻度相关设置。
show: false,
},
},
],
yAxis: [
{
name: '土壤温度 (℃)',
type: 'value',
axisLine: {
show: false,
lineStyle: {
color: '#dddddd',
},
},
axisTick: {
show: false,
},
axisLabel: {
textStyle: {
color: 'rgba(255, 255, 255, 0.7)', //左侧数标
},
},
splitLine: {
show: true,
lineStyle: {
color: '#ccc',
type: 'solid',
opacity: 1,
},
},
},
{
name: '土壤湿度(%RH)',
type: 'value',
axisLine: {
show: false,
lineStyle: {
color: '#dddddd',
},
},
position: 'right',
axisTick: {
show: false,
},
axisLabel: {
textStyle: {
color: 'rgba(255, 255, 255, 0.7)', //右侧数标
},
formatter: '{value}',
},
splitLine: {
show: false,
},
},
],
series: [
{
name: '土壤温度',
type: 'line',
data: sportTime,
symbolSize: 1,
// symbol: 'circle',
itemStyle: {
// 设置symbol的颜色
normal: {
color: 'rgba(252, 186, 211, 1)',
},
},
smooth: true,
yAxisIndex: 0,
showSymbol: false,
lineStyle: {
width: 3,
color: 'rgba(252, 186, 211, 1)',
},
},
{
name: '土壤湿度',
type: 'line',
data: sportData,
symbolSize: 1,
yAxisIndex: 1,
// symbol: 'circle',
itemStyle: {
// 设置symbol的颜色
normal: {
color: 'rgba(168, 216, 234, 1)',
},
},
smooth: true,
showSymbol: false,
lineStyle: {
width: 3,
color: 'rgba(168, 216, 234, 1)',
},
},
],
};
useEcharts(soilDivIntance, option);
}
function chartModes() {
const ASdivisionDivIntance = echarts.init(chartModeDiv.value);
let leftY = '土壤温度 (℃)';
let leftYlabel = '';
let color = 'rgba(255, 235, 59, 1)';
switch (active.value) {
case 6:
leftY = 'EC值(S/cm)';
leftYlabel = 'EC值';
color = 'rgba(0, 209, 195, 1)';
break;
case 7:
leftY = 'PH值(ph)';
leftYlabel = 'PH值';
color = 'rgba(201, 255, 148, 1)';
break;
default:
leftY = '土壤温度 (℃)';
leftYlabel = '土壤温度';
break;
}
var time = EcTimeArr._rawValue;
var sportData = humidity.value;
var sportTime = temperature.value;
let ends = (7 / temperature.value.length) * 100;
let option = {
color: [color, 'rgba(199, 125, 231, 1)'],
tooltip: {
trigger: 'axis',
},
grid: {
top: '15%',
left: '5%',
right: '7%',
bottom: '15%',
containLabel: true,
},
legend: {
show: true,
top: '7%',
x: 'center',
textStyle: { color: 'black' },
itemWidth: 20,
itemHeight: 12.5,
icon: 'rect',
backgroundColor: 'transparent',
},
dataZoom: [
{
type: 'slider',
width: '40%',
zoomLock: true,
top: '90%',
start: 0,
end: ends,
showDataShadow: false,
showDetail: false,
fillerColor: 'rgba(64, 158, 255)',
borderRadius: '50%',
moveHandleSize: 0,
moveHandleStyle: {},
left: '35%',
height: 12,
handleSize: '80%',
handleIcon: 'path://M512,512m-448,0a448,448,0,1,0,896,0a448,448,0,1,0,-896,0Z',
handleStyle: {
borderWidth: 0,
color: 'rgba(64, 158, 255)',
},
},
{
type: 'inside',
},
],
xAxis: [
{
type: 'category',
data: time,
axisLine: {
show: false,
},
axisLabel: {
textStyle: {
color: 'rgba(102, 102, 102, 1)',
},
interval: 0, //使x轴文字显示全
formatter: function (params) {
var newParamsName = '';
var paramsNameNumber = params.length;
var provideNumber = 10; //一行显示几个字
var rowNumber = Math.ceil(paramsNameNumber / provideNumber);
if (paramsNameNumber > provideNumber) {
for (var p = 0; p < rowNumber; p++) {
var tempStr = '';
var start = p * provideNumber;
var end = start + provideNumber;
if (p == rowNumber - 1) {
tempStr = params.substring(start, paramsNameNumber);
} else {
tempStr = params.substring(start, end) + '\n';
}
newParamsName += tempStr;
}
} else {
newParamsName = params;
}
return newParamsName;
},
},
boundaryGap: false,
axisTick: {
//坐标轴刻度相关设置。
show: false,
},
},
],
yAxis: [
{
name: leftY,
type: 'value',
axisLine: {
show: false,
lineStyle: {
color: 'rgba(102, 102, 102, 1)',
},
},
axisTick: {
show: false,
},
axisLabel: {
textStyle: {
color: 'rgba(102, 102, 102, 1)', //左侧数标
},
},
splitLine: {
show: true,
lineStyle: {
color: '#ccc',
type: 'solid',
opacity: 1,
},
},
},
{
name: '土壤湿度(%RH)',
type: 'value',
axisLine: {
show: false,
lineStyle: {
color: 'rgba(102, 102, 102, 1)',
},
},
position: 'right',
axisTick: {
show: false,
},
axisLabel: {
textStyle: {
color: 'rgba(102, 102, 102, 1)', //右侧数标
},
formatter: '{value}',
},
splitLine: {
show: false,
},
},
],
series: [
{
name: leftYlabel,
type: 'line',
data: sportTime,
symbolSize: 10,
itemStyle: {
// 设置symbol的颜色
normal: {
color: function (param) {
//拐点颜色回调
if (active.value == 1) {
if (param.value >= -10 && param.value <= 40) {
return color;
} else {
return 'red';
}
} else if (active.value == 2) {
if (param.value >= -5 <= 40) {
return color;
} else {
return 'red';
}
} else if (active.value == 3) {
if (param.value >= 0 && param.value <= 30) {
return color;
} else {
return 'red';
}
} else if (active.value == 4) {
if (param.value >= 0 && param.value <= 30) {
return color;
} else {
return 'red';
}
} else if (active.value == 5) {
if (param.value >= 0 && param.value <= 30) {
return color;
} else {
return 'red';
}
} else if (active.value == 6) {
if (param.value >= 0 && param.value <= 0.2) {
return color;
} else {
return 'red';
}
} else if (active.value == 7) {
if (param.value >= 5.5 && param.value <= 7.5) {
return color;
} else {
return 'red';
}
}
},
},
},
smooth: true,
yAxisIndex: 0,
showSymbol: true,
symbol: 'circle',
lineStyle: {
width: 3,
color: color,
},
},
{
name: '土壤湿度',
type: 'line',
data: sportData,
symbolSize: 10,
yAxisIndex: 1,
itemStyle: {
// 设置symbol的颜色
normal: {
color: function (param) {
//拐点颜色回调
if (active.value == 1) {
if (param.value >= 5 && param.value <= 60) {
return 'rgba(199, 125, 231, 1)';
} else {
return 'red';
}
} else if (active.value == 2) {
if (param.value >= 0 <= 30) {
return 'rgba(199, 125, 231, 1)';
} else {
return 'red';
}
} else if (active.value == 3) {
if (param.value >= 0 && param.value <= 30) {
return 'rgba(199, 125, 231, 1)';
} else {
return 'red';
}
} else if (active.value == 4) {
if (param.value >= 0 && param.value <= 40) {
return 'rgba(199, 125, 231, 1)';
} else {
return 'red';
}
} else if (active.value == 5) {
if (param.value >= 0 && param.value <= 40) {
return 'rgba(199, 125, 231, 1)';
} else {
return 'red';
}
}
},
},
},
label: {
color: params => params.color,
},
smooth: true,
showSymbol: true,
symbol: 'circle',
lineStyle: {
width: 3,
color: 'rgba(199, 125, 231, 1)',
},
},
{
name: '预警',
type: 'bar',
data: [],
itemStyle: {
color: 'red', // 设置图例的图形颜色
},
},
],
};
useEcharts(ASdivisionDivIntance, option);
}
// 添加wms
// 添加wms
function addWms(layers, customName, bottom) {
let map = new Cesium.WebMapServiceImageryProvider({
url: serverAPI.geoserverUrl + `/map-${layers}/wms111/`,
layers: layers + '@' + layers, //图层名
parameters: {
service: 'WMS',
format: 'image/png',
srs: 'EPSG:4326',
VERSION: '1.1.1',
transparent: true, //是否透明
exceptions: 'application/vnd.ogc.se_inimage',
},
});
map.customName = customName; //自己定义各种属性
let dd = viewer.imageryLayers.addImageryProvider(map); //添加图层
// if (customName.indexOf('gbznt') > -1) {
// // viewer.imageryLayers.lower(dd);//将图层下移一层
// viewer.imageryLayers.lowerToBottom(dd); //将图层移到最底层
// viewer.imageryLayers.raise(dd); //将图层上移一层
// }
if (bottom) {
viewer.imageryLayers.lowerToBottom(dd); //将图层移到最底层
viewer.imageryLayers.raise(dd); //将图层上移一层
}
}
//返回
function back() {
removeWms(['gbznt'], true);
addWms('shuzisannong:huangdaoqu_town', 'tl');
viewer.camera.flyTo({
destination: Cesium.Rectangle.fromDegrees(119.5091, 35.5671, 120.3285, 36.1455),
duration: 2,
});
flag.value = false;
}
/*--------------------------------------------------------------------------------------------*/
function getAreaFenlei() {
let fl = fenleiRef.value;
axios({
url:
serverAPI.geoserverUrl +
'/shuzisannong/ows?service=WFS&version=1.0.0&request=GetFeature&typeName=shuzisannong%3Ahuangdaoqu_town&maxFeatures=50&outputFormat=application%2Fjson',
})
.then(res => {
let data = res.data.features;
data.forEach((item, index) => {
const rectangle = Cesium.Rectangle.fromDegrees(
item.bbox[0],
item.bbox[1],
item.bbox[2],
item.bbox[3]
);
const center = Cesium.Rectangle.center(rectangle); //获取视角范围中心点(得到的结果为弧度Cartographic)
let longitude = Cesium.Math.toDegrees(center.longitude); //将弧度转为度
let latitude = Cesium.Math.toDegrees(center.latitude);
if (item.properties.XZDM === '370211011') {
//灵山卫街道
longitude = 120.0863;
latitude = 35.941;
} else if (item.properties.XZDM === '370211003') {
//薛家岛街道
longitude = 120.243682;
latitude = 35.97123201;
}
const townData = fl[item.properties.XZMC];
let label = [];
if (townData) {
label = townData.map((it, inex) => {
// let dd = `${it.properties.crop} ${(it.properties.Shape_Area / 666.67).toFixed(2)} 亩`
// return dd
return it.properties;
});
}
});
})
.catch(err => {});
}
let fenleiRef = ref({});
function mbHandle() {
axios({
url:
serverAPI.geoserverUrl +
'/shuzisannong/ows?service=WFS&version=1.0.0&request=GetFeature&typeName=shuzisannong%3Afenlei&maxFeatures=137&outputFormat=application%2Fjson',
})
.then(res => {
let features = res.data.features;
let town = {};
// 按镇分类
features.forEach(item => {
let key = item.properties.town;
if (town[key]) {
town[key].push(item);
} else {
town[key] = [item];
}
});
fenleiRef.value = town;
getAreaFenlei();
})
.catch(err => {});
}
// 地图移动时弹窗跟随
function infoWindowPostRender() {
if (townZuowu.value && townZuowu.label[0].msLongitude && townZuowu.label[0].msLatitude) {
//经纬度转为世界坐标
const gisPosition = Cesium.Cartesian3.fromDegrees(
Number(townZuowu.label[0].msLongitude),
Number(townZuowu.label[0].msLatitude),
0
); //转化为屏幕坐标
var windowPosition = Cesium.SceneTransforms.wgs84ToWindowCoordinates(
viewer.scene,
gisPosition
);
if (Cesium.defined(windowPosition)) {
const pop = document.getElementById('pop');
pop.style.top = windowPosition.y - 10 + 'px';
pop.style.left = windowPosition.x + 10 + 'px';
}
}
}
// function infoWindowPostRenders() {
// if (townZuowu.value && townZuowu.label[0].msLongitude && townZuowu.label[0].msLatitude) {
// //经纬度转为世界坐标
// const gisPosition = Cesium.Cartesian3.fromDegrees(
// Number(townZuowu.label[0].msLongitude),
// Number(townZuowu.label[0].msLatitude),
// 0
// ); //转化为屏幕坐标
// var windowPosition = Cesium.SceneTransforms.wgs84ToWindowCoordinates(
// viewers.scene,
// gisPosition
// );
// if (Cesium.defined(windowPosition)) {
// const pop = document.getElementById('pops');
// pop.style.top = windowPosition.y - 10 + 'px';
// pop.style.left = windowPosition.x + 10 + 'px';
// }
// }
// }
// 隐藏弹窗
function hiddenOverlayChart() {
// // 移除各种高亮
// XZDM = '';
// XZQDM = '';
// removeWms(['village_CQL']);
// removeWms(['aaa']);
// deleteEntityByName('villageLine');
// deleteEntityByName('townLine');
const pop = document.getElementById('pop');
pop.style.display = 'none'; // 清除监听事件
viewer.scene.postRender.removeEventListener(infoWindowPostRender);
// // 重定位
// viewer.camera.flyTo({
// destination: Cesium.Rectangle.fromDegrees(119.5091, 35.5671, 120.3285, 36.1455),
// duration: 2,
// });
// removeWms(['gbznt'], true);
// // addWms('shuzisannong:huangdaoqu_town', 'tl');
flag.value = false;
}
function hiddenOverlayCharts() {
// 移除各种高亮
XZDM = '';
XZQDM = '';
removeWms(['village_CQL']);
removeWms(['aaa']);
deleteEntityByName('villageLine');
deleteEntityByName('townLine');
const pop = document.getElementById('pops');
pop.style.display = 'none'; // 清除监听事件
// viewers.scene.postRender.removeEventListener(infoWindowPostRenders);
// 重定位
viewer.camera.flyTo({
destination: Cesium.Rectangle.fromDegrees(119.5091, 35.5671, 120.3285, 36.1455),
duration: 2,
});
removeWms(['gbznt'], true);
// addWms('shuzisannong:huangdaoqu_town', 'tl');
flag.value = false;
}
//显示弹窗
function showOverlayChart(position) {
var coordinate = position;
var pixel = maps.getPixelFromCoordinate(coordinate);
console.log(pixel); // [259, 297]
const pop = document.getElementById('pop');
pop.style.display = 'block';
pop.style.position = 'absolute';
pop.style.top = pixel[0] - 10 + 'px';
pop.style.left = pixel[1] + 10 + 'px';
pop.style.zIndex = 99;
console.log(pop);
}
function showOverlayCharts(position) {
var coordinate = position;
var pixel = maps.getPixelFromCoordinate(coordinate);
console.log(pixel); // [259, 297]
const pop = document.getElementById('pops');
pop.style.display = 'block';
pop.style.position = 'absolute';
pop.style.top = pixel[0] - 10 + 'px';
pop.style.left = pixel[1] + 10 + 'px';
pop.style.zIndex = 99;
console.log(pop);
}
/*-------------------------------------------------------------------------------------------*/
</script>
<style lang="scss" scoped>
$height: calc(100vh - 110px);
.fatherDiv {
width: 100%;
height: 100%;
}
.tabulation,
.centerBox {
width: 100%;
height: 98%;
.imgrotate {
transform: rotate(180deg);
}
.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;
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;
}
p {
width: 110px;
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;
}
}
}
.el-dialog__body {
color: #fff;
}
.tabulation {
display: none;
:deep() .el-dialog {
background: #fff;
}
:deep(.el-dialog__header) {
opacity: 1;
border-bottom: 1px solid rgba(219, 219, 219, 1);
padding: 10px;
font-size: 16px;
font-weight: 700;
}
.rowContent {
.rowContentTop {
border-radius: 8px;
background: rgba(248, 248, 248, 1);
padding: 0 15px;
margin-bottom: 10px;
.rowContentchildren {
display: flex;
align-items: center;
justify-content: space-between;
}
p {
display: flex;
align-items: center;
color: rgba(100, 195, 164, 1);
span {
width: 62px;
height: 24px;
opacity: 1;
border-radius: 0px 8px;
display: flex;
justify-content: flex-start;
align-items: flex-start;
padding: 5px 10px 5px 10px;
text-align: center;
margin-left: 20px;
color: rgba(255, 255, 255, 1);
line-height: 14px;
}
}
}
}
.rowContent_bottom {
.rowContentTop {
border-radius: 8px;
background: rgba(248, 248, 248, 1);
padding: 0 15px;
margin-bottom: 10px;
.rowContentchildren {
display: flex;
align-items: center;
justify-content: space-between;
font-size: 18px;
}
p {
display: flex;
align-items: center;
color: rgba(100, 195, 164, 1);
span {
// width: 62px;
// height: 24px;
opacity: 1;
border-radius: 0px 8px;
display: flex;
justify-content: flex-start;
align-items: flex-start;
padding: 5px 10px 5px 10px;
text-align: center;
margin-left: 20px;
color: rgba(255, 255, 255, 1);
line-height: 14px;
}
}
.rowContentTopChildren {
font-size: 18px;
display: flex;
flex-wrap: wrap;
div {
width: 33%;
text-align: right;
padding: 5px;
}
}
}
}
.demo-tabs {
// width: 100%;
// height: 98%;
:deep(.el-tabs__nav.is-top) {
transform: translateX(60px) !important;
}
}
:deep() .demo-tabs > .el-tabs__content {
padding: 10px;
color: #6b778c;
font-size: 32px;
font-weight: 600;
display: none;
// width: 100%;
// height: 93%;
.el-tab-pane {
// width: 100%;
// height: 100%;
}
}
.tabulationCente {
width: 100%;
height: 92%;
display: flex;
padding: 10px;
.left {
width: 15%;
height: 100%;
box-shadow: 0px 0px 9px 0px rgba(0, 0, 0, 0.08);
margin-right: 20px;
font-size: 14px;
color: rgba(0, 0, 0, 1);
padding: 10px 20px;
}
.cesiumContainersDiv {
width: 30%;
height: 100%;
background: #ccc;
box-shadow: 0px 0px 9px 0px rgba(0, 0, 0, 0.08);
position: relative;
.detailed {
width: 100%;
height: 100%;
}
#pops {
opacity: 1;
border-radius: 5px;
background: rgba(2, 31, 26, 0.6);
display: none;
flex-direction: column;
justify-content: flex-start;
align-items: flex-end;
padding: 6px 8px 6px 8px;
color: rgba(255, 255, 255, 1);
font-size: 14px;
.content {
div {
display: flex;
align-items: center;
justify-content: space-between;
p {
width: 100px;
border-radius: 2px;
background: rgba(217, 231, 255, 0.2);
display: flex;
justify-content: center;
align-items: center;
}
}
}
.cancel {
position: absolute;
right: 10px;
top: 5px;
color: rgba(255, 255, 255, 1);
cursor: pointer;
}
}
}
.centent {
width: 20px;
height: 100%;
position: relative;
z-index: 99;
.arrow {
width: 22px;
height: 22px;
// background: #ccc;
position: absolute;
top: 50%;
transform: translate(-80%, -50%);
z-index: 99;
border-radius: 50%;
cursor: pointer;
}
}
.freckle {
width: 50%;
flex: 1;
// background: #ccc;
box-shadow: 0px 0px 9px 0px rgba(0, 0, 0, 0.08);
:deep(.el-input__wrapper) {
opacity: 1;
border-radius: 4px;
background: #fff;
border: none;
box-shadow: 0px 3px 9px 0px rgba(0, 0, 0, 0.25);
width: 20%;
.el-input__inner {
color: rgba(170, 170, 170, 1);
}
}
.searchDiv {
margin: 20px;
display: flex;
.modeDiv {
width: 234px;
height: 26px;
opacity: 1;
border-radius: 8px;
display: flex;
justify-content: flex-start;
align-items: center;
text-align: center;
font-size: 14px;
// font-weight: 400;
border: 1px solid #ccc;
cursor: pointer;
div {
flex: 1;
height: 100%;
border-radius: 8px;
line-height: 26px;
}
.Selected {
background: rgba(100, 195, 164, 1);
border-radius: 8px 0px 0px 8px;
color: rgba(255, 255, 255, 1);
}
.Selecteds {
background: rgba(100, 195, 164, 1);
border-radius: 0px 8px 8px 0px;
color: rgba(255, 255, 255, 1);
}
}
}
.tableBox {
:deep(
.el-table .el-table__header-wrapper th,
.el-table .el-table__fixed-header-wrapper th
) {
color: rgba(0, 0, 0, 1);
}
height: 93%;
:deep(.el-table__inner-wrapper) {
height: 96% !important;
}
.example-pagination-block {
font-size: 14px;
display: flex;
align-items: center;
justify-content: flex-end;
}
:deep(.tabth) {
background-color: rgba(247, 247, 247, 1);
.el-table-fixed-column--left {
background: rgba(247, 247, 247, 1) !important;
}
}
.insectDiv {
width: 100%;
height: 90%;
overflow: hidden;
.gutters {
width: 100%;
height: 100%;
overflow-y: scroll;
.ins {
position: relative;
.yj {
color: rgba(255, 255, 255, 1);
position: absolute;
font-size: 14px;
border-radius: 0px 30px, 0px, 30px;
top: 0;
right: 0;
text-align: center;
line-height: 24px;
padding: 1px 5px;
}
}
}
}
}
}
}
}
.chartModeFather {
width: 100%;
height: 89%;
}
/*设置弹出框样式*/
.ol-popup {
position: absolute;
background-color: #eeeeee;
-webkit-filter: drop-shadow(0 1px 4px rgba(0, 0, 0, 0.2));
filter: drop-shadow(0 1px 4px rgba(0, 0, 0, 0.2));
padding: 15px;
border-radius: 10px;
border: 1px solid #cccccc;
bottom: 12px;
left: -50px;
min-width: 280px;
}
.ol-popup:after,
.ol-popup:before {
top: 100%;
border: solid transparent;
content: ' ';
height: 0;
width: 0;
position: absolute;
pointer-events: none;
}
.ol-popup:after {
border-top-color: #eeeeee;
border-width: 10px;
left: 48px;
margin-left: -10px;
}
.ol-popup:before {
border-top-color: #cccccc;
border-width: 11px;
left: 48px;
margin-left: -11px;
}
.ol-popup-closer {
text-decoration: none;
position: absolute;
top: 2px;
right: 8px;
}
.ol-popup-closer:after {
content: '✖';
}
.chartMode {
:deep(.el-table .el-table__header-wrapper th, .el-table .el-table__fixed-header-wrapper th) {
color: rgba(0, 0, 0, 1);
}
height: 93%;
:deep(.el-table__inner-wrapper) {
height: 96% !important;
}
.example-pagination-block {
font-size: 14px;
display: flex;
align-items: center;
justify-content: flex-end;
}
:deep(.tabth) {
background-color: rgba(247, 247, 247, 1);
}
.insectDiv {
width: 100%;
height: 90%;
overflow: hidden;
.gutters {
width: 100%;
height: 100%;
overflow-y: scroll;
.ins {
position: relative;
.yj {
color: rgba(255, 255, 255, 1);
position: absolute;
font-size: 14px;
border-radius: 0px 30px, 0px, 30px;
top: 0;
right: 0;
text-align: center;
line-height: 24px;
padding: 1px 5px;
}
}
}
}
.tableBoxs {
width: 100%;
height: 100%;
overflow: hidden;
.gutters {
width: 100%;
height: 100%;
overflow-y: scroll;
.ins {
position: relative;
.yj {
color: rgba(255, 255, 255, 1);
position: absolute;
font-size: 14px;
border-radius: 0px 30px, 0px, 30px;
top: 0;
right: 0;
text-align: center;
line-height: 24px;
padding: 1px 5px;
}
}
}
}
.chartModeDiv {
width: 100%;
height: 50%;
}
.depth {
width: 50%;
height: 26px;
opacity: 1;
border-radius: 4px;
font-size: 12px;
color: rgba(102, 102, 102, 1);
margin-top: 20px;
cursor: pointer;
background: linear-gradient(
180deg,
rgba(16, 111, 111, 0.1) 0%,
rgba(47, 214, 214, 0.1) 100%
);
border: 1px solid rgba(228, 231, 237, 1);
display: flex;
align-items: center;
p {
flex: 1;
text-align: center;
height: 100%;
display: flex;
align-items: center;
justify-content: center;
}
.SelectedDiv {
opacity: 1;
border-radius: 4px;
background: rgba(100, 195, 164, 1);
}
margin: 0 auto;
}
}
.leftWra {
position: absolute;
top: 10px;
left: 20px;
height: $height;
width: 23%;
background: rgba(2, 31, 26, 0.85);
box-shadow: inset 0px 0px 15px 6px rgba(41, 255, 255, 0.5);
transition: transform 1s;
.leftFoldDiv {
width: 30px;
height: 30px;
position: absolute;
right: -14%;
top: 50%;
transform: translate(-50%, -50%);
font-size: 30px;
color: #ccc;
}
.leftTop {
width: 100%;
height: 22%;
display: flex;
flex-direction: column;
.types {
width: 100%;
height: 165px;
display: flex;
div {
flex: 1;
}
font-size: 13px;
font-weight: 700;
letter-spacing: 0px;
line-height: 20.27px;
color: rgba(41, 255, 237, 1);
text-align: center;
p {
height: 34px;
width: 90%;
opacity: 1;
border-radius: 4px;
cursor: pointer;
// background: linear-gradient(
// 180deg,
// rgba(16, 111, 111, 1) 0%,
// rgba(47, 214, 214, 1) 100%
// );
border: 1px solid rgba(23, 194, 180, 1);
display: flex;
justify-content: center;
align-items: center;
padding: 5px 5px 5px 5px;
margin-left: 5px;
overflow: hidden;
// white-space: nowrap;
// text-overflow: ellipsis;
// word-break: keep-all;
}
.sele_types {
background: linear-gradient(
180deg,
rgba(16, 111, 111, 1) 0%,
rgba(47, 214, 214, 1) 100%
);
color: rgba(255, 255, 255, 1);
}
}
}
.leftbottom {
width: 100%;
height: 75%;
opacity: 1;
display: flex;
flex-direction: column;
justify-content: flex-start;
align-items: center;
padding-top: 13px;
.tableDiv {
// background: rgba(255, 255, 255, 0.05);
width: 93%;
height: 92%;
padding: 5px 10px 5px 10px;
color: rgba(255, 255, 255, 1);
.el-table {
--el-table-tr-bg-color: none;
--el-table-border-color: none;
::v-deep .el-table__body tr.el-table__row--striped td {
background: rgba(38, 255, 255, 0.01);
}
// ::v-deep .el-table__row {
// background: linear-gradient(
// 90deg,
// rgba(38, 255, 255, 0.15) 0%,
// rgba(38, 255, 255, 0.01) 100%
// );
// }
::v-deep .el-table__body tr:hover > td {
background: linear-gradient(
90deg,
rgba(38, 255, 255, 0.15) 0%,
rgba(38, 255, 255, 0.01) 100%
) !important;
}
color: rgba(255, 255, 255, 1);
}
.el-checkbox-group {
display: flex;
flex-direction: column;
}
:deep(.ones) {
width: 100%;
height: 171;
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;
color: rgba(255, 255, 255, 1);
}
}
}
}
:deep(.el-table .el-table__cell) {
//解决图片被其他的表格干扰问题
position: unset;
}
.time {
font-size: 12px;
color: #999;
}
.bottom {
// margin-top: 13px;
line-height: 12px;
display: flex;
justify-content: space-between;
align-items: center;
}
.button {
padding: 0;
min-height: auto;
}
.image {
width: 100%;
display: block;
}
.rightWra {
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;
.rightFoldDiv {
width: 30px;
height: 30px;
position: absolute;
left: -8%;
top: 50%;
transform: translate(0, -50%);
font-size: 30px;
color: #ccc;
}
.rightTop {
width: 100%;
height: 100%;
opacity: 1;
display: flex;
flex-direction: column;
justify-content: flex-start;
align-items: center;
.farmlandDiv {
width: 100%;
height: 30%;
opacity: 1;
display: flex;
justify-content: center;
}
.Phdiv {
width: 100%;
display: flex;
height: 30%;
justify-content: center;
}
.depth {
width: 90%;
height: 26px;
opacity: 1;
border-radius: 4px;
font-size: 12px;
color: rgba(255, 255, 255, 1);
margin-top: 20px;
cursor: pointer;
background: linear-gradient(
180deg,
rgba(16, 111, 111, 0.1) 0%,
rgba(47, 214, 214, 0.1) 100%
);
border: 1px solid rgba(23, 194, 180, 0.3);
display: flex;
align-items: center;
p {
flex: 1;
text-align: center;
height: 100%;
display: flex;
align-items: center;
justify-content: center;
}
.SelectedDiv {
opacity: 1;
border-radius: 4px;
background: linear-gradient(
180deg,
rgba(16, 111, 111, 1) 0%,
rgba(47, 214, 214, 1) 100%
);
}
}
.soilDiv {
width: 100%;
display: flex;
height: 30%;
justify-content: center;
}
.ProgressBar {
width: 100%;
height: 9px;
opacity: 1;
}
}
.rightbottom {
width: 100%;
height: 490px;
opacity: 1;
display: flex;
flex-direction: column;
justify-content: flex-start;
align-items: center;
.el-select {
width: 80%;
font-size: 14px;
color: #333;
background: rgba(22, 94, 102, 1);
border: 1px solid rgba(4, 153, 153, 1) !important;
margin-top: 20px;
:deep(.el-input__wrapper) {
background-color: transparent;
}
:deep(.el-input__inner) {
color: rgba(255, 255, 255, 0.7);
}
}
}
}
: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);
width: 20%;
.el-input__inner {
color: rgba(255, 255, 255, 1);
}
}
:deep(.el-table__expand-icon) {
color: #fff;
}
.selectdiv {
display: flex;
flex-direction: row;
flex-wrap: wrap;
p {
padding: 10px;
width: 50%;
}
}
.block {
display: flex;
justify-content: flex-end;
}
:deep(.el-table__expanded-cell) {
background: linear-gradient(
90deg,
rgba(38, 255, 255, 0.15) 0%,
rgba(38, 255, 255, 0.01) 100%
) !important;
}
.modelDiv {
:deep(.el-dialog) {
width: 50%;
color: #fff;
.el-dialog__title {
color: #fff;
}
.center {
color: #fff;
div {
display: flex;
justify-content: space-between;
margin: 10px;
}
}
}
}
:deep(.el-image) {
box-shadow: none;
}
.legend {
position: absolute;
right: 28%;
bottom: 18%;
width: 129px;
height: 338px;
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;
}
}
:deep(.el-checkbox__label) {
color: rgba(255, 255, 255, 1);
}
}
.showBox {
width: 285px;
height: 173px;
opacity: 1;
border-radius: 5px;
background: rgba(2, 31, 26, 0.6);
display: flex;
flex-direction: column;
justify-content: flex-start;
align-items: flex-end;
padding: 6px 8px 6px 8px;
}
.bottom_center {
position: absolute;
left: 26%;
// transform: translate(-50%);
width: calc(100% - 50% - (1vw * 2));
min-width: 380px;
bottom: 6%;
height: 30%;
opacity: 1;
border-radius: 5px;
background: rgba(2, 31, 26, 0.6);
border: 1px solid rgba(4, 153, 153, 1);
display: flex;
.left_bottom {
width: 50%;
}
.right_bottom {
width: 50%;
.tableDiv {
height: 81%;
margin-bottom: 20px;
}
}
.el-table {
--el-table-tr-bg-color: none;
--el-table-border-color: none;
::v-deep .el-table__body tr.el-table__row--striped td {
background: rgba(38, 255, 255, 0.01);
}
// ::v-deep .el-table__row {
// background: linear-gradient(
// 90deg,
// rgba(38, 255, 255, 0.15) 0%,
// rgba(38, 255, 255, 0.01) 100%
// );
// }
::v-deep .el-table__body tr:hover > td {
background: linear-gradient(
90deg,
rgba(38, 255, 255, 0.15) 0%,
rgba(38, 255, 255, 0.01) 100%
) !important;
}
color: rgba(255, 255, 255, 1);
}
.el-checkbox-group {
display: flex;
flex-direction: column;
}
:deep(.ones) {
width: 100%;
height: 171;
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;
color: rgba(255, 255, 255, 1);
}
.imgdiv {
width: 100%;
height: calc(100% - 50px);
display: flex;
justify-content: center;
padding: 10px;
}
.bottonFold {
position: absolute;
left: 47%;
top: -16%;
}
}
.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;
}
#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;
color: #fff;
box-shadow: inset 0px 0px 15px 6px rgba(41, 255, 255, 0.5);
border: rgba(41, 255, 255, 1);
}
#pop {
opacity: 1;
border-radius: 5px;
background: rgba(2, 31, 26, 0.6);
display: none;
flex-direction: column;
justify-content: flex-start;
align-items: flex-end;
padding: 6px 8px 6px 8px;
color: rgba(255, 255, 255, 1);
.content {
div {
display: flex;
align-items: center;
justify-content: space-between;
p {
width: 159px;
border-radius: 2px;
background: rgba(217, 231, 255, 0.2);
display: flex;
justify-content: center;
align-items: center;
}
}
}
.cancel {
position: absolute;
right: 10px;
top: 5px;
color: rgba(255, 255, 255, 1);
cursor: pointer;
}
}
.back_button {
position: absolute;
right: 30%;
top: 20px;
}
:deep(.el-table--enable-row-hover .el-table__body tr:hover > td.el-table__cell) {
background: rgba(38, 255, 255, 0.1);
}
:deep(.el-table--striped .el-table__body tr.el-table__row--striped td.el-table__cell) {
background: rgba(38, 255, 255, 0.01);
}
:deep(.el-select__popper.el-popper) {
}
:deep(.el-dialog) {
opacity: 1;
border-radius: 4px;
background: rgba(3, 48, 54, 0.95);
color: rgba(255, 255, 255, 1);
--el-dialog-width: 70%;
}
:deep(.el-dialog__header) {
opacity: 1;
border-bottom: 1px solid rgba(255, 255, 255, 0.3);
padding: 10px;
}
.my-header {
display: flex;
flex-direction: row;
justify-content: space-between;
color: rgba(255, 255, 255, 1);
.buttonbox {
display: flex;
align-items: center;
}
}
:deep(.el-dialog__header) {
margin-right: 0;
.my-header {
align-items: center;
.el-dialog__title {
color: rgba(255, 255, 255, 1);
}
}
}
</style>
<style lang="scss">
.el-popper {
border: none !important;
background: transparent !important;
}
.el-popper__arrow::before {
background: rgba(41, 255, 255, 0.7) !important;
display: none;
}
.select_div {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 10px;
padding: 0 10px;
.slele_time {
display: flex;
align-items: center;
div {
display: flex;
align-items: center;
}
}
.device {
width: 105px;
}
}
.tableDiv {
// background: rgba(255, 255, 255, 0.05);
width: 100%;
height: 100%;
padding: 5px 10px 5px 10px;
color: rgba(255, 255, 255, 1);
.el-table {
--el-table-tr-bg-color: none;
--el-table-border-color: none;
color: rgba(255, 255, 255, 1);
}
// margin: 20px auto;
}
.el-popper {
background: #fff !important;
}
</style>