<template>
    <div class="center">
        <div style="width: 100%; height: 100%" id="cesiumContainer"></div>
        <div class="leftWra">
            <div class="leftTop">
                <div class="title"><span>作物分类面积统计</span></div>
                <div ref="areaDiv" class="areaDiv"></div>
            </div>
            <div class="leftbottom">
                <div class="title"><span>作物类型统计</span></div>
                <div ref="typesofDiv" class="typesofDiv"></div>
            </div>
        </div>
        <div class="rightWra">
            <div class="rightTop">
                <div class="title">
                    <span>作物类型统计-高标准农田</span>
                    <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">
                    <span>作物类型统计-行政区划</span>
                    <p>
                        下载 &nbsp;
                        <img
                            src="@/assets/icons/svg/downloads.svg"
                            style="width: 14px; height: 14px; cursor: pointer"
                        />
                    </p>
                </div>
                <el-select
                    popper-class="select_city"
                    @change="selectTab(item)"
                    v-model="value"
                    clearable
                    placeholder="全部"
                >
                    <el-option
                        v-for="item in Township.arr"
                        :key="item.properties.XZDM"
                        :label="item.properties.XZMC"
                        :value="item.properties.XZDM"
                    />
                </el-select>
                <div ref="ASdivisionDiv" class="ASdivision"></div>
            </div>
        </div>
        <el-collapse class="legend" accordion>
            <el-collapse-item name="1">
                <template #title>图例</template>
                <div class="mt-4">
                    <el-checkbox-group v-model="checkList" @change="change">
                        <el-checkbox
                            v-for="(value, item, key) in dic"
                            :key="key"
                            :style="{
                                background: value.color,
                                border: `1px solid ${value.color}`,
                                width: `100%`,
                            }"
                            v-model="checked3"
                            :disabled="value.disabled"
                            :label="item"
                        />

                        <!-- <el-checkbox style="
                                background: rgba(251, 171, 60, 1);
                                border: 1px solid rgba(251, 171, 60, 1);
                                width: 100%;
                            " v-model="checked3" label="小麦" />
                        <el-checkbox style="
                                background: rgba(251, 219, 13, 1);
                                border: 1px solid rgba(251, 219, 13, 1);
                                width: 100%;
                            " v-model="checked4" label="玉米" />
                        <el-checkbox style="
                                background: rgba(244, 218, 136, 1);
                                border: 1px solid rgba(244, 218, 136, 1);
                                width: 100%;
                            " v-model="checked3" label="大豆" />
                        <el-checkbox style="
                                background: rgba(174, 83, 110, 1);
                                border: 1px solid rgba(174, 83, 110, 1);
                                width: 100%;
                            " v-model="checked4" label="地瓜" />
                        <el-checkbox style="
                                background: rgba(242, 177, 167, 1);
                                border: 1px solid rgba(242, 177, 167, 1);
                                width: 100%;
                            " v-model="checked3" label="花生" />
                        <el-checkbox style="
                                background: rgba(50, 211, 235, 0.8);
                                border: 1px solid rgba(50, 211, 235, 1);
                                width: 100%;
                            " v-model="checked4" label="蓝莓" />
                        <el-checkbox style="
                                background: rgba(91, 196, 159, 1);
                                border: 1px solid rgba(91, 196, 159, 1);
                                width: 100%;
                            " v-model="checked3" label="茶叶" />
                        <el-checkbox style="
                                background: rgba(225, 153, 75, 1);
                                border: 1px solid rgba(225, 153, 75, 1);
                                width: 100%;
                            " v-model="checked3" label="马铃薯" />
                        <el-checkbox style="
                                background: rgba(166, 209, 82, 1);
                                border: 1px solid rgba(166, 209, 82, 1);
                                width: 100%;
                            " v-model="checked3" label="白菜和萝卜" />
                        <el-checkbox style=" -->
                        background: rgba(175, 110, 250, 0.8); border: 1px solid rgba(175, 110, 250,
                        0.8); width: 100%; " v-model="checked3" label="其他" />
                    </el-checkbox-group>
                </div>
            </el-collapse-item>
        </el-collapse>
        <div class="bottom_center">
            <TimeLine />
        </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="popup1">
            <div v-for="(item, index) in clickInfoMap.info" :key="index">
                <div class="rowWra">
                    <span>作物:</span>
                    <span>{{ item.crop }}</span>
                </div>
                <div class="rowWra">
                    <span>面积:</span>
                    <span>{{ (item.Shape_Area / 666.67).toFixed(2) }} 亩</span>
                </div>
                <div class="rowWra">
                    <span>镇名:</span>
                    <span>{{ item.town }}</span>
                </div>
                <div class="rowWra" v-if="item.village">
                    <span>村名:</span>
                    <span>{{ item.village }}</span>
                </div>
                <div class="rowWra" v-if="item.people">
                    <span>土地所有人:</span>
                    <span>{{ item.people }}</span>
                </div>
            </div>
            <div class="cancel" @click="hiddenOverlayChart">X</div>
        </div>
        <el-button v-if="flag" class="back_button" @click="back()">返回</el-button>
    </div>
</template>

<script setup>
import { ref, onMounted, inject, watch } from 'vue';
import * as echarts from 'echarts';
import 'echarts-gl';
import TimeLine from '@/components/TimeLine/TimeLine.vue';
import { useEcharts } from '@/hooks/useEcharts';
import { getarea, getTownship, getvillage, getareas, dow } from '@/api/crops/classify.js';
import axios from 'axios';

let viewer = ref(null);
const areaDiv = ref(null);
const typesofDiv = ref(null);
const farmlandDiv = ref(null);
const ProgressBarDiv = ref(null);
const ASdivisionDiv = ref(null);
let Township = reactive({ arr: [], brr: [], crr: [] }); //街道
const value = ref('370211');
const clickInfoMap = ref({ info: [] });
const flag = ref(false);
let dd = {
    小麦: [],
    玉米: [],
    大豆: [],
    地瓜: [],
    花生: [],
    蓝莓: [],
    茶叶: [],
    马铃薯: [],
    白菜和萝卜: [],
    其他: [],
};
let dic = {
    小麦: { color: 'rgba(255, 141, 26, 1)', disabled: false },
    玉米: { color: 'rgba(255, 255, 26, 1)', disabled: true },
    大豆: { color: 'rgba(255, 201, 148, 1)', disabled: false },
    地瓜: { color: 'rgba(255, 84, 84, 1)', disabled: false },
    花生: { color: 'rgba(255, 140, 255, 1)', disabled: false },
    蓝莓: { color: 'rgba(26, 255, 255, 1)', disabled: false },
    茶叶: { color: 'rgba(26, 255, 140, 1)', disabled: false },
    马铃薯: { color: 'rgba(255, 171, 87, 1)', disabled: true },
    白菜和萝卜: { color: 'rgba(140, 255, 26, 1)', disabled: true },
    其他: { color: 'rgba(140, 26, 255, 1)', disabled: false },
};
// 图层字典
let layersDic = {
    小麦: 'shuzisannong:xiaomai',
    // 玉米: 'shuzisannong:yumi',
    大豆: 'shuzisannong:dadou',
    地瓜: 'shuzisannong:digua',
    花生: 'shuzisannong:huasheng',
    蓝莓: 'shuzisannong:lanmei',
    茶叶: 'shuzisannong:chaye',
    其他: 'shuzisannong:other',
    // 马铃薯: 'rgba(225, 153, 75, 1)',
    // 白菜和萝卜: 'rgba(166, 209, 82, 1)',
};
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],
};
let classData = [302034, 243990, 42344, 34234, 304235];
const options = [
    {
        value: 'Option1',
        label: 'Option1',
    },
    {
        value: 'Option2',
        label: 'Option2',
    },
];
// 组件挂载完成后执行
onMounted(() => {
    initonMounted();
    // checkList.value = Object.keys(dic.filter(item => !item.disabled))
});
// 初始化
function initonMounted() {
    getaArea(); //面积
    getTownships();
    getvillages(); //村
    initMap(); //地图
    areachar(); //图表
    typesof(); //图表
    farmland(); //图表
    ASdivision(); //图表
    getArea(); //请求
    getFarmland();
    checkList.value = Object.keys(dic);
}
const mapOption = {
    url:
        'http://{s}.tianditu.gov.cn/img_c/wmts?service=wmts&request=GetTile&version=1.0.0' +
        '&LAYER=img&tileMatrixSet=c&TileMatrix={TileMatrix}&TileRow={TileRow}&TileCol={TileCol}' +
        '&style=default&format=tiles&tk=31091965e263284a501a723b8909f405',
    layer: 'tdtCva',
    style: 'default',
    format: 'tiles',
    tileMatrixSetID: 'c',
    subdomains: ['t0', 't1', 't2', 't3', 't4', 't5', 't6', 't7'],
    tilingScheme: new Cesium.GeographicTilingScheme(),
    tileMatrixLabels: [
        '1',
        '2',
        '3',
        '4',
        '5',
        '6',
        '7',
        '8',
        '9',
        '10',
        '11',
        '12',
        '13',
        '14',
        '15',
        '16',
        '17',
        '18',
        '19',
    ],
    maximumLevel: 18,
};
Cesium.Ion.defaultAccessToken =
    'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqdGkiOiJiYzcwZmJmNi02MzQ5LTQ1MGEtODgzMy0yZTZiZGExY2MzMGMiLCJpZCI6MTAxOTgsInNjb3BlcyI6WyJhc2wiLCJhc3IiLCJnYyJdLCJpYXQiOjE1ODEzMDgxNTR9.NeJU4yfUi-SnLrNDOBYsQgmiSh3B4axCTi1m84Qw99c';
function initMap() {
    viewer = new Cesium.Viewer('cesiumContainer', {
        baseLayerPicker: false,
        shouldAnimate: true, //自动播放
        infoBox: false, //信息框
        animation: false, //“动画”窗口小部件提供用于播放,暂停和倒退的按钮,以及当前时间和日期,并由“飞梭环”包围,用于控制动画的速度。cesium示例地图左下角那个
        timeline: false, //时间轴是用于显示和控制当前场景时间的小部件。
        geocoder: false, //查找,用于查找地址和地标,以及将照相机悬挂到它们。使用铯离子进行地址解析。,cesium示例地图右上角的放大镜
        homeButton: false, //主页按钮
        navigationHelpButton: false, //导航帮助按钮
        selectionIndicator: false, //原生选择绿框
        fullscreenButton: false, //右下角的全屏按钮
        // terrainProvider:new Cesium.createWorldTerrain(),
        terrainProvider: new Cesium.EllipsoidTerrainProvider({}),
        sceneModePicker: false, //是否显示投影方式控件
        contextOptions: {
            webgl: {
                alpha: true,
            },
        },

        imageryProvider: new Cesium.WebMapTileServiceImageryProvider({
            ...mapOption,
            // url: "http://service.sdmap.gov.cn/hisimage/weipian202209?tk=9cc3e9deb3cf643b6f133717c333d16d",
            // layer: "c",
            // style: ",c",
            // format: "image/png",
            // tileMatrixSetID: "EPSG:4490",
            // rectangle: Cesium.Rectangle.fromDegrees(114.8, 34.35, 122.82, 38.43),
            // // subdomains: ["t0", "t1", "t2", "t3", "t4", "t5", "t6", "t7"],
            // tilingScheme: new Cesium.GeographicTilingScheme(),
            // tileMatrixLabels: ["1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13", "14", "15", "16", "17", "18", "19"],
            // // maximumLevel: 18
        }),
    });
    // 去除logo
    viewer.cesiumWidget.creditContainer.style.display = 'none';

    viewer.camera.flyTo({
        destination: Cesium.Rectangle.fromDegrees(119.5091, 35.5671, 120.3285, 36.1455),
        duration: 2,
    });

    // 图层点击事件
    layerClick();
    // 添加镇级矢量
    addWms('shuzisannong:huangdaoqu_town', 'shuzisannong:huangdaoqu_town');
}

const checkList = ref([]);

function getLevel(height) {
    if (height > 48000000) {
        return 0;
    } else if (height > 24000000) {
        return 1;
    } else if (height > 12000000) {
        return 2;
    } else if (height > 6000000) {
        return 3;
    } else if (height > 3000000) {
        return 4;
    } else if (height > 1500000) {
        return 5;
    } else if (height > 750000) {
        return 6;
    } else if (height > 375000) {
        return 7;
    } else if (height > 187500) {
        return 8;
    } else if (height > 93750) {
        return 9;
    } else if (height > 46875) {
        return 10;
    } else if (height > 23437.5) {
        return 11;
    } else if (height > 11718.75) {
        return 12;
    } else if (height > 5859.38) {
        return 13;
    } else if (height > 2929.69) {
        return 14;
    } else if (height > 1464.84) {
        return 15;
    } else if (height > 732.42) {
        return 16;
    } else if (height > 366.21) {
        return 17;
    } else {
        return 18;
    }
}

function change(e, a) {
    // console.log('e:', e, a);
    // removeWms('crop');
    // addwms();
}

// 农作物
watch(
    () => checkList.value,
    (val, oldVal) => {
        if (val.length > oldVal.length) {
            // 挑选出增多的数据
            const newData = val.filter(item => {
                const index = oldVal.findIndex(it => it === item);
                if (index < 0) {
                    return item;
                }
            });
            newData.forEach(item => {
                if (layersDic[item]) {
                    addWms(layersDic[item], item + 'zuowu');
                }
            });
        } else if (val.length < oldVal.length) {
            // 挑选出减少的数据
            const newData = oldVal.filter(item => {
                const index = val.findIndex(it => it === item);
                if (index < 0) {
                    return item;
                }
            });
            newData.forEach(item => {
                if (layersDic[item]) {
                    removeWms([item + 'zuowu']);
                }
            });
        }
    }
);

// 添加wms
function addWms(layers, customName) {
    let map = new Cesium.WebMapServiceImageryProvider({
        url: serverAPI.geoserverUrl + `/shuzisannong/wms?`,
        layers: layers, //图层名
        parameters: {
            service: 'WMS',
            format: 'image/png',
            transparent: true, //是否透明
            // CQL_FILTER: `crop in (${name})`,
        },
    });
    map.customName = customName; //自己定义各种属性
    let dd = viewer.imageryLayers.addImageryProvider(map); //添加图层
    if (customName.indexOf('gbznt') > -1) {
        console.log('dididididi');
        // viewer.imageryLayers.lower(dd);//将图层下移一层
        viewer.imageryLayers.lowerToBottom(dd); //将图层移到最底层
        viewer.imageryLayers.raise(dd); //将图层上移一层
    }
}
// 图层点击事件
let XZDM = '';
function layerClick() {
    var handler = new Cesium.ScreenSpaceEventHandler(viewer.canvas);
    handler.setInputAction(async function (movement) {
        var ray = viewer.camera.getPickRay(movement.position);
        var cartesian = viewer.scene.globe.pick(ray, viewer.scene);
        if (cartesian) {
            let cartographic = Cesium.Cartographic.fromCartesian(cartesian);
            if (cartographic) {
                let xy = new Cesium.Cartesian2();
                let alti = viewer.camera.positionCartographic.height;
                let level = getLevel(alti);
                const layers = viewer.imageryLayers._layers;
                // 获取镇的图层 (点击镇后,再点击种植结构)
                const index = layers.findIndex(
                    item =>
                        item._imageryProvider._layers &&
                        item._imageryProvider._layers === 'shuzisannong:huangdaoqu_town'
                );
                if (index > -1) {
                    const providerPoint = layers[index];
                    // 拿取最后一个图层
                    let provider = providerPoint._imageryProvider;
                    if (
                        provider &&
                        provider.ready &&
                        provider._layers &&
                        providerPoint.show === true
                    ) {
                        xy = provider.tilingScheme.positionToTileXY(cartographic, level, xy);
                        let promise = provider.pickFeatures(
                            xy.x,
                            xy.y,
                            level,
                            cartographic.longitude,
                            cartographic.latitude
                        );
                        if (promise) {
                            promise.then(async data => {
                                if (data.length > 0) {
                                    let newData = data['0'];
                                    if (newData.properties && newData.properties.XZDM) {
                                        if (XZDM !== newData.properties.XZDM) {
                                            //防止
                                            XZDM = newData.properties.XZDM;
                                            value.value = XZDM; //
                                            selectTab(); //
                                            let item = newData.data;
                                            // 定位
                                            viewer.camera.flyTo({
                                                destination: Cesium.Rectangle.fromDegrees(
                                                    item.bbox[0],
                                                    item.bbox[1],
                                                    item.bbox[2],
                                                    item.bbox[3]
                                                ),
                                                duration: 2,
                                            });
                                            // 移除高亮
                                            deleteEntityByName('townLine');
                                            // 高亮边界
                                            addBoundaryHandle(
                                                item.geometry.coordinates,
                                                'townLine',
                                                'red'
                                            );
                                            // 移除以前的
                                            removeWms(['village_CQL']);
                                            // 添加新的
                                            addvillage(
                                                `XZDM=${newData.properties.XZDM}`,
                                                'village_CQL'
                                            );
                                            // 隐藏pop
                                            hiddenOverlayChart();
                                        } else {
                                            //已经点击了镇了,开始监测是否点击作物了
                                            zuowuClick(layers, cartographic, level, xy, movement);
                                        }
                                    } else {
                                        removeWms(['village_CQL']);
                                    }
                                }
                            });
                        }
                    }
                } else {
                    // 直接种植结构
                    zuowuClick(layers, cartographic, level, xy, movement);
                }
            }
        }
    }, Cesium.ScreenSpaceEventType.LEFT_CLICK);
}
// 种植结构
async function zuowuClick(layers, cartographic, level, xy, movement) {
    let newData = [];
    let promise = layers.map(async item => {
        if (item._imageryProvider._layers) {
            // 是种植结构图层
            if (
                Object.values(layersDic).findIndex(it => it === item._imageryProvider._layers) > -1
            ) {
                const providerPoint = item;
                // 拿取最后一个图层
                let provider = providerPoint._imageryProvider;
                if (provider && provider.ready && provider._layers && providerPoint.show === true) {
                    xy = provider.tilingScheme.positionToTileXY(cartographic, level, xy);
                    let promise = provider.pickFeatures(
                        xy.x,
                        xy.y,
                        level,
                        cartographic.longitude,
                        cartographic.latitude
                    );
                    if (promise) {
                        await promise.then(data => {
                            if (data.length > 0) {
                                // 移除高亮
                                deleteEntityByName('landtype');
                                // 高亮边界
                                addBoundaryHandle(
                                    data['0'].data.geometry.coordinates,
                                    'landtype',
                                    'red'
                                );
                                let info = data['0'].properties;
                                const ind = newData.findIndex(ii => ii && ii.crop === info.crop);
                                if (ind < 0) {
                                    newData.push(info);
                                }
                            }
                        });
                    }
                }
            }
        }
    });
    await Promise.all(promise);
    if (newData.length > 0) {
        const coordinate = movement.position; //屏幕坐标 // 转为经纬度,保存,用于监听时转换坐标
        var ellipsoid = viewer.scene.globe.ellipsoid; // 将屏幕坐标转为地理坐标
        var cartesian = viewer.camera.pickEllipsoid(coordinate, ellipsoid);
        if (cartesian) {
            let cartographic = ellipsoid.cartesianToCartographic(cartesian);
            let longitudeString = Cesium.Math.toDegrees(cartographic.longitude).toFixed(6);
            let latitudeString = Cesium.Math.toDegrees(cartographic.latitude).toFixed(6);
            clickInfoMap.value = {
                info: newData,
                // ...newData['0'],
                lon: longitudeString,
                lat: latitudeString,
            };
        }
        showOverlayChart(coordinate); // 添加地图移动监听:使地图移动弹窗跟着移动
        viewer.scene.postRender.addEventListener(infoWindowPostRender);
    } else {
        hiddenOverlayChart(); // 清除监听事件 // viewer.scene.postRender.removeEventListener(infoWindowPostRender);
    }
}

// data数据数组
// name实体名称,方便以后删除
// color实体颜色
function addBoundaryHandle(data, name, color) {
    data.forEach(item => {
        let arr = [];
        item[0].forEach(mem => {
            arr.push(mem[0]);
            arr.push(mem[1]);
        });
        viewer.entities.add({
            name: name,
            polyline: {
                positions: Cesium.Cartesian3.fromDegreesArray(arr),
                width: 6,
                // material: new Cesium.PolylineDashMaterialProperty({//虚线
                material: new Cesium.PolylineGlowMaterialProperty({
                    //光晕
                    glowPower: 0.2,
                    color: color
                        ? Cesium.Color.fromCssColorString(color)
                        : Cesium.Color.fromBytes(250, 128, 114), //#FA8072
                }),
                // followSurface: false, //是否贴着地表
                clampToGround: true, //贴地
            },
        });
    });
}
// 添加村
// CQL_FILTER:筛选的语句
// customName地图服务自定义属性名
function addvillage(CQL_FILTER, customName) {
    let map2 = new Cesium.WebMapServiceImageryProvider({
        url: `http://121.36.229.60:9080/geoserver/shuzisannong/wms`,
        layers: 'shuzisannong:huangdaoqu_village', //图层名
        parameters: {
            service: 'WMS',
            format: 'image/png',
            transparent: true, //是否透明
            // CQL_FILTER: `XZDM=${value.value}`,
            CQL_FILTER: CQL_FILTER,
        },
    });
    map2.customName = customName;
    viewer.imageryLayers.addImageryProvider(map2);
}
// 移除wms
// nameArry :属性名数组(customName)
// isMohu :是否模糊查询
function removeWms(nameArry, isMohu) {
    if (viewer) {
        // 倒叙遍历,customName是自定义的属性
        const layers = viewer.imageryLayers._layers;
        for (let f = layers.length - 1; f >= 0; f--) {
            nameArry.forEach(item => {
                if (
                    layers[f] &&
                    layers[f]._imageryProvider &&
                    layers[f]._imageryProvider.customName
                ) {
                    if (isMohu) {
                        if (layers[f]._imageryProvider.customName.indexOf(item) > -1) {
                            viewer.imageryLayers.remove(layers[f]);
                        }
                    } else {
                        if (layers[f]._imageryProvider.customName === item) {
                            viewer.imageryLayers.remove(layers[f]);
                        }
                    }
                }
            });
        }
    }
}

// 根据实体名字删除实体(模糊删除)
function deleteEntityByName(name) {
    if (viewer) {
        let entitys = viewer.entities._entities._array;
        for (var na = entitys.length - 1; na >= 0; na--) {
            if (entitys[na]._name && entitys[na]._name === name) {
                viewer.entities.remove(entitys[na]);
            }
        }
    }
}

// 地图移动时弹窗跟随
function infoWindowPostRender() {
    // let viewer = viewers.value;
    if (clickInfoMap.value && clickInfoMap.value.lon && clickInfoMap.value.lat) {
        //经纬度转为世界坐标
        const gisPosition = Cesium.Cartesian3.fromDegrees(
            Number(clickInfoMap.value.lon),
            Number(clickInfoMap.value.lat),
            0
        ); //转化为屏幕坐标
        var windowPosition = Cesium.SceneTransforms.wgs84ToWindowCoordinates(
            viewer.scene,
            gisPosition
        );

        if (Cesium.defined(windowPosition)) {
            const pop = document.getElementById('popup1');
            pop.style.top = windowPosition.y - 10 + 'px';
            pop.style.left = windowPosition.x + 10 + 'px';
        }
    }
}
// 隐藏弹窗
function hiddenOverlayChart() {
    // let viewer = viewers.value;
    const pop = document.getElementById('popup1');
    pop.style.display = 'none'; // 清除监听事件
    viewer.scene.postRender.removeEventListener(infoWindowPostRender);
}
//显示弹窗
function showOverlayChart(position) {
    const pop = document.getElementById('popup1');
    pop.style.display = 'block';
    pop.style.position = 'absolute';
    pop.style.top = position.y - 10 + 'px';
    pop.style.left = position.x + 10 + 'px';
    pop.style.zIndex = 99;
}
const formLandRef = ref([]);
// 获取高标准农田
function getFarmland() {
    axios({
        url:
            serverAPI.geoserverUrl +
            '/shuzisannong/ows?service=WFS&version=1.0.0&request=GetFeature&typeName=shuzisannong%3Afarmland&maxFeatures=50&outputFormat=application%2Fjson',
        method: 'get',
    })
        .then(res => {
            console.log('农田:', res);
            formLandRef.value = res.data.features;
        })
        .catch(err => {});
}
//返回
function back() {
    removeWms(['huangdaoqu_town'], true);
}
//接口
const getArea = (item, index) => {
    return getarea({ time: '2023-04-19', subregion: index, parent: item }).then(response => {
        return response.data;
    });
};
//镇
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)];
        ASdivision();
    });
};
//村
const getvillages = () => {
    getvillage().then(res => {
        Township.brr = res.features;
    });
};
//面积
const getaArea = () => {
    let arr = [];
    let a = {};
    getareas().then(res => {
        console.log('res:', res);
        Township.crr = res.features;
        data.title.forEach((item, indexs) => {
            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(1);
                } else {
                    dd[it].push(null);
                }
            });
        });
        ASdivision();
        selectTab();
    });
};

const selectTab = () => {
    areachar();
    if (value.value == '370211') {
        getTownships();
        classData = [302034, 243990, 42344, 34234, 304235];
    } else if (value.value) {
        classData = [102034, 173990, 22344, 14234, 104235];
    }

    console.log(classData);
    areachar();
    let arr = [...Township.arr];
    arr.forEach(item => {
        if (item.properties.XZDM == value.value) {
            getArea(item.properties.XZMC, '2');
            viewer.camera.flyTo({
                destination: Cesium.Rectangle.fromDegrees(
                    item.bbox[0],
                    item.bbox[1],
                    item.bbox[2],
                    item.bbox[3]
                ),
                duration: 2,
            });
        }
        let arr = [...Township.brr];
        let brr = [];
        arr.forEach(item => {
            if (item.properties.XZDM == value.value) {
                brr.push(item.properties.XZQMC);
            }
        });
        data.title = [...Object.values(brr)];
        ASdivision();
    });
    const layers = viewer.imageryLayers._layers;
    for (let f = layers.length - 1; f >= 0; f--) {
        if (layers[f]._imageryProvider.aaa === 'aaa') {
            viewer.imageryLayers.remove(layers[f]);
        }
    }
    let map2 = new Cesium.WebMapServiceImageryProvider({
        url: `http://121.36.229.60:9080/geoserver/shuzisannong/wms`,
        layers: 'shuzisannong:huangdaoqu_village', //图层名
        parameters: {
            service: 'WMS',
            format: 'image/png',
            transparent: true, //是否透明
            CQL_FILTER: `XZDM=${value.value}`,
        },
    });
    map2.aaa = 'aaa';
    viewer.imageryLayers.addImageryProvider(map2);
};

//图表
function areachar() {
    if (areaDiv.value) {
        const areaDivIntance = echarts.init(areaDiv.value);

        let option = {
            // backgroundColor: 'rgba(255, 255, 255, 0.1)',
            textStyle: {
                color: '#c0c3cd',
                fontSize: 14,
            },
            toolbox: {
                show: false,
                feature: {
                    saveAsImage: {
                        backgroundColor: '#031245',
                    },
                    restore: {},
                },
                iconStyle: {
                    borderColor: '#c0c3cd',
                },
            },
            legend: {
                top: 10,
                itemWidth: 8,
                itemHeight: 8,
                icon: 'circle',
                left: 'center',
                padding: 0,
                textStyle: {
                    color: '#c0c3cd',
                    fontSize: 14,
                    padding: [2, 0, 0, 0],
                },
                border: '1px solid rgba(4, 153, 153, 1)',
            },
            color: ['#00D7E9', 'rgba(0, 215, 233, 0.9)'],
            grid: {
                containLabel: true,
                left: 20,
                right: 20,
                bottom: 10,
                top: 40,
            },
            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: {
                nameTextStyle: {
                    color: '#c0c3cd',
                    padding: [0, 0, 0, 0],
                    fontSize: 14,
                },
                axisLabel: {
                    color: '#c0c3cd',
                    fontSize: 14,
                },
                axisTick: {
                    lineStyle: {
                        color: '#668092',
                        width: 1,
                    },
                    show: false,
                },
                splitLine: {
                    show: true,
                    lineStyle: {
                        color: 'rgba(255, 255, 255, 0.7)',
                        type: 'dashed',
                    },
                },
                axisLine: {
                    lineStyle: {
                        color: 'rgba(255, 255, 255, 0.7)',
                        width: 1,
                        // "type": "dashed"
                    },
                    show: false,
                },
                name: '面积(亩)',
            },
            series: [
                {
                    data: classData,
                    type: 'bar',
                    barMaxWidth: 'auto',
                    barWidth: 30,
                    itemStyle: {
                        color: {
                            x: 0,
                            y: 0,
                            x2: 0,
                            y2: 1,
                            type: 'linear',
                            colorStops: [
                                {
                                    offset: 0,
                                    color: ' rgba(0, 208, 255, 0.1)',
                                },

                                {
                                    offset: 1,
                                    color: 'rgba(0, 208, 255, 0.9) ',
                                },
                            ],
                        },
                        borderWidth: 1,
                        borderColor: 'black',
                    },

                    label: {
                        show: true,
                        position: 'top',
                        distance: 10,
                        color: '#fff',
                    },
                },
                {
                    data: [1, 1, 1, 1, 1],
                    type: 'pictorialBar',
                    barMaxWidth: '20',
                    symbol: 'diamond',
                    symbolOffset: [0, '50%'],
                    symbolSize: [30, 15],
                },
                {
                    data: classData,
                    type: 'pictorialBar',
                    barMaxWidth: '20',

                    symbolPosition: 'end',
                    symbol: 'diamond',
                    symbolOffset: [0, '-50%'],
                    symbolSize: [30, 12],
                    zlevel: 2,
                },
            ],
            tooltip: {
                show: true,
                formatter: '面积:{c0}',
            },
        };
        // option && areaDivIntance.setOption(option);
        useEcharts(areaDivIntance, option);
    }
}

function typesof() {
    const typesofDivIntance = echarts.init(typesofDiv.value);
    let isSelected = '';
    let isHovered = '';
    let hoveredIndex = '';
    let option = getPie3D(
        [
            {
                name: '小麦',
                value: 101,
                itemStyle: {
                    opacity: 0.5,
                    color: 'rgba(110, 209, 84, 0.9)',
                },
            },
            {
                // 数据项名称
                name: '花生',
                value: 56,
                itemStyle: {
                    // 透明度
                    opacity: 0.5,
                    // 扇形颜色
                    color: 'rgba(251, 201, 3, 1)',
                },
                label: {
                    show: true,
                },
            },
            {
                // 数据项名称
                name: '大豆',
                value: 56,
                itemStyle: {
                    // 透明度
                    opacity: 0.5,
                    // 扇形颜色
                    color: 'rgba(240, 129, 31, 0.9)',
                },
                label: {
                    show: true,
                },
            },
            {
                // 数据项名称
                name: '地瓜',
                value: 56,
                itemStyle: {
                    // 透明度
                    opacity: 0.5,
                    // 扇形颜色
                    color: 'rgba(27, 85, 222, 1)',
                },
                label: {
                    show: true,
                },
            },
        ],
        0
    );
    // 生成扇形的曲面参数方程
    function getParametricEquation(startRatio, endRatio, isSelected, isHovered, k, h) {
        // 计算
        const midRatio = (startRatio + endRatio) / 2;

        const startRadian = startRatio * Math.PI * 2;
        const endRadian = endRatio * Math.PI * 2;
        const midRadian = midRatio * Math.PI * 2;

        // 如果只有一个扇形,则不实现选中效果。
        if (startRatio === 0 && endRatio === 1) {
            // eslint-disable-next-line no-param-reassign
            isSelected = false;
        }

        // 通过扇形内径/外径的值,换算出辅助参数 k(默认值 1/3)
        // eslint-disable-next-line no-param-reassign
        k = typeof k !== 'undefined' ? k : 1 / 3;

        // 计算选中效果分别在 x 轴、y 轴方向上的位移(未选中,则位移均为 0)
        const offsetX = isSelected ? Math.cos(midRadian) * 0.1 : 0;
        const offsetY = isSelected ? Math.sin(midRadian) * 0.1 : 0;

        // 计算高亮效果的放大比例(未高亮,则比例为 1)
        const hoverRate = isHovered ? 1.05 : 1;

        // 返回曲面参数方程
        return {
            u: {
                min: -Math.PI,
                max: Math.PI * 3,
                step: Math.PI / 32,
            },

            v: {
                min: 0,
                max: Math.PI * 2,
                step: Math.PI / 20,
            },

            x(u, v) {
                if (u < startRadian) {
                    return offsetX + Math.cos(startRadian) * (1 + Math.cos(v) * k) * hoverRate;
                }
                if (u > endRadian) {
                    return offsetX + Math.cos(endRadian) * (1 + Math.cos(v) * k) * hoverRate;
                }
                return offsetX + Math.cos(u) * (1 + Math.cos(v) * k) * hoverRate;
            },

            y(u, v) {
                if (u < startRadian) {
                    return offsetY + Math.sin(startRadian) * (1 + Math.cos(v) * k) * hoverRate;
                }
                if (u > endRadian) {
                    return offsetY + Math.sin(endRadian) * (1 + Math.cos(v) * k) * hoverRate;
                }
                return offsetY + Math.sin(u) * (1 + Math.cos(v) * k) * hoverRate;
            },

            z(u, v) {
                if (u < -Math.PI * 0.5) {
                    return Math.sin(u);
                }
                if (u > Math.PI * 2.5) {
                    return Math.sin(u) * h * 0.1;
                }
                // 当前图形的高度是Z根据h(每个value的值决定的)
                return Math.sin(v) > 0 ? 1 * h * 0.1 : -1;
            },
        };
    }
    // 生成模拟 3D 饼图的配置项
    function getPie3D(pieData, internalDiameterRatio) {
        const series = [];
        // 总和
        let sumValue = 0;
        let startValue = 0;
        let endValue = 0;
        const legendData = [];
        const k =
            typeof internalDiameterRatio !== 'undefined'
                ? (1 - internalDiameterRatio) / (1 + internalDiameterRatio)
                : 1 / 3;

        // 为每一个饼图数据,生成一个 series-surface 配置
        for (let i = 0; i < pieData.length; i += 1) {
            sumValue += pieData[i].value;

            const seriesItem = {
                name: typeof pieData[i].name === 'undefined' ? `series${i}` : pieData[i].name,
                type: 'surface',
                parametric: true,
                wireframe: {
                    show: false,
                },
                pieData: pieData[i],
                pieStatus: {
                    selected: false,
                    hovered: false,
                    k,
                },
            };

            if (typeof pieData[i].itemStyle !== 'undefined') {
                const { itemStyle } = pieData[i];

                // eslint-disable-next-line no-unused-expressions
                typeof pieData[i].itemStyle.color !== 'undefined'
                    ? (itemStyle.color = pieData[i].itemStyle.color)
                    : null;
                // eslint-disable-next-line no-unused-expressions
                typeof pieData[i].itemStyle.opacity !== 'undefined'
                    ? (itemStyle.opacity = pieData[i].itemStyle.opacity)
                    : null;

                seriesItem.itemStyle = itemStyle;
            }
            series.push(seriesItem);
        }
        // 使用上一次遍历时,计算出的数据和 sumValue,调用 getParametricEquation 函数,
        // 向每个 series-surface 传入不同的参数方程 series-surface.parametricEquation,也就是实现每一个扇形。
        console.log(series);
        for (let i = 0; i < series.length; i += 1) {
            endValue = startValue + series[i].pieData.value;

            series[i].pieData.startRatio = startValue / sumValue;
            series[i].pieData.endRatio = endValue / sumValue;
            series[i].parametricEquation = getParametricEquation(
                series[i].pieData.startRatio,
                series[i].pieData.endRatio,
                false,
                false,
                k,
                // 我这里做了一个处理,使除了第一个之外的值都是10
                series[i].pieData.value === series[0].pieData.value ? 35 : 10
            );

            startValue = endValue;

            legendData.push(series[i].name);
        }

        // 准备待返回的配置项,把准备好的 legendData、series 传入。
        const option = {
            // animation: false,
            legend: {
                show: true,
                bottom: 0,
                textStyle: { color: 'rgba(255,255,255,.9)' },
            },
            tooltip: {
                formatter: params => {
                    if (params.seriesName !== 'mouseoutSeries') {
                        return `${params.seriesName}<br/><span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:${params.color};"></span>`;
                    }
                    return '';
                },
            },
            // visualMap: [
            //     {
            //         show: false,
            //         dimension: 2, // [x, y, z, u, v]
            //         min: -1,
            //         seriesIndex: 0,
            //         max: 1,
            //         inRange: {
            //             color: ['#ff0', '#f00'],
            //         },
            //     },
            //     {
            //         show: false,
            //         dimension: 4, // [x, y, z, u, v]
            //         min: 0,
            //         seriesIndex: 1,
            //         max: Math.PI * 2,
            //         inRange: {
            //             color: ['#0bf', '#0f0', '#0bf'],
            //         },
            //     },
            //     {
            //         show: false,
            //         dimension: 3, // [x, y, z, u, v]
            //         min: 0,
            //         seriesIndex: 2,
            //         max: Math.PI * 2,
            //         inRange: {
            //             color: [
            //                 '#a50026',
            //                 '#d73027',
            //                 '#f46d43',
            //                 '#fdae61',
            //                 '#fee090',
            //                 '#ffffbf',
            //                 '#e0f3f8',
            //                 '#abd9e9',
            //                 '#74add1',
            //                 '#4575b4',
            //                 '#313695',
            //             ],
            //         },
            //     },
            // ],
            xAxis3D: {
                min: -1,
                max: 1,
            },
            yAxis3D: {
                min: -1,
                max: 1,
            },
            zAxis3D: {
                min: -1,
                max: 1,
            },
            grid3D: {
                show: false,
                boxHeight: 10,
                top: '-10%',
                viewControl: {
                    // 3d效果可以放大、旋转等,请自己去查看官方配置
                    alpha: 35,
                    beta: 30,
                    rotateSensitivity: 1,
                    zoomSensitivity: 0,
                    panSensitivity: 0,
                    autoRotate: true,
                    distance: 300,
                },
                // 后处理特效可以为画面添加高光、景深、环境光遮蔽(SSAO)、调色等效果。可以让整个画面更富有质感。
                postEffect: {
                    // 配置这项会出现锯齿,请自己去查看官方配置有办法解决
                    enable: false,
                    bloom: {
                        enable: true,
                        bloomIntensity: 0.1,
                    },
                    SSAO: {
                        enable: true,
                        quality: 'medium',
                        radius: 2,
                    },
                    // temporalSuperSampling: {
                    //   enable: true,
                    // },
                },
            },
            series,
        };
        return option;
    }
    //  修正取消高亮失败的 bug
    // 监听 mouseover,近似实现高亮(放大)效果
    typesofDivIntance.on('mouseover', function (params) {
        // 准备重新渲染扇形所需的参数
        let isSelected;
        let isHovered;
        let startRatio;
        let endRatio;
        let k;
        let i;

        // 如果触发 mouseover 的扇形当前已高亮,则不做操作
        if (hoveredIndex === params.seriesIndex) {
            return;

            // 否则进行高亮及必要的取消高亮操作
        } else {
            // 如果当前有高亮的扇形,取消其高亮状态(对 option 更新)
            if (hoveredIndex !== '') {
                // 从 option.series 中读取重新渲染扇形所需的参数,将是否高亮设置为 false。
                isSelected = option.series[hoveredIndex].pieStatus.selected;
                isHovered = false;
                startRatio = option.series[hoveredIndex].pieData.startRatio;
                endRatio = option.series[hoveredIndex].pieData.endRatio;
                k = option.series[hoveredIndex].pieStatus.k;
                i =
                    option.series[hoveredIndex].pieData.value === option.series[0].pieData.value
                        ? 35
                        : 10;
                // 对当前点击的扇形,执行取消高亮操作(对 option 更新)
                option.series[hoveredIndex].parametricEquation = getParametricEquation(
                    startRatio,
                    endRatio,
                    isSelected,
                    isHovered,
                    k,
                    i
                );
                option.series[hoveredIndex].pieStatus.hovered = isHovered;

                // 将此前记录的上次选中的扇形对应的系列号 seriesIndex 清空
                hoveredIndex = '';
            }

            // 如果触发 mouseover 的扇形不是透明圆环,将其高亮(对 option 更新)
            if (params.seriesName !== 'mouseoutSeries') {
                // 从 option.series 中读取重新渲染扇形所需的参数,将是否高亮设置为 true。
                isSelected = option.series[params.seriesIndex].pieStatus.selected;
                isHovered = true;
                startRatio = option.series[params.seriesIndex].pieData.startRatio;
                endRatio = option.series[params.seriesIndex].pieData.endRatio;
                k = option.series[params.seriesIndex].pieStatus.k;

                // 对当前点击的扇形,执行高亮操作(对 option 更新)
                option.series[params.seriesIndex].parametricEquation = getParametricEquation(
                    startRatio,
                    endRatio,
                    isSelected,
                    isHovered,
                    k,
                    option.series[params.seriesIndex].pieData.value + 5
                );
                option.series[params.seriesIndex].pieStatus.hovered = isHovered;

                // 记录上次高亮的扇形对应的系列号 seriesIndex
                hoveredIndex = params.seriesIndex;
            }

            // 使用更新后的 option,渲染图表
            typesofDivIntance.setOption(option);
        }
    });

    // 修正取消高亮失败的 bug
    typesofDivIntance.on('globalout', function () {
        if (hoveredIndex !== '') {
            // 从 option.series 中读取重新渲染扇形所需的参数,将是否高亮设置为 true。
            isSelected = option.series[hoveredIndex].pieStatus.selected;
            isHovered = false;
            let k = option.series[hoveredIndex].pieStatus.k;
            startRatio = option.series[hoveredIndex].pieData.startRatio;
            endRatio = option.series[hoveredIndex].pieData.endRatio;
            // 对当前点击的扇形,执行取消高亮操作(对 option 更新)
            i =
                option.series[hoveredIndex].pieData.value === option.series[0].pieData.value
                    ? 35
                    : 10;
            option.series[hoveredIndex].parametricEquation = getParametricEquation(
                startRatio,
                endRatio,
                isSelected,
                isHovered,
                k,
                i
            );
            option.series[hoveredIndex].pieStatus.hovered = isHovered;

            // 将此前记录的上次选中的扇形对应的系列号 seriesIndex 清空
            hoveredIndex = '';
        }

        // 使用更新后的 option,渲染图表
        typesofDivIntance.setOption(option);
    });

    // option && typesofDivIntance.setOption(option);
    useEcharts(typesofDivIntance, option);
}
// 高标准农田echarts
function farmland() {
    const farmlandDivIntance = echarts.init(farmlandDiv.value);
    let option = {
        // backgroundColor: '#333333',
        // tooltip: {},
        grid: {
            left: '3%',
            right: '4%',
            bottom: '3%',
            top: '10%',
            containLabel: true,
        },
        legend: {
            show: true,
            top: '10',
            left: 'center',
            textStyle: { color: 'rgba(255,255,255,.9)' },
            itemWidth: 20,
            itemHeight: 12.5,
            icon: 'stack',
        },

        xAxis: {
            type: 'value',
            max: 500,
            show: false,
            // 不显示轴线
            axisLine: {
                show: false,
            },
            // 不显示刻度线
            axisTick: {
                show: false,
            },
            splitLine: {
                // 网格线为虚线
                show: false,
            },
            // axisLabel:{
            //     formatter:'{value}%'
            // }
        },
        yAxis: {
            type: 'category',
            inverse: true,
            splitLine: {
                show: false,
            },
            axisTick: {
                show: false,
            },
            axisLine: {
                show: false,
            },
            axisLabel: {
                interval: 0,
                color: 'rgba(255, 255, 255, 1)',
                fontSize: 14,
            },
            data: ['片区1', '片区2', '片区3', '片区4', '片区5', '片区6', '片区7'],
        },
        series: [
            {
                name: '小麦',
                type: 'bar',
                barWidth: 12,
                stack: 'stack',
                data: [200, 300, 0, 200, 0, 100, 300],
                itemStyle: {
                    normal: {
                        barBorderRadius: 0,
                        color: new echarts.graphic.LinearGradient(0, 0, 0.9, 0, [
                            {
                                offset: 1,
                                color: 'rgba(33, 187, 251, 0.9)',
                            },
                            {
                                offset: 0,
                                color: 'rgba(33, 187, 251, 0.05)',
                            },
                        ]),
                    },
                },
            },
            {
                name: '大豆',
                type: 'bar',
                barWidth: 12,
                stack: 'stack',
                data: [200, 300, 200, 100, 0, 100, 300],
                itemStyle: {
                    normal: {
                        barBorderRadius: 0,
                        color: new echarts.graphic.LinearGradient(0, 0, 0.9, 0, [
                            {
                                offset: 1,
                                color: 'rgba(143, 186, 243, 0.9)',
                            },
                            {
                                offset: 0,
                                color: 'rgba(143, 186, 243, 0.05)',
                            },
                        ]),
                    },
                },
            },
            {
                name: '地瓜',
                type: 'bar',
                barWidth: 12,
                stack: 'stack',
                data: [200, 0, 200, 100, 300, 200, 0],
                itemStyle: {
                    normal: {
                        barBorderRadius: 0,
                        color: new echarts.graphic.LinearGradient(0, 0, 0.9, 0, [
                            {
                                offset: 1,
                                color: 'rgba(255, 225, 104, 1)',
                            },
                            {
                                offset: 0,
                                color: 'rgba(255, 225, 104, 0.05)',
                            },
                        ]),
                    },
                },
            },
            {
                name: '花生',
                type: 'bar',
                barWidth: 12,
                stack: 'stack',
                data: [0, 0, 200, 100, 300, 200, 0],
                itemStyle: {
                    normal: {
                        barBorderRadius: 0,
                        color: new echarts.graphic.LinearGradient(0, 0, 0.9, 0, [
                            {
                                offset: 1,
                                color: 'rgba(4, 247, 227, 0.9)',
                            },
                            {
                                offset: 0,
                                color: 'rgba(4, 247, 227, 0.25)',
                            },
                        ]),
                    },
                },
            },
        ],
    };

    // areaDivIntance.off('click') //图表渲染前销毁点击事件,防止点击图标多次触发
    farmlandDivIntance.on('click', param => ChartClick(param));
    useEcharts(farmlandDivIntance, option);
}
// 图表点击事件
function ChartClick(item) {
    console.log('item:', item);
    // 移除作物
    removeWms(['huangdaoqu_town'], true);
    let layername = 'shuzisannong:farmland';

    // 判断是否存在避免重复添加
    let cz = false;
    const layers = viewer.imageryLayers._layers;
    for (let f = layers.length - 1; f >= 0; f--) {
        if (
            layers[f] &&
            layers[f]._imageryProvider.customName &&
            layers[f]._imageryProvider.customName === layername + 'gbznt'
        ) {
            cz = true;
        }
    }
    if (!cz) {
        // 添加高标准农田服务
        addWms(layername, layername + 'gbznt');
    }
    // 定位到地块
    let features = formLandRef.value;
    features.forEach(it => {
        console.log('it.properties.name:', it.properties.name);
        console.log('item.name:', item.name);
        if (it.properties.name === item.name) {
            console.log('dingwei');
            viewer.camera.flyTo({
                destination: Cesium.Rectangle.fromDegrees(
                    it.bbox[0],
                    it.bbox[1],
                    it.bbox[2],
                    it.bbox[3]
                ),
                duration: 2,
            });
        }
    });
    flag.value = true;
}

function ASdivision() {
    const ASdivisionDivIntance = echarts.init(ASdivisionDiv.value);
    var option = {
        // 设置图表的位置
        grid: {
            bottom: '8%',
            left: '10%',
            right: '6%',
            top: '6%',
            containLabel: true,
        },
        dataZoom: [
            {
                type: 'slider',
                show: false,
                zoomLock: true, //禁止拉伸
                width: 8,
                yAxisIndex: [0],
                bottom: 30,
                top: 20,
                right: 10,
                startValue: 0,
                endValue: 4,
                handleIcon:
                    'M-292,322.2c-3.2,0-6.4-0.6-9.3-1.9c-2.9-1.2-5.4-2.9-7.6-5.1s-3.9-4.8-5.1-7.6c-1.3-3-1.9-6.1-1.9-9.3c0-3.2,0.6-6.4,1.9-9.3c1.2-2.9,2.9-5.4,5.1-7.6s4.8-3.9,7.6-5.1c3-1.3,6.1-1.9,9.3-1.9c3.2,0,6.4,0.6,9.3,1.9c2.9,1.2,5.4,2.9,7.6,5.1s3.9,4.8,5.1,7.6c1.3,3,1.9,6.1,1.9,9.3c0,3.2-0.6,6.4-1.9,9.3c-1.2,2.9-2.9,5.4-5.1,7.6s-4.8,3.9-7.6,5.1C-285.6,321.5-288.8,322.2-292,322.2z',
                handleSize: '100%',
                handleStyle: {
                    color: '#DBDBDB',
                    height: '100%',
                },
                backgroundColor: 'transparent',
                fillerColor: '#DBDBDB',
                textStyle: {
                    color: 'transparent',
                },
                dataBackground: {
                    lineStyle: {
                        color: 'transparent',
                    },
                    areaStyle: {
                        color: 'transparent',
                    },
                },
                borderColor: 'transparent',
            },
            {
                type: 'inside',
                id: 'insideY',
                yAxisIndex: 0,
                start: 0,
                end: 50,
                zoomOnMouseWheel: false,
                moveOnMouseMove: true,
                moveOnMouseWheel: 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: 12, // 文字的字体大小
                    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: '玉米',
                    textStyle: {
                        fontSize: 12,
                        fontWeight: 'bolder',
                        color: 'rgba(255,255,255,1)',
                    },
                },
                // 图形样式
                itemStyle: {
                    barBorderRadius: [0, 0, 0, 0],
                    barBorderRadius: [0, 0, 0, 0], //
                    borderWidth: 1, // 设置边框宽度
                    borderColor: 'rgba(4, 247, 227, 0.8)', // 设置边框颜色
                    color: {
                        colorStops: [
                            {
                                offset: 0,
                                color: 'rgba(4, 247, 227, 0.9)', // 0% 处的颜色
                            },
                            {
                                offset: 1,
                                color: 'rgba(4, 247, 227, 0.25)', // 100% 处的颜色
                            },
                        ],
                    },
                },
                data: dd.玉米, // 系列中的数据内容数组
            },
            {
                type: 'bar', // 系列类型
                name: '大豆', // 系列名称, 用于tooltip的显示, legend 的图例筛选
                // 数据堆叠,同个类目轴上系列配置相同的stack值后,后一个系列的值会在前一个系列的值上相加
                stack: '总量',
                barMaxWidth: 30, // 柱条的最大宽度,不设时自适应
                // 图形上的文本标签
                label: {
                    show: true,
                    position: 'inside',
                    formatter: '大豆',
                    textStyle: {
                        fontSize: 12,
                        fontWeight: 'bolder',
                        color: 'rgba(255,255,255,1)',
                    },
                },
                // 图形样式
                itemStyle: {
                    barBorderRadius: [0, 0, 0, 0], //
                    borderWidth: 1, // 设置边框宽度
                    borderColor: 'rgba(143, 186, 243, 0.8)', // 设置边框颜色
                    color: {
                        colorStops: [
                            {
                                offset: 0,
                                color: 'rgba(143, 186, 243, 0.9)', // 0% 处的颜色
                            },
                            {
                                offset: 1,
                                color: 'rgba(143, 186, 243, 0.3)', // 100% 处的颜色
                            },
                        ],
                    },
                },
                data: dd.大豆, // 系列中的数据内容数组
            },
            {
                type: 'bar', // 系列类型
                name: '花生', // 系列名称, 用于tooltip的显示, legend 的图例筛选
                // 数据堆叠,同个类目轴上系列配置相同的stack值后,后一个系列的值会在前一个系列的值上相加
                stack: '总量',
                barMaxWidth: 30, // 柱条的最大宽度,不设时自适应
                // 图形上的文本标签
                label: {
                    show: true,
                    position: 'inside',
                    formatter: '花生',
                    textStyle: {
                        fontSize: 12,
                        fontWeight: 'bolder',
                        color: 'rgba(255,255,255,1)',
                    },
                },
                // 图形样式
                itemStyle: {
                    barBorderRadius: [0, 0, 0, 0],
                    barBorderRadius: [0, 0, 0, 0], //
                    borderWidth: 1, // 设置边框宽度
                    borderColor: 'rgba(255, 225, 104, 0.8)', // 设置边框颜色
                    color: {
                        colorStops: [
                            {
                                offset: 0,
                                color: 'rgba(4, 247, 227, 0.9)', // 0% 处的颜色
                            },
                            {
                                offset: 1,
                                color: 'rgba(4, 247, 227, 0.25)', // 100% 处的颜色
                            },
                        ],
                    },
                },
                data: dd.花生, // 系列中的数据内容数组
            },
            {
                type: 'bar', // 系列类型
                name: '小麦', // 系列名称, 用于tooltip的显示, legend 的图例筛选
                // 数据堆叠,同个类目轴上系列配置相同的stack值后,后一个系列的值会在前一个系列的值上相加
                stack: '总量',
                barMaxWidth: 30, // 柱条的最大宽度,不设时自适应
                // 图形上的文本标签
                label: {
                    show: true,
                    position: 'inside',
                    formatter: '小麦',
                    textStyle: {
                        fontSize: 12,
                        fontWeight: 'bolder',
                        color: 'rgba(255,255,255,1)',
                    },
                },
                // 图形样式
                itemStyle: {
                    barBorderRadius: [0, 0, 0, 0],
                    barBorderRadius: [0, 0, 0, 0], //
                    borderWidth: 1, // 设置边框宽度
                    borderColor: 'rgba(33, 187, 251, 0.8)', // 设置边框颜色
                    color: {
                        colorStops: [
                            {
                                offset: 0,
                                color: 'rgba(33, 187, 251, 0.9)', // 0% 处的颜色
                            },
                            {
                                offset: 1,
                                color: 'rgba(33, 187, 251, 0.25)', // 100% 处的颜色
                            },
                        ],
                    },
                },
                data: dd.小麦, // 系列中的数据内容数组
            },
            {
                type: 'bar', // 系列类型
                name: '蓝莓', // 系列名称, 用于tooltip的显示, legend 的图例筛选
                // 数据堆叠,同个类目轴上系列配置相同的stack值后,后一个系列的值会在前一个系列的值上相加
                stack: '总量',
                barMaxWidth: 30, // 柱条的最大宽度,不设时自适应
                // 图形上的文本标签
                label: {
                    show: true,
                    position: 'inside',
                    formatter: '蓝莓',
                    textStyle: {
                        fontSize: 12,
                        fontWeight: 'bolder',
                        color: 'rgba(255,255,255,1)',
                    },
                },
                // 图形样式
                itemStyle: {
                    barBorderRadius: [0, 0, 0, 0],
                    barBorderRadius: [0, 0, 0, 0], //
                    borderWidth: 1, // 设置边框宽度
                    borderColor: 'rgba(14, 223, 255, 0.8)', // 设置边框颜色
                    color: {
                        colorStops: [
                            {
                                offset: 0,
                                color: 'rgba(14, 223, 255, 0.9)', // 0% 处的颜色
                            },
                            {
                                offset: 1,
                                color: 'rgba(14, 223, 255, 0.25)', // 100% 处的颜色
                            },
                        ],
                    },
                },
                data: dd.蓝莓, // 系列中的数据内容数组
            },
        ],
    };
    ASdivisionDivIntance.on('click', param => ChartClickRB(param));
    // option && ASdivisionDivIntance.setOption(option, true);
    useEcharts(ASdivisionDivIntance, option);
}
// 右下角图表点击事件
function ChartClickRB(param) {
    console.log('右下点击', param);
}
</script>

<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;
        cursor: pointer;
        justify-content: space-between;

        span {
            width: 80%;
            white-space: nowrap;
            text-overflow: ellipsis;
            overflow: hidden;
        }

        p {
            width: 79px;
            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;
        }
    }
}

.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);

    .leftTop {
        // height: 35%;
        max-width: calc(100% - 20px);
        display: flex;
        flex-direction: column;

        .areaDiv {
            width: 100%;
            height: 327px;
            opacity: 1;
            display: flex;
            padding: 1px;
            justify-content: center;
        }
    }

    .leftbottom {
        height: 35%;
        display: flex;
        flex-direction: column;
        max-width: calc(100% - 7px);
        align-items: center;

        .typesofDiv {
            width: 375px;
            height: 397px;
            background: url('@/assets/images/bj1_00000_iSpt.png');
            background-repeat: no-repeat;
            background-size: 85% 85%;
            background-position: center;
        }
    }
}

.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);

    .rightTop {
        width: 100%;
        height: 40%;
        opacity: 1;
        display: flex;
        flex-direction: column;
        justify-content: flex-start;
        align-items: center;

        .farmlandDiv {
            width: 100%;
            height: 340px;
            opacity: 1;
        }

        .ProgressBar {
            width: 100%;
            height: 9px;
            opacity: 1;
        }
    }

    .rightbottom {
        width: 100%;
        height: 455px;
        opacity: 1;
        display: flex;
        flex-direction: column;
        justify-content: flex-start;
        align-items: center;
        padding-top: 13px;

        .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;
                border-radius: 0;
                box-shadow: none;
            }

            :deep(.el-input__inner) {
                color: rgba(255, 255, 255, 0.7);
            }
        }

        .ASdivision {
            width: 415px;
            height: 368px;
            opacity: 1;
        }

        :deep(.el-select__popper) {
            border: none !important;
            background: transparent !important;
        }

        :deep(.el-popper) {
            border: none !important;
            background: transparent !important;
        }
    }
}

.legend {
    position: absolute;
    right: 25%;
    bottom: 7%;
    width: 129px;
    border: 1px solid rgba(4, 153, 153, 1);

    // height: 50px;
    :deep(.el-collapse-item__header) {
        background: rgba(2, 31, 26, 0.6);
        color: rgba(255, 255, 255, 1);
        text-align: center;
        padding: 0 30px;
        font-size: 14px;
    }

    --el-collapse-content-bg-color {
        background: rgba(2, 31, 26, 0.6);
    }

    :deep(.el-collapse-item__content) {
        background: rgba(2, 31, 26, 0.6);
        padding: 0 10px;
        padding-bottom: 10px;
    }

    --el-collapse-border-color: none;
    --el-collapse-content-bg-color: none;

    // opacity: 1;
    // border-radius: 4px;
    // background: rgba(2, 31, 26, 0.6);
    // display: flex;
    // flex-direction: column;
    // justify-content: flex-start;
    // align-items: center;
    // padding: 10px 10px 10px 10px;
    p {
        margin: 10px;
        font-size: 14px;
        font-weight: 400;
        letter-spacing: 0px;
        line-height: 0px;
        color: rgba(255, 255, 255, 1);
        text-align: center;
    }

    .mt-4 {
        .el-checkbox {
            height: 30px;
            width: 100%;
            margin-bottom: 2px;
            padding-left: 10px;
            font-size: 14px;
            font-weight: 400;
            letter-spacing: 0px;
            line-height: 0px;
            color: rgba(255, 255, 255, 1);
            text-align: left;
        }
    }

    :deep(.el-checkbox__label) {
        color: rgba(255, 255, 255, 1);
    }
}

.bottom_center {
    position: absolute;
    // left: calc(400px + 20px + 8vw);
    left: 0;
    right: 0;
    margin: auto;
    width: calc(100% - (400px * 2) - (10vw * 2));
    min-width: 380px;
    bottom: 5%;
    height: 75px;
    opacity: 1;
    border-radius: 5px;
    background: rgba(2, 31, 26, 0.6);
    border: 1px solid rgba(4, 153, 153, 1);
}

.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;
}

#popup1 {
    border-radius: 5px;
    background: rgba(2, 31, 26, 0.6);
    display: none;
    // justify-content: flex-start;
    // align-items: flex-end;
    padding: 30px 8px 20px 8px;
    border: 2px solid rgba(4, 153, 153, 1);

    .rowWra {
        display: flex;
        margin-bottom: 10px;

        & > span:nth-child(1) {
            font-weight: 400;
            letter-spacing: 0px;
            color: rgba(255, 255, 255, 1);
            // margin-top: 20px;
            line-height: 24px;
            width: 3em;
            // font-size: 14px;
            margin-right: 10px;
        }

        & > span:nth-child(2) {
            color: rgba(255, 255, 255, 1);
            width: 129px;
            height: 24px;
            opacity: 1;
            border-radius: 2px;
            background: rgba(217, 231, 255, 0.2);
            display: flex;
            justify-content: center;
            align-items: center;
            padding: 2px 10px 2px 10px;
        }
    }

    .cancel {
        position: absolute;
        right: 10px;
        top: 5px;
        color: rgba(255, 255, 255, 1);
        cursor: pointer;
    }
}
.back_button {
    position: absolute;
    right: 30%;
    top: 20px;
}
</style>

<style lang="scss">
.select_city {
    background: rgba(2, 31, 26, 0.85);
    box-shadow: inset 0px 0px 15px 6px rgba(41, 255, 255, 0.5);

    .el-select-dropdown__item.hover {
        background: rgba(2, 31, 26, 0.95);
        box-shadow: inset 0px 0px 15px 6px rgba(41, 255, 255, 0.7);
    }

    .el-select-dropdown__item {
        color: #fff;
    }
}

.el-select__popper {
    border: none !important;
    background: transparent !important;
}

.el-popper {
    border: none !important;
    background: transparent !important;
}

.el-popper__arrow::before {
    background: rgba(41, 255, 255, 0.7) !important;
}
</style>