Newer
Older
urbanLifeline_YanAn / src / views / oneMap / OverallOverview / RightBox.vue
@jimengfei jimengfei on 22 Oct 20 KB updata
<!-- 总体概览右侧面板 -->
<template>
  <!-- 风险评估 -->
  <div class="RiskAssessment">
    <div class="ListBoxHeader">
      <div class="ListBoxHeader_font">风险评估</div>
    </div>
    <div class="RiskProportion">
      <div class="TopProportion">
        <div class="riskMc">
          <div class="icon"></div>
          <div class="text">风险占比</div>
        </div>
        <div class="riskZs">
          <div class="eachDescribe">
            <div class="icon bgcblue"></div>
            <div class="text">总数</div>
          </div>
          <div class="eachDescribe">
            <div class="icon bgcYellow"></div>
            <div class="text">风险数量</div>
          </div>
        </div>
      </div>
      <div class="ContentNum">
        <div class="dfFlxa" v-for="(item, index) in riskData">
          <div class="middleextA flex">
            <div>
              <img :src="item.Imgurl" alt="" />
            </div>
            <div style="margin-left: 4px; cursor: pointer" @click="FxClick(item.name)">
              {{ item.name }}
            </div>
          </div>
          <div class="middleextB flex">
            <div class="BJ_CenBox1" :style="getWidth(item, 1)"></div>
            <div
              style="
                font-family: Source Han Sans CN;
                font-weight: bold;
                font-size: 13px;
                color: rgba(248, 116, 75, 1);
                text-align: right;
                line-height: 12px;
                margin-left: 5px;
              "
            >
              {{ item.sl }}
            </div>
          </div>
          <div class="middleextC flex">
            <div
              style="
                font-family: Source Han Sans CN;
                font-weight: bold;
                font-size: 16px;
                color: #12f9ff;
                width: 65%;
                text-align: right;
              "
            >
              {{ item.num }}
            </div>

            <div style="font-family: Source Han Sans CN; font-weight: bold; font-size: 13px; color: #12f9ff">
              {{ item.dw }}
            </div>
          </div>
        </div>
      </div>
    </div>

    <div class="DrainageRisk">
      <div class="TopProportion">
        <div class="riskMc">
          <div class="icon"></div>
          <div class="text">{{ FxClickName }}风险评估</div>
        </div>
      </div>

      <tslyqk_constituent_3d />
    </div>
  </div>
  <!-- 预警处置 -->
  <div class="WarningSisposal">
    <div class="ListBoxHeader">
      <div class="ListBoxHeader_font">预警处置</div>
    </div>
    <div class="WarningSj">
      <div class="TopProportion">
        <div class="WarningSl">
          <div class="eachDescribe">
            <div class="icon bgcls"></div>
            <div class="text">预警数量</div>
          </div>
          <div class="eachDescribe">
            <div class="icon bgcYellow"></div>
            <div class="text">处置数量</div>
          </div>
        </div>
        <div class="WarningNy">
          <div class="head-right" style="">
            <div
              class="head-item"
              v-for="(item, index) in yearList"
              :key="item"
              :class="activedname == item.name ? 'activedright' : ''"
              @click="yearclick(item, index)"
            >
              {{ item.name }}
            </div>
          </div>
        </div>
      </div>
      <div class="WarningList">
        <div class="Warningpart flex flex-justcontent-spacebetween">
          <div class="part" v-for="(item, index) in tableData" :key="index">
            <div class="parttop">
              <div class="upper">
                <div class="Major">
                  <img :src="item.Imgurl" class="upImg" />
                </div>
                <div class="lower">{{ item.name }}</div>
              </div>
              <div class="below">
                <div class="handIn">{{ item.num }}</div>
                <div
                  class="oflower"
                  :style="{
                    color: item.gm == '较多' ? '#FF4D5DFF' : item.gm == '正常' ? '#2BE7ABFF' : '#F8E270FF',
                  }"
                >
                  {{ item.gm }}
                </div>
              </div>
            </div>
          </div>
        </div>
      </div>
    </div>
    <div class="WarningEcharts">
      <AssessmentjsEcharts :data="chartData2" :refresh="chartData2.refresh"></AssessmentjsEcharts>
    </div>
  </div>
</template>

<script setup>
import tslyqk_constituent_3d from '@/views/oneMap/Echarts/tslyqk_constituent_3d.vue'; //3d图例
import AssessmentjsEcharts from '@/views/oneMap/Echarts/AssessmentjsEcharts.vue';

import { ref, reactive, toRefs, onMounted, onBeforeUnmount } from 'vue';
const AllData = reactive({});
import yjsj from '@/assets/newImgs/yjsj.png'; //预警数据
import czsj from '@/assets/newImgs/czsj.png'; //处置数据
import czl from '@/assets/newImgs/czl.png'; //处置率

import ranqi_icon from '@/assets/newImgs/ranqi_icon.png'; //燃气
import qiaoliang from '@/assets/newImgs/qiaoliang.png'; //桥梁
import sd_icon from '@/assets/newImgs/sd_icon.png'; //隧道
import ps_icon from '@/assets/newImgs/ps_icon.png'; //隧道
import fxzb from '@/assets/newImgs/fxzb.png'; //风险占比
import bus from '@/bus';
import mapBoxVectorLayer from '@/utils/GISdocument/mapboxVectorLayer.js';
const yearList = ref([
  { name: '月', value: 1 },
  { name: '年', value: 2 },
]);
const chartData2 = ref({
  xAxis: ['12/1', '12/2', '12/3', '12/4', '12/5', '12/6'],
  refresh: 1,
});
const riskData = ref([
  { name: '燃气', num: 4549.53, sl: 1922.11, Imgurl: ranqi_icon, dw: '公里' },
  { name: '排水', num: 435.7, sl: 118, Imgurl: ps_icon, dw: '公里' },
  { name: '桥梁', num: 84, sl: 0, Imgurl: qiaoliang, dw: '座' },
  { name: '隧道', num: 1, sl: 0, Imgurl: sd_icon, dw: '座' },
]);
const tableData = ref([
  { name: '预警数量', num: '60', gm: '较多', Imgurl: yjsj },
  { name: '处置数量', num: '60', gm: '正常', Imgurl: czsj },
  { name: '处置率', num: '75%', gm: '未完成', Imgurl: czl },
]);

const activedname = ref('月');
function yearclick(val) {
  activedname.value = val.name;
}
// 动态计算盒子的宽度
const getWidth = (item, Num) => {
  let widthNum = 0;
  if (Num == 1) {
    widthNum = (item.sl / (item.num + item.sl)) * 100;
  }
  return `width:${widthNum}%`;
};

// 风险评估点击事件
const FxClickName = ref('燃气');
const obj = ref([
  {
    name: '低风险  70%  1345.5',
    value: 1345.5,
    itemStyle: {
      color: '#2BE7ABFF',
    },
  },
  {
    name: '一般风险 20%  384.5',
    value: 384.5,
    itemStyle: {
      color: '#18A7F2FF',
    },
  },
  {
    name: '较大风险 5%  91.11',
    value: 91.11,
    itemStyle: {
      color: '#F8E270FF',
    },
  },
  {
    name: '重大风险 5%  91',
    value: 91,
    itemStyle: {
      color: '#FF5D6CFF',
    },
  },
]);

function FxClick(val) {
  FxClickName.value = val;
  if (FxClickName.value == '燃气') {
    let obj = [
      {
        name: '低风险  70%  1345.5',
        value: 1345.5,
        itemStyle: {
          color: '#2BE7ABFF',
        },
      },
      {
        name: '一般风险 20%  384.5',
        value: 384.5,
        itemStyle: {
          color: '#18A7F2FF',
        },
      },
      {
        name: '较大风险 5%  91.11',
        value: 91.11,
        itemStyle: {
          color: '#F8E270FF',
        },
      },
      {
        name: '重大风险 5%  91',
        value: 91,
        itemStyle: {
          color: '#FF5D6CFF',
        },
      },
    ];
    bus.emit('FxVisible', obj);
    // bus.emit('clearAllLayer');
    // bus.emit('SetLayerShow', ['燃气视角']);
  } else if (FxClickName.value == '排水') {
    let obj = [
      {
        name: '低风险  65%  76.7',
        value: 76.7,
        itemStyle: {
          color: '#2BE7ABFF',
        },
      },
      {
        name: '一般风险 20%  23.6',
        value: 23.6,
        itemStyle: {
          color: '#18A7F2FF',
        },
      },
      {
        name: '较大风险 10%  11.8',
        value: 11.8,
        itemStyle: {
          color: '#F8E270FF',
        },
      },
      {
        name: '重大风险 5%  5.9',
        value: 5.9,
        itemStyle: {
          color: '#FF5D6CFF',
        },
      },
    ];
    bus.emit('FxVisible', obj);

    // bus.emit('clearAllLayer');
    // bus.emit('SetLayerShow', ['雨水管网', '综合视角']);
  } else if (FxClickName.value == '桥梁') {
    let obj = [
      {
        name: '低风险  0%  0',
        value: 0,
        itemStyle: {
          color: '#2BE7ABFF',
        },
      },
      {
        name: '一般风险  0%  0',
        value: 0,
        itemStyle: {
          color: '#18A7F2FF',
        },
      },
      {
        name: '较大风险  0%  0',
        value: 0,
        itemStyle: {
          color: '#F8E270FF',
        },
      },
      {
        name: '重大风险  0%  0',
        value: 0,
        itemStyle: {
          color: '#FF5D6CFF',
        },
      },
    ];
    bus.emit('FxVisible', obj);
    let heatMapList = [
      { lonlat: [109.483918489923, 36.61249884561792], value: 2 },
      { lonlat: [109.49124949683474, 36.60775434074279], value: 2 },
      { lonlat: [109.50572853744899, 36.604187093623594], value: 2 },
      { lonlat: [109.5132346699733, 36.608741935164794], value: 2 },
      { lonlat: [109.51904613562726, 36.611042774763824], value: 2 },
      { lonlat: [109.53198346589791, 36.61636440529855], value: 2 },
      { lonlat: [109.54373268160329, 36.62722667094952], value: 2 },
      { lonlat: [109.55451083074375, 36.63431209655593], value: 2 },
      { lonlat: [109.57940016110899, 36.64686611882419], value: 2 },
      { lonlat: [109.6012150494243, 36.65907698436654], value: 2 },
      { lonlat: [109.61124926974423, 36.66415805243906], value: 2 },
      { lonlat: [109.61784004029477, 36.67516787032632], value: 2 },
      { lonlat: [109.62919460452721, 36.67788106032265], value: 2 },
      { lonlat: [109.63196929767449, 36.67928099390055], value: 2 },
      { lonlat: [109.46480514943485, 36.62360094904237], value: 2 },
      { lonlat: [109.46681140209512, 36.62561194970287], value: 2 },
      { lonlat: [109.45369327487766, 36.62328969949192], value: 2 },
      { lonlat: [109.443303636095, 36.62474923155087], value: 2 },
      { lonlat: [109.44253820357403, 36.62516596076744], value: 2 },
      { lonlat: [109.43462173954586, 36.62753072368888], value: 2 },
      { lonlat: [109.43142085679224, 36.62788342400572], value: 2 },
      { lonlat: [109.39106668692392, 36.63072241385541], value: 2 },
      { lonlat: [109.38132672192305, 36.63163653873149], value: 2 },
      { lonlat: [109.37824301325273, 36.63040238705813], value: 27 },
      { lonlat: [109.37798122397636, 36.63011639738166], value: 2 },
      { lonlat: [109.37831675562222, 36.63067146665423], value: 27 },
      { lonlat: [109.45808259115762, 36.64141836784447], value: 27 },
      { lonlat: [109.45252356495284, 36.64605023114681], value: 27 },
      { lonlat: [109.44790551030523, 36.649213742325166], value: 27 },
      { lonlat: [109.45036882152101, 36.65071418592719], value: 27 },
      { lonlat: [109.45281846503426, 36.652553881255365], value: 27 },
      { lonlat: [109.45326421337076, 36.65291233679495], value: 27 },
      { lonlat: [109.4536673368842, 36.658868012328924], value: 27 },
      { lonlat: [109.45294461614503, 36.659015596859966], value: 27 },
      { lonlat: [109.4510201368656, 36.67300515322296], value: 27 },
      { lonlat: [109.44381236996472, 36.68160182382983], value: 27 },
      { lonlat: [109.44144112268805, 36.68059085074304], value: 2 },
      { lonlat: [109.49931192498602, 36.60090167752511], value: 2 },
      { lonlat: [109.49902156203582, 36.59724500678111], value: 2 },
      { lonlat: [109.49840537722008, 36.58936418409113], value: 2 },
      { lonlat: [109.49699505923651, 36.58701118890556], value: 2 },
      { lonlat: [109.49461410678568, 36.58333134844861], value: 2 },
      { lonlat: [109.49111259069487, 36.57930391823156], value: 2 },
      { lonlat: [109.48858414500634, 36.57771295040469], value: 2 },
      { lonlat: [109.48677981843753, 36.57709276592818], value: 2 },
      { lonlat: [109.48281921942416, 36.57541727734781], value: 2 },
      { lonlat: [109.48006673878221, 36.575126922804415], value: 2 },
      { lonlat: [109.4761270437505, 36.5750411530202], value: 2 },
      { lonlat: [109.47084671389513, 36.5750022383416], value: 2 },
      { lonlat: [109.46891109753669, 36.5745583596313], value: 2 },
      { lonlat: [109.46741115045506, 36.57421153657004], value: 2 },
    ];
    let heatMapJeojson = {};
    let heatMapFeatures = [];
    heatMapList.forEach(element => {
      let heatmap = turf.point(element.lonlat);
      heatmap.properties.value = element.value;
      gcoord.transform(heatmap, gcoord.BD09, gcoord.WGS84);
      heatMapFeatures.push(heatmap);
    });
    heatMapJeojson = turf.featureCollection(heatMapFeatures);
    mapBoxVectorLayer.removeByIds(['heatMapLayer']);
    mapBoxVectorLayer.addHeatMapLayer('heatMapLayer', heatMapJeojson, 'value');
    heatMapJeojson.features.forEach(feature => {
      gcoord.transform(feature, gcoord.WGS84, gcoord.BD09);
    });
    // bus.emit('clearAllLayer');
    // bus.emit('SetLayerShow', ['仿真地图', '桥梁视角']);
  } else {
    let obj = [
      {
        name: '低风险  0%  0',
        value: 0,
        itemStyle: {
          color: '#2BE7ABFF',
        },
      },
      {
        name: '一般风险  0%  0',
        value: 0,
        itemStyle: {
          color: '#18A7F2FF',
        },
      },
      {
        name: '较大风险  0%  0',
        value: 0,
        itemStyle: {
          color: '#F8E270FF',
        },
      },
      {
        name: '重大风险  0%  0',
        value: 0,
        itemStyle: {
          color: '#FF5D6CFF',
        },
      },
    ];
    bus.emit('FxVisible', obj);
    // bus.emit('clearAllLayer');
    // bus.emit('SetLayerShow', ['仿真地图', '隧道视角']);
  }
}

const showPanel = ref(true); //面板展开收起
// 面板内容展开收起控制
const props = defineProps({
  showPanel: {
    type: Boolean,
  },
});
watch(
  () => props.showPanel,
  () => {
    showPanel.value = props.showPanel;
  },
  { immediate: true }
);
onMounted(() => {
  bus.emit('FxVisible', obj.value);
});
onBeforeUnmount(() => {
  mapBoxVectorLayer.removeByIds(['heatMapLayer']);
});
</script>

<style lang="scss" scoped>
.RiskAssessment {
  width: 450px;
  height: 410px;
  // background: yellowgreen;
  .RiskProportion {
    width: 450px;
    height: 175px;
    // background: red;
    .ContentNum {
      margin-top: 4px;
      width: 450px;
      height: 140px;
      .dfFlxa {
        width: 420px;
        height: 30px;
        margin: 5px auto;
        display: flex;

        .middleextA {
          height: 30px;
          width: 17%;
          align-items: center;
          font-family: Source Han Sans CN;
          font-weight: 500;
          font-size: 14px;
          color: #ebfeff;
        }
        .middleextB {
          height: 14px;
          width: 58%;
          margin-top: 8px;
          background: linear-gradient(0deg, rgba(0, 43, 67, 0.8) 0%, rgba(0, 76, 118, 0.8) 100%);
          border-radius: 16px;
          border: 1px solid #15d2fd;
          // background: yellow;
          .BJ_CenBox1 {
            display: inline-block;
            height: 12px;
            background: #00f2ff;
            border-radius: 15px;
            box-sizing: border-box;
            // padding: 0 5px;
          }
        }
        .middleextC {
          margin-left: 13px;
          height: 30px;
          width: 22%;
          justify-content: space-between;
          align-items: center;
        }
      }
    }
  }
  .DrainageRisk {
    margin-top: 5px;
    width: 450px;
    // height: 41%;
    height: calc(100% - 225px);
    // background: blue;
  }
}
.WarningSisposal {
  width: 450px;
  height: calc(100vh - 530px);
  // background: red;
  .WarningSj {
    width: 450px;
    height: 190px;
    margin-top: 5px;
    // background: yellowgreen;
    .WarningList {
      margin-top: 5px;
      width: 425px;
      height: 85%;
      // background: yellow;
      margin: auto;
      .Warningpart {
        margin-top: 5px;
        .part {
          width: 130px;
          height: 160px;
          background: url('@/assets/newImgs/iSpt.png') no-repeat;
          background-size: 100% 100%;
          .parttop {
            height: 160px;
            .upper {
              height: 50%;
              .Major {
                height: 70%;
                .upImg {
                  width: 30px;
                  height: 30px;
                  position: relative;
                  top: 20px;
                  left: 38%;
                }
              }
              .lower {
                height: 30%;
                font-family: Source Han Sans CN;
                font-weight: 500;
                font-size: 14px;
                color: #c1d3d4;
                display: flex;
                // align-items: center;
                justify-content: center;
              }
            }
            .below {
              height: 50%;
              .handIn {
                height: 50%;
                display: flex;
                align-items: center;
                justify-content: center;
                font-family: Source Han Sans CN;
                font-weight: bold;
                font-size: 22px;
                color: #12f9ff;
              }
              .oflower {
                height: 50%;
                display: flex;
                // align-items: center;
                justify-content: center;
                font-family: Source Han Sans CN;
                font-weight: 500;
                font-size: 14px;
                color: #c1d3d4;
              }
            }
          }
        }
      }
    }
  }
  .WarningEcharts {
    margin-top: 5px;
    width: 450px;
    // height: 38%;
    height: calc(100% - 245px);
    // background: rgb(228, 228, 228);
  }
}
.partTitleHM {
  top: 8px;
  position: relative;
  width: 408px;
  height: 44px;
  background: url('@/assets/newImgs/partBg.png') no-repeat;
  background-size: 100% 100%;
  font-family: PangMenZhengDao;
  font-weight: 400;
  font-size: 23px;
  color: #ebfeff;
  line-height: 44px;
  padding-left: 35px;
  margin-left: 10px;
}
.TopProportion {
  display: flex;
  width: 100%;
  .riskMc {
    display: flex;
    width: 60%;
    .icon {
      margin-left: 5px;
      width: 25px;
      height: 25px;
      background: url('@/assets/newImgs/xtb_img.png') no-repeat;
    }
    .text {
      font-family: Source Han Sans CN;
      font-weight: bold;
      font-size: 16px;
      color: #ebfeff;
      line-height: 25px;
      padding-left: 5px;
      background: linear-gradient(0deg, rgba(0, 242, 255, 0.5) 0%, rgba(0, 242, 255, 0) 100%);
      height: 10px;
      line-height: 0px;
      margin-top: 10px;
    }
  }
  .riskZs {
    display: flex;
    justify-content: space-around;
    align-items: center;
    width: 40%;
    .eachDescribe {
      display: flex;
      align-items: center;
      font-family: Source Han Sans CN;
      font-weight: 400;
      // padding-top: 5px;
      .icon {
        width: 8px;
        height: 8px;
        border-radius: 50%;
      }
      .bgcYellow {
        background: #f8744bff;
      }
      .bgcblue {
        background: #18ffff;
      }
      .text {
        padding: 0 10px 0 6px;
        font-family: Source Han Sans CN;
        font-weight: 500;
        font-size: 16px;
        color: #c1d3d4;
      }
    }
  }
  .WarningSl {
    display: flex;
    justify-content: space-around;
    align-items: center;
    width: 55%;
    .eachDescribe {
      display: flex;
      align-items: center;
      font-family: Source Han Sans CN;
      font-weight: 400;
      // padding-top: 5px;
      .icon {
        width: 8px;
        height: 8px;
        border-radius: 50%;
      }
      .bgcYellow {
        background: #2be7abff;
      }
      .bgcls {
        background: #18a7f2ff;
      }
      .text {
        padding: 0 10px 0 6px;
        font-family: Source Han Sans CN;
        font-weight: 500;
        font-size: 14px;
        color: #c1d3d4;
      }
    }
  }
  .WarningNy {
    display: flex;
    width: 45%;
    .head-right {
      cursor: pointer;
      font-size: 14px;
      color: #ffffff;
      display: flex;
      line-height: 18px;
      .head-item {
        width: 70px;
        margin-right: 10px;
        padding: 2px 3px;
        background: #00344f;
        height: 23px;
        text-align: center;
        position: relative;
        left: 40px;
      }
      .activedright {
        border: 1px solid #2cfce9;
        color: #e4f5ff;
        background: #166f84;
      }
    }
  }
}
.ListBoxHeader {
  height: 44px;
  line-height: 50px;
  width: 98%;
  background: url('@/assets/newImgs/partBg.png') no-repeat;
  background-size: 100% 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 7px 0px 0px 8px;
  .ListBoxHeader_font {
    font-family: PangMenZhengDao;
    font-weight: 400;
    font-size: 23px;
    color: #ebfeff;
    padding-left: 34px;
  }
}
</style>