| ¶Ô±ÈÐÂÎļþ |
| | |
| | | <template> |
| | | <v-scale-screen width="1920" height="960"> |
| | | <div class="main_app"> |
| | | <img src="@/assets/images/FireFighting/bg@2x.png" class="main_bg" alt="" /> |
| | | <div class="main_header"> |
| | | <img src="@/assets/images/maintitle@2x.png" class="main_header_bg" alt="" /> |
| | | <div class="title">宿³°æºæ
§ç©æµååº-æ¶é²æå¿çæ§</div> |
| | | <div class="time_wrap"> |
| | | <span class="date">{{ date }}</span> |
| | | <span class="week">{{ week }}</span> |
| | | <span class="time">{{ time }}</span> |
| | | </div> |
| | | </div> |
| | | <div class="main_content"> |
| | | <div class="left_box"> |
| | | <div class="left_box_one"> |
| | | <div class="com_header"> |
| | | <div class="title"> |
| | | <img src="@/assets/images/ic_title@2x.png" class="icon" alt="" /> |
| | | <div>仿¥åç³»ç»è®¾å¤ç¶æååè¦æ°</div> |
| | | </div> |
| | | <img src="@/assets/images/title@2x.png" class="bg" alt="" /> |
| | | </div> |
| | | <div class="list_wrap"> |
| | | <div class="list"> |
| | | <div class="header line"> |
| | | <span class="item name">设å¤ç±»å</span> |
| | | <span class="item">æ»æ°</span> |
| | | <span class="item">æ¥è¦</span> |
| | | <span class="item">å±è½</span> |
| | | <span class="item">æ
é</span> |
| | | <span class="item">离线</span> |
| | | </div> |
| | | <template v-for="i in 5"> |
| | | <div class="line"> |
| | | <span class="item name">ç«ç¶æ¥è¦ç³»ç»</span> |
| | | <span class="item">11</span> |
| | | <span class="item">11</span> |
| | | <span class="item">11</span> |
| | | <span class="item">11</span> |
| | | <span class="item">11</span> |
| | | </div> |
| | | <div class="separate"></div> |
| | | </template> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <div class="left_box_two"> |
| | | <div class="com_header"> |
| | | <div class="title"> |
| | | <img src="@/assets/images/ic_title@2x.png" class="icon" alt="" /> |
| | | <div>æ¥è¦ä¿¡æ¯</div> |
| | | </div> |
| | | <img src="@/assets/images/title@2x.png" class="bg" alt="" /> |
| | | </div> |
| | | <div class="police_wrap"> |
| | | <div class="item" v-for="(ind, i) in 4"> |
| | | <div class="head"> |
| | | <div class="name">ç宿¥è¦æ°</div> |
| | | <div class="name">{{ i }}次</div> |
| | | </div> |
| | | <FirePercent :color="policeColors[i]" :rate="40" /> |
| | | </div> |
| | | |
| | | </div> |
| | | </div> |
| | | <div class="left_box_three"> |
| | | <div class="com_header"> |
| | | <div class="title"> |
| | | <img src="@/assets/images/ic_title@2x.png" class="icon" alt="" /> |
| | | <div>åè¦å¤çåæ</div> |
| | | </div> |
| | | <img src="@/assets/images/title@2x.png" class="bg" alt="" /> |
| | | </div> |
| | | <div class="dispose_wrap"> |
| | | <div class="echart2" id="echart2"></div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <div class="center_box"> |
| | | <div class="center_box_one"> |
| | | <div class="static_wrap"> |
| | | <div class="item"> |
| | | <img src="@/assets/images/FireFighting/xiaofang_ic_zaixian@2x.png" alt=""> |
| | | <div class="content"> |
| | | <div class="name">å¨çº¿</div> |
| | | <div class="num">1000</div> |
| | | </div> |
| | | </div> |
| | | <div class="item"> |
| | | <img src="@/assets/images/FireFighting/xiaofang_ic_baojing@2x.png" alt=""> |
| | | <div class="content"> |
| | | <div class="name">æ¥è¦</div> |
| | | <div class="num num2">12</div> |
| | | </div> |
| | | </div> |
| | | <div class="item"> |
| | | <img src="@/assets/images/FireFighting/xiaofang_ic_guzhang@2x.png" alt=""> |
| | | <div class="content"> |
| | | <div class="name">æ
é</div> |
| | | <div class="num num3">12</div> |
| | | </div> |
| | | </div> |
| | | <div class="item"> |
| | | <img src="@/assets/images/FireFighting/xiaofang_ic_lixian@2x.png" alt=""> |
| | | <div class="content"> |
| | | <div class="name">离线</div> |
| | | <div class="num num4">12</div> |
| | | </div> |
| | | </div> |
| | | <div class="item"> |
| | | <img src="@/assets/images/FireFighting/xiaofang_ic_pingbi@2x.png" alt=""> |
| | | <div class="content"> |
| | | <div class="name">å±è½</div> |
| | | <div class="num num5">12</div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <div class="center_box_two"> |
| | | <div class="content_wrap"> |
| | | <div class="header"> |
| | | <div class="left"> |
| | | <img class="icon" src="@/assets/images/FireFighting/468@2x.png" alt=""> |
| | | <span>温度/æ¹¿åº¦ä¼ æå¨</span> |
| | | </div> |
| | | <div class="right"> |
| | | <img class="icon" src="@/assets/images/FireFighting/xiaofang_ar_left@2x.png" alt=""> |
| | | <div class="num">1/5</div> |
| | | <img class="icon" src="@/assets/images/FireFighting/xiaofang_ar_right@2x.png" alt=""> |
| | | </div> |
| | | </div> |
| | | <div class="list_wrap"> |
| | | <div class="title"> |
| | | <img class="icon" src="@/assets/images/FireFighting/ic_location@2x.png" alt=""> |
| | | <span>å¸è´§åº1</span> |
| | | </div> |
| | | <div class="list"> |
| | | <div class="item"> |
| | | <img class="icon" src="@/assets/images/FireFighting/ic_wendu@2x.png" alt=""> |
| | | <div class="content"> |
| | | <div class="num">23<span>°C</span></div> |
| | | <div class="la">éå¼ 0ï½100°C</div> |
| | | </div> |
| | | </div> |
| | | <div class="item"> |
| | | <img class="icon" src="@/assets/images/FireFighting/ic_shidu@2x.png" alt=""> |
| | | <div class="content"> |
| | | <div class="num">23<span>%</span></div> |
| | | <div class="la">éå¼ 0ï½100%</div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <div class="content_wrap"> |
| | | <div class="header"> |
| | | <div class="left"> |
| | | <img class="icon" src="@/assets/images/FireFighting/468@2x.png" alt=""> |
| | | <span>宿¶ä¼ æå¨æ£æµ</span> |
| | | </div> |
| | | <div class="right"> |
| | | <img class="icon" src="@/assets/images/FireFighting/xiaofang_ar_left@2x.png" alt=""> |
| | | <div class="num">1/5</div> |
| | | <img class="icon" src="@/assets/images/FireFighting/xiaofang_ar_right@2x.png" alt=""> |
| | | </div> |
| | | </div> |
| | | <div class="list_wrap"> |
| | | <div class="title_wrap"> |
| | | <div class="title"> |
| | | <img class="icon" src="@/assets/images/FireFighting/ic_location@2x.png" alt=""> |
| | | <span>1è·¯/æ°´å</span> |
| | | </div> |
| | | <div class="title"> |
| | | <img class="icon" src="@/assets/images/FireFighting/ic_location@2x.png" alt=""> |
| | | <span>2è·¯/æ¶²ä½</span> |
| | | </div> |
| | | </div> |
| | | <div class="list"> |
| | | <div class="watergage_wrap"> |
| | | <div class="watergage" id="watergage"></div> |
| | | <div class="unit">2.50 <span>Mpa</span></div> |
| | | <div class="place">éå¼ 0ï½2.5Mpa</div> |
| | | </div> |
| | | <div class="item"> |
| | | <div class="liquidlevel_wrap"> |
| | | <div class="liquidlevel" id="liquidlevel"></div> |
| | | <div class="unit">3.45 <span>M</span></div> |
| | | <div class="place">éå¼ 0ï½4.50M</div> |
| | | </div> |
| | | |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <div class="right_box"> |
| | | <div class="right_box_one"> |
| | | <div class="com_header"> |
| | | <div class="title"> |
| | | <img src="@/assets/images/ic_title@2x.png" class="icon" alt="" /> |
| | | <div>æ¬å¹´æ¶é²è®¾å¤/设æ½ç»´ä¿æ
åµ</div> |
| | | </div> |
| | | <img src="@/assets/images/title@2x.png" class="bg" alt="" /> |
| | | </div> |
| | | <div class="content_wrap"> |
| | | <div class="list"> |
| | | <template v-for="i in 3"> |
| | | <div class="item"> |
| | | <div>已维ä¿</div> |
| | | <div class="num active">500</div> |
| | | </div> |
| | | <div v-if="i < 3" class="separate"></div> |
| | | </template> |
| | | |
| | | </div> |
| | | <div class="footer"> |
| | | <img src="@/assets/images/FireFighting/ic_weixiu@2x.png" class="icon" alt=""> |
| | | <div class="content"> |
| | | <div>æ¬ææ°å¢ç»´ä¿</div> |
| | | <div class="num">40 <span>个</span></div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <div class="right_box_two"> |
| | | <div class="com_header"> |
| | | <div class="title"> |
| | | <img src="@/assets/images/ic_title@2x.png" class="icon" alt="" /> |
| | | <div>仿¥éæ£/åè¦</div> |
| | | </div> |
| | | <img src="@/assets/images/title@2x.png" class="bg" alt="" /> |
| | | </div> |
| | | <div class="su_title"> |
| | | <img class="icon" src="@/assets/images/FireFighting/ic_title_green@2x.png" alt=""> |
| | | <div class="name">鿣鿿</div> |
| | | </div> |
| | | <div class="static_wrap"> |
| | | <div class="item"> |
| | | <img src="@/assets/images/FireFighting/ic_tibao@2x.png" alt=""> |
| | | <div class="content"> |
| | | <div class="name">ææ¥éæ£æ°</div> |
| | | <div class="num"><span>10</span>个</div> |
| | | </div> |
| | | </div> |
| | | <div class="item"> |
| | | <img src="@/assets/images/FireFighting/ic_chuli@2x.png" alt=""> |
| | | <div class="content"> |
| | | <div class="name">å¤ç鿣æ°</div> |
| | | <div class="num"><span class="today">3</span>个</div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <div class="su_title"> |
| | | <img class="icon" src="@/assets/images/FireFighting/ic_title_green@2x.png" alt=""> |
| | | <div class="name">åè¦ä¿¡æ¯</div> |
| | | </div> |
| | | <div class="list"> |
| | | <div class="item" v-for="i in 5"> |
| | | <div class="icon"> |
| | | <div class="circle"></div> |
| | | <div class="line"></div> |
| | | </div> |
| | | <div class="content"> |
| | | <div class="header"> |
| | | <div class="time"> |
| | | <span>123</span> |
| | | <span class="status">å¤çä¸</span> |
| | | </div> |
| | | <div class="have_time">å·²ç»åç<span>1</span>åé</div> |
| | | </div> |
| | | <div class="wrap"> |
| | | <div class="title"> |
| | | <img class="xf" src="@/assets/images/FireFighting/ic_gaojing_red@2x.png" alt=""> |
| | | <span>æ¶é²è¦å</span> |
| | | </div> |
| | | <div class="title"> |
| | | <img class="addr" src="@/assets/images/FireFighting/xiaofang_ic_weizhi@2x.png" alt=""> |
| | | <span>address</span> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </v-scale-screen> |
| | | </template> |
| | | |
| | | <script setup> |
| | | import { ref, onMounted } from 'vue' |
| | | import VScaleScreen from 'v-scale-screen' |
| | | import FirePercent from '@/components/FirePercent.vue' |
| | | import dayjs from 'dayjs' |
| | | |
| | | import * as echarts from 'echarts' |
| | | const colors = ['#FEAF01', '#01ABFE', '#51F9E4'] |
| | | const weekMap = ['æææ¥', 'ææä¸', 'ææäº', 'ææä¸', 'ææå', 'ææäº', 'ææå
',] |
| | | const date = ref(dayjs().format('YYYY.MM.DD')) |
| | | const week = ref(weekMap[new Date().getDay()]) |
| | | const time = ref(dayjs().format('HH:mm:ss')) |
| | | setInterval(() => { |
| | | date.value = dayjs().format('YYYY-MM-DD') |
| | | week.value = weekMap[new Date().getDay()] |
| | | time.value = dayjs().format('HH:mm:ss') |
| | | |
| | | }, 1000) |
| | | |
| | | const arr = ['#68e2e3', '#50afd3', '#377cdb', '#d5ae3a'] |
| | | const initEchart2 = () => { |
| | | var myChart = echarts.init(document.querySelector('.echart2')) |
| | | // çææ°æ®åæ¥æ |
| | | function getLastSevenDays() { |
| | | const days = [] |
| | | const today = new Date() |
| | | for (let i = 10; i >= 0; i--) { |
| | | days.push(`${i + 1}æ`) // æ ¼å¼åæ¥æä¸º "XæXæ¥" |
| | | } |
| | | return days |
| | | } |
| | | |
| | | // ç¤ºä¾æ°æ® |
| | | const data1 = [13, 14, 14, 14, 14, 12, 11, 23, 12, 1] // åæ¶ |
| | | const data2 = [1, 1, 2, 1, 1, 2, 2, 3, 2, 1, 5] // è¿å° |
| | | const data3 = [1, 0, 0, 0, 0, 0, 2, 2, 3, 1, 2] // 请å |
| | | const data4 = [8, 5, 4, 7, 4, 5, 7, 4, 2, 1, 3] // å ç |
| | | const option = { |
| | | legend: { |
| | | x: "center", |
| | | textStyle: { |
| | | color: "#FFFFFF", // å¾ä¾æå设为ç½è² |
| | | fontSize: 12 |
| | | }, |
| | | icon: 'circle', |
| | | top: '6%', |
| | | itemWidth: 8, |
| | | itemHeight: 8, |
| | | itemGap: 20, |
| | | data: ['åè¦æ°', 'è¿è¡ä¸', 'å·²å¤ç', 'è¯¯æ¥æ°'] // æ´æ°å¾ä¾åç§° |
| | | }, |
| | | grid: { |
| | | left: '2%', |
| | | right: '0%', |
| | | top: '18%', |
| | | bottom: '10%', |
| | | containLabel: true, |
| | | }, |
| | | tooltip: { |
| | | trigger: "axis", |
| | | axisPointer: { |
| | | type: "shadow" |
| | | }, |
| | | textStyle: { |
| | | color: "rgba(255, 255, 255, 1)" |
| | | }, |
| | | backgroundColor: "rgba(0,0,0,0.8)", |
| | | borderColor: "rgba(219, 230, 255, 0.8)", |
| | | }, |
| | | xAxis: { |
| | | data: getLastSevenDays(), // 使ç¨è¿ä¸å¤©æ¥æ |
| | | axisLabel: { |
| | | color: "#FFFFFF", // X è½´æå设为ç½è² |
| | | fontSize: 14, |
| | | }, |
| | | axisLine: { |
| | | lineStyle: { |
| | | color: '#1E294C' |
| | | } |
| | | }, |
| | | axisTick: { |
| | | show: false |
| | | } |
| | | }, |
| | | yAxis: { |
| | | show: true, |
| | | axisLabel: { |
| | | color: "#FFFFFF", // Y è½´æå设为ç½è² |
| | | fontSize: 12, |
| | | }, |
| | | axisLine: { |
| | | lineStyle: { |
| | | color: '#A9AEB2' |
| | | } |
| | | }, |
| | | axisTick: { |
| | | lineStyle: { |
| | | color: '#A9AEB2' |
| | | } |
| | | }, |
| | | splitLine: { |
| | | show: true, |
| | | lineStyle: { |
| | | color: ["#0f1d27"], |
| | | width: 1 |
| | | }, |
| | | }, |
| | | }, |
| | | series: [ |
| | | { |
| | | name: "åè¦æ°", |
| | | type: "bar", |
| | | stack: "attendance", |
| | | data: data1, |
| | | itemStyle: { |
| | | color: '#FEAF01', |
| | | }, |
| | | label: { |
| | | show: false, |
| | | color: "#FFFFFF", |
| | | }, |
| | | emphasis: { |
| | | focus: "series", |
| | | }, |
| | | barWidth: 6, |
| | | }, |
| | | { |
| | | name: "è¿è¡ä¸", // è¿å°æ°æ® |
| | | type: "bar", |
| | | stack: "attendance", |
| | | data: data2, |
| | | itemStyle: { |
| | | color: '#28F0C4', // è¿å°çé¢è² |
| | | }, |
| | | label: { |
| | | show: false, |
| | | color: "#FFFFFF", |
| | | }, |
| | | emphasis: { |
| | | focus: "series", |
| | | }, |
| | | }, |
| | | { |
| | | name: "å·²å¤ç", // è¯·åæ°æ® |
| | | type: "bar", |
| | | stack: "attendance", |
| | | data: data3, |
| | | itemStyle: { |
| | | color: '#0193FE', // 请åçé¢è² |
| | | }, |
| | | label: { |
| | | show: false, |
| | | color: "#FFFFFF", |
| | | }, |
| | | emphasis: { |
| | | focus: "series", |
| | | }, |
| | | }, |
| | | { |
| | | name: "è¯¯æ¥æ°", // åç¬çå çæ±å |
| | | type: "bar", |
| | | data: data4, |
| | | barWidth: 6, |
| | | itemStyle: { |
| | | color: '#FEED01', // é«äº®çç´«è² |
| | | }, |
| | | emphasis: { |
| | | focus: "series", |
| | | }, |
| | | }, |
| | | ], |
| | | } |
| | | myChart.setOption(option) |
| | | window.addEventListener('resize', function () {//æ§è¡ |
| | | myChart.resize() |
| | | }) |
| | | } |
| | | |
| | | const policeColors = ['#01D9FE', '#FE5501', '#0193FE', '#28F0C4'] |
| | | const initWatergage = () => { |
| | | const myChart = echarts.init(document.getElementById('watergage')) |
| | | var data_value = 2 |
| | | const option = { |
| | | barMaxWidth: 3, |
| | | polar: { |
| | | radius: '80%' |
| | | }, |
| | | grid: { |
| | | top: '0%', |
| | | left: '0%', |
| | | right: '%', |
| | | bottom: '0%', |
| | | containLabel: true |
| | | }, |
| | | angleAxis: { |
| | | show: false, |
| | | max: (360 * 100) / 270, |
| | | type: 'value', |
| | | startAngle: 225, |
| | | }, |
| | | radiusAxis: { |
| | | show: false, |
| | | type: 'category', |
| | | z: 10 |
| | | }, |
| | | series: [ |
| | | { |
| | | type: 'gauge', |
| | | min: 0, |
| | | max: 2.50, |
| | | splitNumber: 5, |
| | | radius: '100%', |
| | | center: ['50%', '50%'], |
| | | data: [data_value], |
| | | detail: { |
| | | formatter: (v) => v + '%', |
| | | color: '#152435', |
| | | fontSize: 1, |
| | | |
| | | }, |
| | | itemStyle: { |
| | | color: '#3DE6FF' |
| | | }, |
| | | pointer: { |
| | | width: 2, |
| | | length: '90%', |
| | | offsetCenter: [0, '3%'], |
| | | }, |
| | | axisLine: { |
| | | show: true, |
| | | lineStyle: { |
| | | width: 0, |
| | | color: [ |
| | | [0.05, '#1b6dff'], |
| | | [0.10, '#2084ff'], |
| | | [0.15, '#2596ff'], |
| | | [0.20, '#2db0ff'], |
| | | [0.25, '#31c0ff'], |
| | | [0.30, '#36d3ff'], |
| | | [0.35, '#4fe6ec'], |
| | | [0.40, '#6ae7d2'], |
| | | [0.45, '#84e8b9'], |
| | | [0.50, '#a5e999'], |
| | | [0.55, '#ccea75'], |
| | | [0.60, '#f8eb4a'], |
| | | [0.65, '#ffdd4f'], |
| | | [0.70, '#ffcb5a'], |
| | | [0.75, '#ffae6e'], |
| | | [0.80, '#ff9c7b'], |
| | | [0.85, '#ff8d87'], |
| | | [0.90, '#ff7d91'], |
| | | [0.95, '#ff6f9b'], |
| | | [1, '#ff5ca9'] |
| | | ] |
| | | |
| | | } |
| | | }, |
| | | axisTick: { |
| | | show: true, |
| | | length: 3, |
| | | splitNumber: 12, |
| | | lineStyle: { |
| | | width: 1, |
| | | color: 'auto', |
| | | }, |
| | | }, |
| | | axisLabel: { |
| | | distance: 12, |
| | | fontSize: 8, |
| | | color: 'auto', |
| | | }, |
| | | splitLine: { |
| | | show: true, |
| | | length: -5, |
| | | lineStyle: { |
| | | width: 1, |
| | | color: 'auto', |
| | | } |
| | | }, |
| | | z: 9, |
| | | }, |
| | | { |
| | | type: 'bar', |
| | | barGap: '-100%', |
| | | coordinateSystem: 'polar', |
| | | roundCap: true, |
| | | data: [ |
| | | { |
| | | value: 100, |
| | | itemStyle: { |
| | | color: new echarts.graphic.LinearGradient(0, 0, 1, 1, [ |
| | | { offset: 0, color: '#0A5EFF' }, |
| | | { offset: 0.45, color: '#20DDFF' }, |
| | | { offset: 1, color: '#FC10CB' } |
| | | ]) |
| | | } |
| | | } |
| | | ], |
| | | z: 3, |
| | | }, |
| | | { |
| | | type: 'pie', |
| | | radius: ['2%', '6%'], |
| | | center: ['50%', '50%'], |
| | | labelLine: { |
| | | show: false |
| | | }, |
| | | data: [ |
| | | { |
| | | value: 100, |
| | | itemStyle: { |
| | | color: '#3DE6FF', |
| | | opacity: 0.5 |
| | | } |
| | | } |
| | | ], |
| | | z: 2, |
| | | }, |
| | | { |
| | | type: 'pie', |
| | | radius: 4, |
| | | labelLine: { |
| | | show: false |
| | | }, |
| | | data: [ |
| | | { |
| | | value: 20, |
| | | itemStyle: { |
| | | color: '#3DE6FF' |
| | | } |
| | | } |
| | | ], |
| | | z: 1, |
| | | }, |
| | | ] |
| | | } |
| | | myChart.setOption(option) |
| | | window.addEventListener('resize', function () { // æ§è¡ |
| | | myChart.resize() |
| | | }) |
| | | } |
| | | const initLiquidlevel = () => { |
| | | const myChart = echarts.init(document.getElementById('liquidlevel')) |
| | | var data = 65 |
| | | const option = { |
| | | tooltip: { |
| | | trigger: 'none', |
| | | }, |
| | | xAxis: { |
| | | data: ['ç¾åæ¯'], |
| | | axisTick: { |
| | | show: false, |
| | | }, |
| | | axisLine: { |
| | | show: false, |
| | | }, |
| | | axisLabel: { |
| | | show: false, |
| | | textStyle: { |
| | | color: '#e54035', |
| | | }, |
| | | }, |
| | | }, |
| | | yAxis: { |
| | | splitLine: { |
| | | show: false, |
| | | }, |
| | | axisTick: { |
| | | show: false, |
| | | }, |
| | | axisLine: { |
| | | show: false, |
| | | }, |
| | | axisLabel: { |
| | | show: false, |
| | | }, |
| | | }, |
| | | series: [ |
| | | { |
| | | name: 'æä¸å±ç«ä½å', |
| | | type: 'pictorialBar', |
| | | symbolSize: [260, 40], |
| | | symbolOffset: [0, -20], |
| | | z: 12, |
| | | itemStyle: { |
| | | normal: { |
| | | color: 'rgba(8,44,110, 1)', |
| | | }, |
| | | }, |
| | | data: [ |
| | | { |
| | | value: 100, |
| | | symbolPosition: 'end', |
| | | }, |
| | | ], |
| | | }, |
| | | { |
| | | name: 'ä¸é´ç«ä½å', |
| | | type: 'pictorialBar', |
| | | symbolSize: [260, 40], |
| | | symbolOffset: [0, -20], |
| | | z: 12, |
| | | itemStyle: { |
| | | normal: { |
| | | color: () => |
| | | new echarts.graphic.LinearGradient(1, 1, 0, 0, [ |
| | | { |
| | | offset: 0, |
| | | color: '#03C7F9', |
| | | }, |
| | | { |
| | | offset: 1, |
| | | // color: '#03C7F922', |
| | | color: 'rgb(8,44,110)', |
| | | }, |
| | | ]), |
| | | shadowColor: '#03C7F9', |
| | | shadowBlur: 10, |
| | | shadowOffsetX: 0, |
| | | shadowOffsetY: 4, |
| | | }, |
| | | }, |
| | | data: [ |
| | | { |
| | | value: data, |
| | | symbolPosition: 'end', |
| | | }, |
| | | ], |
| | | }, |
| | | { |
| | | name: 'æåºé¨ç«ä½å', |
| | | type: 'pictorialBar', |
| | | symbolSize: [260, 40], |
| | | symbolOffset: [0, 20], |
| | | z: 12, |
| | | itemStyle: { |
| | | normal: { |
| | | color: () => |
| | | new echarts.graphic.LinearGradient(0, 1, 1, 0, [ |
| | | { |
| | | offset: 0, |
| | | color: '#03C7F9', |
| | | }, |
| | | { |
| | | offset: 0.9, |
| | | // color: '#03C7F922', |
| | | color: 'rgba(8,44,110, 0.85)', |
| | | }, |
| | | ]), |
| | | // shadowColor: '#03C7F9', |
| | | // shadowBlur: 30, |
| | | // shadowOffsetX: 0, |
| | | // shadowOffsetY: -10, |
| | | }, |
| | | }, |
| | | data: [100 - data], |
| | | }, |
| | | { |
| | | //åºé¨ç«ä½æ± |
| | | stack: '1', |
| | | type: 'bar', |
| | | itemStyle: { |
| | | normal: { |
| | | // color: 'rgba(8,44,110, 0.94)', |
| | | color: () => |
| | | new echarts.graphic.LinearGradient(0, 0, 1, 0, [ |
| | | { |
| | | offset: 0, |
| | | color: 'rgba(18,85,213,0.77)', |
| | | }, |
| | | { |
| | | offset: 1, |
| | | color: 'rgba(8,44,110, 0.77)', |
| | | }, |
| | | ]), |
| | | opacity: 0.77, |
| | | }, |
| | | }, |
| | | label: { |
| | | distance: 15, |
| | | show: true, |
| | | position: data > 58 ? 'inside' : 'top', |
| | | formatter: '{c}' + '%', |
| | | fontSize: 80, |
| | | color: '#1AFCFF', |
| | | textShadowColor: '#03C7F9', |
| | | textShadowBlur: 30, |
| | | textShadowOffsetX: 5, |
| | | textShadowOffsetY: 10, |
| | | }, |
| | | |
| | | silent: true, |
| | | barWidth: 250, |
| | | barGap: '-100%', // Make series be overlap |
| | | data: [data], |
| | | }, |
| | | { |
| | | //ä¸é¨ç«ä½æ± |
| | | stack: '1', |
| | | type: 'bar', |
| | | itemStyle: { |
| | | normal: { |
| | | color: () => |
| | | new echarts.graphic.LinearGradient(1, 0, 0, 0, [ |
| | | { |
| | | offset: 0, |
| | | color: '#47C8FF77', |
| | | }, |
| | | { |
| | | offset: 0.05, |
| | | color: '#47C8FF44', |
| | | }, |
| | | { |
| | | offset: 0.15, |
| | | color: '#47C8FF00', |
| | | }, |
| | | { |
| | | offset: 0.85, |
| | | color: '#47C8FF00', |
| | | }, |
| | | { |
| | | offset: 0.95, |
| | | color: '#47C8FF44', |
| | | }, |
| | | { |
| | | offset: 1, |
| | | color: '#47C8FF77', |
| | | }, |
| | | ]), |
| | | }, |
| | | }, |
| | | silent: true, |
| | | barWidth: 300, |
| | | barGap: '-100%', // Make series be overlap |
| | | data: [100 - data], |
| | | }, |
| | | ], |
| | | } |
| | | myChart.setOption(option) |
| | | window.addEventListener('resize', function () { // æ§è¡ |
| | | myChart.resize() |
| | | }) |
| | | } |
| | | |
| | | onMounted(() => { |
| | | initEchart2() |
| | | initWatergage() |
| | | initLiquidlevel() |
| | | }) |
| | | |
| | | |
| | | </script> |
| | | |
| | | <style lang="scss" scoped> |
| | | div { |
| | | box-sizing: border-box; |
| | | } |
| | | |
| | | .main_content { |
| | | display: flex; |
| | | padding: 20px 25px 0; |
| | | |
| | | .left_box { |
| | | width: 450px; |
| | | |
| | | .left_box_one { |
| | | width: 100%; |
| | | margin-bottom: 20px; |
| | | border: 1px solid; |
| | | |
| | | .list_wrap { |
| | | padding: 10px 0; |
| | | height: 227px; |
| | | overflow: auto; |
| | | |
| | | .list { |
| | | .line { |
| | | display: flex; |
| | | height: 32px; |
| | | align-items: center; |
| | | font-size: 14px; |
| | | |
| | | .item { |
| | | flex: 1; |
| | | display: flex; |
| | | justify-content: center; |
| | | align-items: center; |
| | | white-space: nowrap; |
| | | overflow: hidden; |
| | | text-overflow: ellipsis; |
| | | } |
| | | |
| | | .name { |
| | | flex: 2; |
| | | } |
| | | |
| | | .warnning { |
| | | color: #FEAF01; |
| | | } |
| | | } |
| | | |
| | | .header { |
| | | background: rgba(134, 156, 201, 0.1); |
| | | font-weight: 500; |
| | | |
| | | .item { |
| | | border-right: 1px solid rgba(255, 255, 255, 0.2); |
| | | |
| | | &:nth-last-child(1) { |
| | | border: none; |
| | | } |
| | | } |
| | | } |
| | | |
| | | .separate { |
| | | width: 100%; |
| | | height: 2px; |
| | | background-color: rgba(255, 255, 255, 0.2); |
| | | /* background-color: red; */ |
| | | border-right: 4px solid #00F2F3; |
| | | border-left: 4px solid #00F2F3; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | .left_box_two { |
| | | margin-bottom: 20px; |
| | | |
| | | .police_wrap { |
| | | padding: 15px 20px 0; |
| | | height: 225px; |
| | | border: 1px solid; |
| | | |
| | | .item { |
| | | margin-bottom: 5px; |
| | | |
| | | .head { |
| | | display: flex; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | font-size: 16px; |
| | | color: #FFFFFF; |
| | | margin-bottom: 8px; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | .left_box_three { |
| | | .dispose_wrap { |
| | | border: 1px solid; |
| | | height: 210px; |
| | | width: 100%; |
| | | |
| | | .echart2 { |
| | | width: 100%; |
| | | height: 100%; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | .center_box { |
| | | flex: 1; |
| | | padding: 16px 60px 0; |
| | | display: flex; |
| | | flex-direction: column; |
| | | justify-content: space-between; |
| | | |
| | | .center_box_one { |
| | | .static_wrap { |
| | | display: flex; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | margin: 30px 0 54px; |
| | | |
| | | .item { |
| | | display: flex; |
| | | |
| | | img { |
| | | width: 61px; |
| | | height: 63px; |
| | | margin-right: 15px; |
| | | } |
| | | |
| | | .content { |
| | | font-size: 15px; |
| | | |
| | | .num { |
| | | font-size: 12px; |
| | | color: #D2E0FF; |
| | | |
| | | font-weight: bold; |
| | | font-size: 30px; |
| | | margin-right: 5px; |
| | | font-weight: 600; |
| | | background-image: -webkit-linear-gradient(top, |
| | | #01D9FE 0%, |
| | | #01D9FE 60%, |
| | | #fff 100%); |
| | | -webkit-background-clip: text; |
| | | -webkit-text-fill-color: transparent; |
| | | } |
| | | |
| | | .num2 { |
| | | background-image: -webkit-linear-gradient(top, |
| | | #fff 0%, |
| | | #dd4c26 50%, |
| | | #e43724 100%); |
| | | } |
| | | |
| | | .num3 { |
| | | background-image: -webkit-linear-gradient(top, |
| | | #fff 0%, |
| | | #e9bf43 50%, |
| | | #eb8131 100%); |
| | | } |
| | | |
| | | .num4 { |
| | | background-image: -webkit-linear-gradient(top, |
| | | #fff 0%, |
| | | #9e9e9e 50%, |
| | | #9e9e9e 100%); |
| | | } |
| | | |
| | | .num5 { |
| | | background-image: -webkit-linear-gradient(top, |
| | | #fff 0%, |
| | | #3a83f5 50%, |
| | | #3a83f5 100%); |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | .center_box_two { |
| | | width: 100%; |
| | | display: flex; |
| | | |
| | | .content_wrap { |
| | | flex: 1; |
| | | margin-right: 20px; |
| | | |
| | | .title_wrap { |
| | | display: flex; |
| | | |
| | | .title { |
| | | flex: 1; |
| | | } |
| | | } |
| | | |
| | | &:nth-last-child(1) { |
| | | margin-right: 0; |
| | | } |
| | | |
| | | .header { |
| | | display: flex; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | font-weight: bold; |
| | | font-size: 16px; |
| | | text-shadow: 0px 2px 8px #01ABFE; |
| | | margin-bottom: 20px; |
| | | |
| | | .left { |
| | | display: flex; |
| | | align-items: center; |
| | | |
| | | .icon { |
| | | width: 14px; |
| | | height: 28px; |
| | | margin-right: 10px; |
| | | } |
| | | } |
| | | |
| | | .right { |
| | | display: flex; |
| | | align-items: center; |
| | | |
| | | .num { |
| | | margin: 0 40px; |
| | | } |
| | | |
| | | .icon { |
| | | width: 13px; |
| | | height: 16px; |
| | | } |
| | | } |
| | | } |
| | | |
| | | .list_wrap { |
| | | height: 206px; |
| | | background-image: url('@/assets/images/FireFighting/bg_wendu@2x.png'); |
| | | background-size: cover; |
| | | |
| | | .title { |
| | | height: 46px; |
| | | display: flex; |
| | | align-items: center; |
| | | color: #D2E0FF; |
| | | padding-left: 20px; |
| | | |
| | | .icon { |
| | | width: 16px; |
| | | margin-right: 8px; |
| | | } |
| | | } |
| | | |
| | | .list { |
| | | height: 160px; |
| | | display: flex; |
| | | justify-content: space-evenly; |
| | | |
| | | .item { |
| | | display: flex; |
| | | align-items: center; |
| | | |
| | | .icon { |
| | | width: 70px; |
| | | height: 70px; |
| | | margin-right: 10px; |
| | | } |
| | | |
| | | .content { |
| | | .num { |
| | | font-size: 28px; |
| | | font-weight: 500; |
| | | |
| | | span { |
| | | font-style: 14px; |
| | | font-weight: 400; |
| | | } |
| | | } |
| | | |
| | | .la { |
| | | font-size: 13px; |
| | | color: #869CC9; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | .watergage_wrap { |
| | | text-align: center; |
| | | position: relative; |
| | | left: 30px; |
| | | |
| | | .watergage { |
| | | width: 130px; |
| | | height: 112px; |
| | | } |
| | | |
| | | .unit { |
| | | font-weight: 500; |
| | | font-size: 18px; |
| | | position: relative; |
| | | bottom: 16px; |
| | | left: 4px; |
| | | |
| | | span { |
| | | font-size: 12px; |
| | | font-weight: 400; |
| | | } |
| | | } |
| | | |
| | | .place { |
| | | position: relative; |
| | | bottom: 16px; |
| | | left: 4px; |
| | | font-size: 13px; |
| | | color: #869CC9; |
| | | } |
| | | } |
| | | |
| | | .liquidlevel_wrap { |
| | | transform: scale(0.24); |
| | | color: #fff; |
| | | text-align: center; |
| | | position: relative; |
| | | left: 20px; |
| | | bottom: 10px; |
| | | |
| | | .unit { |
| | | font-weight: 500; |
| | | font-size: 80px; |
| | | position: relative; |
| | | bottom: 24px; |
| | | left: 4px; |
| | | |
| | | span { |
| | | font-size: 52px; |
| | | font-weight: 400; |
| | | } |
| | | } |
| | | |
| | | .place { |
| | | position: relative; |
| | | bottom: 10px; |
| | | left: 4px; |
| | | font-size: 44px; |
| | | color: #869CC9; |
| | | } |
| | | |
| | | .liquidlevel { |
| | | width: 320px; |
| | | height: 420px; |
| | | |
| | | } |
| | | } |
| | | |
| | | |
| | | } |
| | | } |
| | | |
| | | } |
| | | } |
| | | |
| | | .right_box { |
| | | width: 450px; |
| | | |
| | | .right_box_one { |
| | | .content_wrap { |
| | | height: 176px; |
| | | |
| | | .list { |
| | | display: flex; |
| | | align-items: center; |
| | | |
| | | .item { |
| | | height: 116px; |
| | | flex: 1; |
| | | display: flex; |
| | | flex-direction: column; |
| | | justify-content: center; |
| | | align-items: center; |
| | | |
| | | .num { |
| | | margin-top: 12px; |
| | | font-weight: bold; |
| | | font-size: 32px; |
| | | } |
| | | |
| | | .active { |
| | | color: #00F2F3; |
| | | } |
| | | } |
| | | |
| | | .separate { |
| | | width: 1px; |
| | | height: 50px; |
| | | background-color: rgba(255, 255, 255, 0.21); |
| | | } |
| | | } |
| | | |
| | | .footer { |
| | | display: flex; |
| | | |
| | | .icon { |
| | | width: 40px; |
| | | height: 41px; |
| | | margin-right: 2px; |
| | | } |
| | | |
| | | .content { |
| | | flex: 1; |
| | | font-size: 16px; |
| | | height: 40px; |
| | | display: flex; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | padding: 0 20px; |
| | | background: linear-gradient(270deg, rgba(1, 217, 254, 0) 0%, rgba(1, 217, 254, 0.19) 100%); |
| | | border: 1px solid; |
| | | border-image: linear-gradient(270deg, rgba(1, 217, 254, 0), rgba(1, 217, 254, 0.6)) 1 1; |
| | | |
| | | .num { |
| | | font-size: 20px; |
| | | font-weight: bold; |
| | | |
| | | span { |
| | | font-size: 13px; |
| | | color: #869CC9; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | .right_box_two { |
| | | .su_title { |
| | | display: flex; |
| | | align-items: center; |
| | | font-weight: 500; |
| | | font-size: 16px; |
| | | margin: 20px; |
| | | |
| | | .icon { |
| | | width: 17px; |
| | | height: 17px; |
| | | margin-right: 7px; |
| | | } |
| | | } |
| | | |
| | | .static_wrap { |
| | | display: flex; |
| | | justify-content: space-evenly; |
| | | align-items: center; |
| | | height: 110px; |
| | | |
| | | .item { |
| | | display: flex; |
| | | align-items: center; |
| | | |
| | | img { |
| | | width: 80px; |
| | | height: 80px; |
| | | margin-right: 8px; |
| | | } |
| | | |
| | | .content { |
| | | font-size: 14px; |
| | | |
| | | .num { |
| | | font-size: 12px; |
| | | color: #D2E0FF; |
| | | margin-top: 8px; |
| | | |
| | | span { |
| | | font-weight: bold; |
| | | font-size: 24px; |
| | | margin-right: 4px; |
| | | font-weight: 600; |
| | | background-image: -webkit-linear-gradient(top, |
| | | #01D9FE 0%, |
| | | #01D9FE 60%, |
| | | #fff 100%); |
| | | -webkit-background-clip: text; |
| | | -webkit-text-fill-color: transparent; |
| | | } |
| | | |
| | | .today { |
| | | background-image: -webkit-linear-gradient(top, |
| | | #fff 0%, |
| | | #FFB120 50%, |
| | | #FFB120 100%); |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | .list { |
| | | height: 330px; |
| | | overflow: auto; |
| | | margin-top: 15px; |
| | | scrollbar-width: none; |
| | | |
| | | .item { |
| | | display: flex; |
| | | font-size: 13px; |
| | | color: #D2E0FF; |
| | | |
| | | .icon { |
| | | width: 40px; |
| | | display: flex; |
| | | flex-direction: column; |
| | | align-items: center; |
| | | padding-top: 10px; |
| | | |
| | | .circle { |
| | | width: 7px; |
| | | height: 7px; |
| | | border-radius: 50%; |
| | | background: #01D9FE; |
| | | box-shadow: 0px 0px 1px 4px #34788f; |
| | | /* opacity: 0.52; */ |
| | | } |
| | | |
| | | .line { |
| | | margin-top: 3px; |
| | | width: 1px; |
| | | flex: 1; |
| | | background-color: #153947; |
| | | } |
| | | } |
| | | |
| | | .content { |
| | | flex: 1; |
| | | |
| | | .header { |
| | | display: flex; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | |
| | | .time { |
| | | display: flex; |
| | | align-items: center; |
| | | |
| | | .status { |
| | | height: 18px; |
| | | line-height: 18px; |
| | | border-radius: 2px; |
| | | padding: 2px 4px; |
| | | border: 1px solid #869CC9; |
| | | font-size: 12px; |
| | | margin-left: 8px; |
| | | } |
| | | } |
| | | |
| | | .have_time { |
| | | font-size: 12px; |
| | | color: #D2E0FF; |
| | | |
| | | span { |
| | | color: #FEAF01; |
| | | } |
| | | } |
| | | } |
| | | |
| | | .wrap { |
| | | height: 40px; |
| | | background: linear-gradient(270deg, rgba(254, 85, 1, 0) 0%, rgba(254, 85, 1, 0.19) 100%); |
| | | border-radius: 2px 0px 0px 2px; |
| | | display: flex; |
| | | align-items: center; |
| | | border: 1px solid; |
| | | margin-bottom: 20px; |
| | | margin-top: 8px; |
| | | padding: 0 10px; |
| | | border-image: linear-gradient(270deg, rgba(254, 85, 1, 0), rgba(254, 85, 1, 0.6)) 1 1; |
| | | |
| | | .title { |
| | | flex: 4; |
| | | font-weight: bold; |
| | | font-size: 15px; |
| | | color: #FFFFFF; |
| | | display: flex; |
| | | align-items: center; |
| | | |
| | | span { |
| | | margin-left: 4px; |
| | | } |
| | | |
| | | .xf { |
| | | width: 14px; |
| | | height: 14px; |
| | | } |
| | | |
| | | .addr { |
| | | width: 12px; |
| | | height: 12px; |
| | | } |
| | | } |
| | | |
| | | .address { |
| | | flex: 6; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | .main_header { |
| | | display: flex; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | height: 90px; |
| | | position: relative; |
| | | padding: 0px 40px 16px; |
| | | font-weight: 600; |
| | | font-size: 36px; |
| | | |
| | | .title { |
| | | background-image: -webkit-linear-gradient(top, |
| | | #ffffff 0%, |
| | | #c8ddff 70%, |
| | | #85b4ff 80%, |
| | | #74a9ff 100%); |
| | | -webkit-background-clip: text; |
| | | -webkit-text-fill-color: transparent; |
| | | } |
| | | |
| | | .time_wrap { |
| | | font-size: 26px; |
| | | font-weight: 600; |
| | | background-image: -webkit-linear-gradient(top, |
| | | #ffffff 0%, |
| | | #c8ddff 50%, |
| | | #85b4ff 80%, |
| | | #74a9ff 100%); |
| | | -webkit-background-clip: text; |
| | | -webkit-text-fill-color: transparent; |
| | | display: flex; |
| | | align-items: center; |
| | | |
| | | .time { |
| | | width: 130px; |
| | | display: flex; |
| | | justify-content: flex-end; |
| | | font-size: 30px; |
| | | } |
| | | |
| | | .week { |
| | | margin-left: 20px; |
| | | } |
| | | } |
| | | |
| | | .main_header_bg { |
| | | position: absolute; |
| | | left: 0; |
| | | top: 0; |
| | | width: 100%; |
| | | height: 100%; |
| | | object-fit: cover; |
| | | z-index: -1; |
| | | } |
| | | } |
| | | |
| | | .com_header { |
| | | height: 40px; |
| | | display: flex; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | padding: 0 15px 0 13px; |
| | | position: relative; |
| | | |
| | | .title { |
| | | display: flex; |
| | | align-items: center; |
| | | font-weight: bold; |
| | | font-size: 16px; |
| | | background-image: -webkit-linear-gradient(top, |
| | | #ffffff 0%, |
| | | #c8ddff 66%, |
| | | #85b4ff 72%, |
| | | #74a9ff 100%); |
| | | -webkit-background-clip: text; |
| | | -webkit-text-fill-color: transparent; |
| | | |
| | | .icon { |
| | | width: 16px; |
| | | height: 16px; |
| | | margin-right: 14px; |
| | | } |
| | | } |
| | | |
| | | .tabs { |
| | | display: flex; |
| | | align-items: center; |
| | | font-size: 14px; |
| | | color: #d2e0ff; |
| | | |
| | | .separate { |
| | | width: 1px; |
| | | height: 14px; |
| | | background-color: #d2e0ff; |
| | | margin: 0 6px; |
| | | } |
| | | |
| | | .active { |
| | | color: #0094eb; |
| | | } |
| | | } |
| | | } |
| | | |
| | | .main_app { |
| | | width: 1920px; |
| | | height: 960px; |
| | | /* width: 100%; |
| | | height: 100vh; */ |
| | | background: #0b2539; |
| | | color: #FFFFFF; |
| | | position: relative; |
| | | z-index: -2; |
| | | font-size: 14px; |
| | | |
| | | .main_bg { |
| | | position: absolute; |
| | | left: 0; |
| | | top: 0; |
| | | width: 100%; |
| | | height: 100%; |
| | | object-fit: cover; |
| | | z-index: -1; |
| | | } |
| | | } |
| | | |
| | | .bg { |
| | | position: absolute; |
| | | left: 0; |
| | | top: 0; |
| | | width: 100%; |
| | | height: 100%; |
| | | object-fit: cover; |
| | | z-index: -1; |
| | | } |
| | | </style> |