947 lines
29 KiB
Vue
Raw Normal View History

2023-04-17 18:02:03 +08:00
<template>
<div class="center">
<div style="width: 100%; height: 100%" id="cesiumContainer"></div>
<div class="leftWra">
<div class="leftTop">
<div class="title">作物分类面积统计</div>
<div ref="areaDiv" class="areaDiv"></div>
</div>
<div class="leftbottom">
<div class="title">作物类型统计</div>
<div ref="typesofDiv" class="typesofDiv"></div>
</div>
</div>
<div class="rightWra">
<div class="rightTop">
<div class="title">
作物类型统计-高标准农田
<p>
下载 &nbsp;
<img
src="@/assets/icons/svg/downloads.svg"
style="width: 14px; height: 14px; cursor: pointer"
/>
</p>
</div>
<div ref="farmlandDiv" class="farmlandDiv"></div>
<div ref="ProgressBarDiv" class="ProgressBar"></div>
</div>
<div class="rightbottom">
<div class="title">
作物类型统计-行政区划
<p>
下载 &nbsp;
<img
src="@/assets/icons/svg/downloads.svg"
style="width: 14px; height: 14px; cursor: pointer"
/>
</p>
</div>
<el-select v-model="value" clearable placeholder="Select">
<el-option
v-for="item in options"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
<div ref="ASdivisionDiv" class="ASdivision"></div>
</div>
</div>
<div class="legend">
<p>图例</p>
<div class="mt-4">
<el-checkbox
style="
background: rgba(102, 142, 214, 0.8);
border: 1px solid rgba(102, 142, 214, 1);
"
v-model="checked3"
label="小麦"
/>
<el-checkbox
style="
background: rgba(255, 225, 104, 0.8);
border: 1px solid rgba(255, 225, 104, 1);
"
v-model="checked4"
label="玉米"
/>
<el-checkbox
style="
background: rgba(156, 220, 130, 0.8);
border: 1px solid rgba(156, 220, 130, 1);
"
v-model="checked3"
label="大豆"
/>
<el-checkbox
style="
background: rgba(209, 91, 127, 0.8);
border: 1px solid rgba(209, 91, 127, 1);
"
v-model="checked4"
label="地瓜"
/>
<el-checkbox
style="
background: rgba(212, 236, 89, 0.8);
border: 1px solid rgba(212, 236, 89, 1);
"
v-model="checked3"
label="花生"
/>
<el-checkbox
style="
background: rgba(50, 211, 235, 0.8);
border: 1px solid rgba(50, 211, 235, 1);
"
v-model="checked4"
label="蓝莓"
/>
<el-checkbox
style="
background: rgba(91, 196, 159, 0.8);
border: 1px solid rgba(91, 196, 159, 1);
"
v-model="checked3"
label="茶叶"
/>
<el-checkbox
style="
background: rgba(254, 182, 77, 0.8);
border: 1px solid rgba(254, 182, 77, 1);
"
v-model="checked4"
label="马铃薯"
/>
<el-checkbox
style="
background: rgba(250, 129, 109, 0.8);
border: 1px solid rgba(250, 129, 109, 1);
"
v-model="checked3"
label="白菜和萝卜"
/>
</div>
</div>
<div class="bottom_center"></div>
</div>
2023-04-16 22:33:44 +08:00
</template>
2023-04-17 18:02:03 +08:00
<script setup>
import { ref, onMounted, inject } from 'vue';
import * as echarts from 'echarts';
2023-04-16 22:33:44 +08:00
2023-04-17 18:02:03 +08:00
const viewer = ref(null);
const areaDiv = ref(null);
const typesofDiv = ref(null);
const farmlandDiv = ref(null);
const ProgressBarDiv = ref(null);
const ASdivisionDiv = ref(null);
const value = ref('');
var data = {
title: ['区域一', '区域二', '区域三', '区域四', '区域五', '区域六', '区域七', '区域八'],
corn: [333.3, null, 500, 500, 333.3, null, 333.3, 500],
soybean: [333.3, null, null, null, 333.3, null, 333.3, null],
peanut: [333.3, 500, 500, null, 333.3, 500, 333.3, null],
wheat: [null, 500, null, 500, null, 500, null, null],
Blueberries: [null, null, null, null, null, null, null, 500],
};
const options = [
{
value: 'Option1',
label: 'Option1',
},
{
value: 'Option2',
label: 'Option2',
},
];
// 组件挂载完成后执行
onMounted(() => {
initMap();
areachar();
typesof();
farmland();
ProgressBar();
ASdivision();
});
function initMap() {
viewer.value = new Cesium.Viewer('cesiumContainer', {});
}
//
function areachar() {
const areaDivIntance = echarts.init(areaDiv.value);
var option = {
// backgroundColor: 'rgba(255, 255, 255, 0.1)',
tooltip: {
trigger: 'axis',
axisPointer: {
type: 'shadow',
},
},
grid: {
top: '15%',
right: '3%',
left: '11%',
bottom: '12%',
},
xAxis: [
{
type: 'category',
data: ['小麦', '玉米', '大豆', '花生', '蓝莓'],
axisLine: {
lineStyle: {
color: '#C0C4CC',
width: 1,
},
},
axisTick: {
show: false,
},
axisLabel: {
margin: 10,
color: 'rgba(255, 255, 255, 0.7)',
textStyle: {
fontSize: 14,
},
},
},
],
yAxis: [
{
axisLabel: {
formatter: '{value}',
color: 'rgba(255, 255, 255, 0.7)',
},
axisLine: {
show: false,
},
axisTick: {
show: false,
},
splitLine: {
lineStyle: {
color: 'rgba(192,196,204,1)',
type: 'dashed',
},
},
name: '面积(亩)',
},
],
series: [
{
name: '面积',
type: 'bar',
data: [3598, 1235, 2354, 3251, 1652],
barWidth: '14px',
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(
0,
0,
0,
1,
[
{
offset: 0,
color: 'rgba(71,179,161,0.8)', // 0% 处的颜色
},
{
offset: 1,
color: 'rgba(212,236,89,1) ', // 100% 处的颜色
},
],
false
),
barBorderRadius: [30, 30, 30, 30],
label: {
show: true,
position: 'top',
formatter: '{c}',
textStyle: {
color: 'rgba(255, 255, 255, 0.8)',
fontSize: '14',
},
},
},
},
},
],
legend: {
right: 0,
top: 14,
data: ['面积'],
textStyle: {
color: ' rgba(255,255,255,0.7)',
fontSize: '14',
},
},
};
option && areaDivIntance.setOption(option);
}
function typesof() {
const typesofDivIntance = echarts.init(typesofDiv.value);
var option = {
tooltip: {
trigger: 'item',
formatter: '{a} <br/>{b}: {c} ({d}%)',
},
color: [
'rgba(212,236,89,0.8)',
'rgba(102,142,214,0.8)',
'rgba(156,220,130,0.8)',
'rgba(255,225,104,0.8)',
], // 指定饼图颜色
legend: {
orient: 'vertical', //图例方向分水平和垂直
icon: 'rect', //图例样式
x: 'center', //图例位置
bottom: 'bottom',
data: ['花生', '小麦', '大豆', '玉米'],
textStyle: {
color: ' rgba(255,255,255,0.7)',
fontSize: '14',
},
},
series: [
{
name: '占比',
type: 'pie',
radius: ['50%', '70%'],
avoidLabelOverlap: true,
label: {
normal: {
show: true,
position: 'left',
textStyle: {
color: 'rgba(41,255,219,1)',
},
},
emphasis: {
show: true,
textStyle: {
fontSize: '30',
fontWeight: 'bold',
},
},
},
labelLine: {
show: true,
normal: {
show: true,
},
},
data: [
{ value: 25, name: '花生' },
{ value: 25, name: '小麦' },
{ value: 25, name: '大豆' },
{ value: 25, name: '玉米' },
],
},
],
};
option && typesofDivIntance.setOption(option);
}
function farmland() {
const farmlandDivIntance = echarts.init(farmlandDiv.value);
var option = {
title: {
text: '',
subtext: '',
},
tooltip: {
trigger: 'axis',
axisPointer: {
type: 'shadow',
},
},
legend: {
icon: 'circle',
left: 'center',
top: '5',
show: true,
},
grid: {
containLabel: true,
bottom: '10%',
},
xAxis: {
type: 'category',
data: ['区域一', '区域二', '区域三', '区域四', '区域五'],
axisLine: {
lineStyle: {
color: '#C0C4CC',
width: 1,
},
},
axisTick: {
show: false,
},
axisLabel: {
margin: 10,
color: 'rgba(255, 255, 255, 0.7)',
textStyle: {
fontSize: 14,
},
},
},
yAxis: {
type: 'value',
splitLine: {
lineStyle: {
color: 'rgba(192,196,204,1)',
type: 'dashed',
},
},
},
series: [
{
name: '生活',
type: 'bar',
barWidth: 14,
stack: '数量',
data: [1666, 1666, 1666, 1666, 1666],
itemStyle: {
normal: {
//颜色渐变
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: 'rgba(102, 142, 214, 0.8)',
},
{
offset: 1,
color: 'rgba(102, 142, 214, 0.8)',
},
]),
},
},
},
{
name: '工业',
type: 'bar',
barWidth: 30,
stack: '数量',
data: [1666, 1666, 1666, 1666, 1666],
itemStyle: {
normal: {
//颜色渐变
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: 'rgba(255, 225, 104, 0.8)',
},
{
offset: 1,
color: 'rgba(255, 225, 104, 0.8)',
},
]),
},
},
},
{
name: '农业',
type: 'bar',
barWidth: 30,
stack: '数量',
data: [1666, 1666, 1666, 1666, 1666],
itemStyle: {
normal: {
//颜色渐变
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: 'rgba(209, 91, 127, 0.8)',
},
{
offset: 1,
color: 'rgba(209, 91, 127, 0.8)',
},
]),
},
},
},
],
};
option && farmlandDivIntance.setOption(option, { notMerge: true, grid: { bottom: 20 } });
}
function ProgressBar() {
const ProgressBarDivIntance = echarts.init(ProgressBarDiv.value);
var option = {
// backgroundColor: '#031d33',
grid: {
top: 0,
bottom: 0,
left: '10%',
right: '10%',
},
xAxis: {
show: false,
type: 'value',
boundaryGap: [0, 0],
},
yAxis: [
{
type: 'category',
data: [''],
axisLine: { show: false },
axisTick: [
{
show: false,
},
],
},
],
series: [
{
name: '金额',
type: 'bar',
zlevel: 1,
itemStyle: {
normal: {
barBorderRadius: 30,
color: new echarts.graphic.LinearGradient(1, 0, 0, 1, [
{
offset: 1,
color: 'rgba(7,99,84,0.95) ',
},
{
offset: 0,
color: 'rgba(71,179,161,0.95)',
},
]),
},
},
barWidth: 20,
data: [10],
},
{
name: '背景',
type: 'bar',
barWidth: 20,
barGap: '-100%',
data: [20],
itemStyle: {
normal: {
color: 'rgba(255, 255, 255, 0.2)',
barBorderRadius: 50,
},
},
},
],
};
option && ProgressBarDivIntance.setOption(option);
}
function ASdivision(params) {
const ASdivisionDivIntance = echarts.init(ASdivisionDiv.value);
var option = {
// title: {
// text: 'BY制程单位',
// left: '1%',
// top: '1%',
// textStyle: {
// fontSize: 16,
// color: '#9d9d9d',
// fontWeight: 'bold',
// },
// },
// legend: {
// data: ['正式工占比', '派遣工占比'],
// orient: 'horizontal',
// itemHeight: 20,
// itemWidth: 40,
// left: '30%',
// top: '8%',
// textStyle: {
// fontSize: 16,
// },
// },
// 设置图表的位置
grid: {
bottom: '8%',
left: '6%',
right: '6%',
top: '6%',
containLabel: true,
},
// X轴
xAxis: {
type: 'value', // 坐标轴类型, 'value' 数值轴,适用于连续数据
// 坐标轴刻度
axisTick: {
show: false, // 是否显示坐标轴刻度 默认显示
},
// 坐标轴轴线
axisLine: {
// 是否显示坐标轴轴线 默认显示
show: false, // 是否显示坐标轴轴线 默认显示
},
// 坐标轴在图表区域中的分隔线
splitLine: {
show: false, // 是否显示分隔线。默认数值轴显示
},
// 坐标轴刻度标签
axisLabel: {
show: false, // 是否显示刻度标签 默认显示
},
},
// Y轴
yAxis: [
// 左侧Y轴
{
// 坐标轴类型, 'category' 类目轴,适用于离散的类目数据
// 为该类型时必须通过 data 设置类目数据
type: 'category',
// 坐标轴刻度
axisTick: {
show: false, // 是否显示坐标轴刻度 默认显示
},
// 坐标轴轴线
axisLine: {
// 是否显示坐标轴轴线 默认显示
show: false, // 是否显示坐标轴轴线 默认显示
lineStyle: {
// 坐标轴线线的颜色
color: '#cdd3ee',
},
},
// 坐标轴在图表区域中的分隔线
splitLine: {
show: false, // 是否显示分隔线。默认数值轴显示
},
// 坐标轴刻度标签
axisLabel: {
show: true, // 是否显示刻度标签 默认显示
fontSize: 16, // 文字的字体大小
color: 'rgba(255, 255, 255, 1)', // 刻度标签文字的颜色
// 使用字符串模板,模板变量为刻度默认标签 {value}
formatter: '{value}',
},
// 类目数据在类目轴type: 'category')中有效
data: data.title,
inverse: true,
},
],
// 系列列表
series: [
{
type: 'bar', // 系列类型
name: '玉米', // 系列名称, 用于tooltip的显示, legend 的图例筛选
// 数据堆叠同个类目轴上系列配置相同的stack值后后一个系列的值会在前一个系列的值上相加
stack: '总量',
barMaxWidth: 30, // 柱条的最大宽度,不设时自适应
// 图形上的文本标签
label: {
show: true,
position: 'inside',
formatter: '玉米',
textStyle: {
fontSize: 14,
fontWeight: 'bolder',
color: 'rgba(255,255,255,1)',
},
},
// 图形样式
itemStyle: {
color: '#fdad3c',
},
data: data.corn, // 系列中的数据内容数组
},
{
type: 'bar', // 系列类型
name: '大豆', // 系列名称, 用于tooltip的显示, legend 的图例筛选
// 数据堆叠同个类目轴上系列配置相同的stack值后后一个系列的值会在前一个系列的值上相加
stack: '总量',
barMaxWidth: 30, // 柱条的最大宽度,不设时自适应
// 图形上的文本标签
label: {
show: true,
position: 'inside',
formatter: '大豆',
textStyle: {
fontSize: 14,
fontWeight: 'bolder',
color: 'rgba(255,255,255,1)',
},
},
// 图形样式
itemStyle: {
color: 'rgba(156, 220, 130, 0.8)',
},
data: data.soybean, // 系列中的数据内容数组
},
{
type: 'bar', // 系列类型
name: '花生', // 系列名称, 用于tooltip的显示, legend 的图例筛选
// 数据堆叠同个类目轴上系列配置相同的stack值后后一个系列的值会在前一个系列的值上相加
stack: '总量',
barMaxWidth: 30, // 柱条的最大宽度,不设时自适应
// 图形上的文本标签
label: {
show: true,
position: 'inside',
formatter: '花生',
textStyle: {
fontSize: 14,
fontWeight: 'bolder',
color: 'rgba(255,255,255,1)',
},
},
// 图形样式
itemStyle: {
color: 'rgba(212, 236, 89, 0.8)',
},
data: data.peanut, // 系列中的数据内容数组
},
{
type: 'bar', // 系列类型
name: '小麦', // 系列名称, 用于tooltip的显示, legend 的图例筛选
// 数据堆叠同个类目轴上系列配置相同的stack值后后一个系列的值会在前一个系列的值上相加
stack: '总量',
barMaxWidth: 30, // 柱条的最大宽度,不设时自适应
// 图形上的文本标签
label: {
show: true,
position: 'inside',
formatter: '小麦',
textStyle: {
fontSize: 14,
fontWeight: 'bolder',
color: 'rgba(255,255,255,1)',
},
},
// 图形样式
itemStyle: {
color: 'rgba(102, 142, 214, 0.8)',
},
data: data.wheat, // 系列中的数据内容数组
},
{
type: 'bar', // 系列类型
name: '蓝莓', // 系列名称, 用于tooltip的显示, legend 的图例筛选
// 数据堆叠同个类目轴上系列配置相同的stack值后后一个系列的值会在前一个系列的值上相加
stack: '总量',
barMaxWidth: 30, // 柱条的最大宽度,不设时自适应
// 图形上的文本标签
label: {
show: true,
position: 'inside',
formatter: '蓝莓',
textStyle: {
fontSize: 14,
fontWeight: 'bolder',
color: 'rgba(255,255,255,1)',
},
},
// 图形样式
itemStyle: {
color: 'rgba(50, 211, 235, 0.8)',
},
data: data.Blueberries, // 系列中的数据内容数组
},
],
};
option && ASdivisionDivIntance.setOption(option);
2023-04-16 22:33:44 +08:00
}
</script>
2023-04-17 18:02:03 +08:00
<style lang="scss" scoped>
$height: calc(100vh - 100px);
.center {
width: 100%;
height: 100%;
.title {
width: 100%;
height: 45px;
background: url('@/assets/images/title.png');
color: #fff;
font-size: 18px;
font-weight: 700;
line-height: 45px;
padding-left: 46px;
display: flex;
align-items: center;
justify-content: space-between;
p {
width: 79px;
height: 25px;
border-radius: 20px;
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;
margin-right: 30px;
}
}
}
.leftWra {
position: absolute;
left: 20px;
top: 50px;
width: 455px;
height: 957px;
opacity: 1;
background: rgba(2, 31, 26, 0.3);
.leftTop {
width: 455px;
height: 397px;
opacity: 1;
display: flex;
flex-direction: column;
justify-content: flex-start;
align-items: center;
.areaDiv {
width: 415px;
height: 327px;
opacity: 1;
display: flex;
padding: 1px;
}
}
.leftbottom {
width: 455px;
height: 337px;
opacity: 1;
display: flex;
flex-direction: column;
justify-content: flex-start;
align-items: center;
.typesofDiv {
width: 410px;
height: 267px;
}
}
}
.rightWra {
position: absolute;
top: 50px;
right: 20px;
width: 455px;
height: 957px;
opacity: 1;
display: flex;
flex-direction: column;
align-items: center;
background: rgba(2, 31, 26, 0.3);
.rightTop {
width: 455px;
height: 439px;
opacity: 1;
display: flex;
flex-direction: column;
justify-content: flex-start;
align-items: center;
.farmlandDiv {
width: 415px;
height: 340px;
opacity: 1;
}
.ProgressBar {
width: 372px;
height: 9px;
opacity: 1;
}
}
.rightbottom {
width: 455px;
height: 490px;
opacity: 1;
display: flex;
flex-direction: column;
justify-content: flex-start;
align-items: center;
.el-select {
width: 400px;
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;
}
}
.ASdivision {
width: 415px;
height: 368px;
opacity: 1;
}
}
}
.legend {
position: absolute;
left: 1296px;
top: 540px;
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--large {
height: 30px;
width: 108px;
margin-bottom: 2px;
margin: 2px 10px;
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);
}
}
2023-04-16 22:33:44 +08:00
2023-04-17 18:02:03 +08:00
.bottom_center {
position: fixed;
left: 693px;
top: 975px;
width: 732px;
height: 75px;
opacity: 1;
border-radius: 5px;
background: rgba(2, 31, 26, 0.6);
border: 1px solid rgba(4, 153, 153, 1);
}
</style>