翠屏区智慧广电示范区
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

2013 lines
74 KiB

<template>
<!-- 县级大屏 -->
<div class="eb-container" ref="appRef">
<MainTitle class="title" :title="title" :show-menu="false"></MainTitle>
<div class="left">
<div class="min-title">
<span>基本概况</span>
</div>
<div class="left-top">
<div class="top-top-one">
<div
class="top-one1"
v-for="(item, index) in baseInfoList"
:key="index"
>
<countTo
class="number"
:startVal="0"
:endVal="parseFloat(item.value)"
:decimals="2"
:duration="3000"
>
</countTo>
<img
class="img"
:src="
require(`../../assets/welcome/Frame-${
index + 1
}.png`)
"
alt="图片加载失败"
/>
<p class="title">{{ item.label }}</p>
</div>
</div>
<div class="top-icon-title">
<img
src="../../assets/welcome/sczzqs.png"
alt="图片加载失败"
/>
<span>生产总值趋势</span>
</div>
<!-- 图表 -->
<div class="top-chart" id="chartZone"></div>
</div>
<!-- 标题(广播电视) -->
<div class="min-title">
<span>广播电视</span>
</div>
<div class="left-bottom">
<div class="bottom-box">
<div
class="box-box"
v-for="(item, index) in radioList"
:key="index"
>
<div class="box-icon-title">
<img :src="item.icon" alt="图片加载失败" />
<span>{{ item.label }}</span>
</div>
<countTo
class="box-number"
:startVal="0"
:endVal="Number(item.value)"
:duration="3000"
>KM
</countTo>
</div>
</div>
</div>
</div>
<div class="right">
<!-- 快捷入口 -->
<div class="min-title">
<span>智慧应用</span>
</div>
<div class="enter">
<div
class="enter-item"
@click="jumpSystem(item)"
v-for="(item, index) in itemList"
:key="index"
>
<span>{{ item.menuName }}</span>
</div>
</div>
<!-- 标题(公共文化场所分布) -->
<div class="min-title">
<span>公共文化场所分布</span>
</div>
<!-- 公共文化场所分布 -->
<div class="public-culture">
<div class="pieChart" id="pieChart"></div>
<div class="pieContent">
<vueSeamlessScroll
:data="analysisInfo"
:class-option="activityOption"
class="scrollBox"
>
<div class="datalist">
<div
class="contentItem"
v-for="(item, index) in analysisInfo"
:key="index"
>
<div class="line">
<div
class="dataline"
:style="{
backgroundColor: colorList[index],
}"
></div>
<div class="defaultline"></div>
</div>
<span class="name">{{ item.label }}</span>
<span class="num">{{ item.value }}</span>
</div>
</div>
</vueSeamlessScroll>
</div>
</div>
<!-- 标题(各乡镇应急广播建设情况统计) -->
<div class="min-title">
<span>各乡镇应急广播建设情况统计</span>
</div>
<!-- 各乡镇应急广播建设情况统计 -->
<div class="emergency-broadcast" id="pieChart2"></div>
</div>
<img class="map-center" :src="require('@/assets/map.png')" />
<div class="page-bottom-bg"></div>
<div class="page-left-bg"></div>
<div class="page-right-bg"></div>
<Modal v-model="townModal" :footer-hide="true" width="1200">
<div class="turntable">
<div class="left"></div>
<div style="color: white">
<div class="page-left-left">
<img
src="../../assets/screenView/line.png"
alt=""
style="position: absolute; top: 270px; left: -100px"
/>
<div class="list">
<swiper :options="swiperOptions" ref="mySwiper">
<swiper-slide
v-for="(item, index) in menus"
:key="index"
class="item"
>
<div class="swiper-item">
{{ item.areaName }}
</div>
</swiper-slide>
</swiper>
</div>
</div>
</div>
<div class="right">
<div class="current">
<div
style="text-align: center; cursor: pointer"
@click="goTown"
>
<img
src="../../assets/ScreenView/currenttwon.png"
style="width: 70px; height: 60px"
/>
<div
style="
font-size: 30px;
font-weight: 700;
color: #fdb955;
margin-left: 10px;
"
>
{{ currentTwon.areaName }}
</div>
</div>
</div>
<div class="menu-container">
<div
style="text-align: center; cursor: pointer"
v-for="(item, index) in townData"
:key="index"
@click="toScreenPage(item)"
>
<img
src="../../assets/ScreenView/twon.png"
alt=""
style="width: 70px; height: 60px"
/>
<div
style="
font-size: 16px;
font-weight: bold;
color: #fdb955;
"
>
{{ item.areaName }}
</div>
</div>
</div>
</div>
</div>
</Modal>
<common-modal
v-model="appState"
:title="currentMenu.menuName"
width="600"
>
<div style="width: 100%; display: flex; flex-wrap: wrap">
<div
class="menu-item"
@click="toMenu(index)"
v-for="(item, index) in currentMenu.children"
:key="index"
>
<span>{{ item.menuItem }}</span>
</div>
</div>
</common-modal>
<common-modal
v-model="warringState"
:title="currentMenu.menuItem"
width="600"
>
<div style="width: 100%; display: flex; flex-wrap: wrap">
<div
class="menu-item"
@click="toWarring(item)"
v-for="(item, index) in currentMenu.children"
:key="index"
>
<span>{{ item.menuItem }}</span>
</div>
</div>
</common-modal>
</div>
</template>
<script>
import { useIndex } from "../../utils/utilsDramAdmin";
import MainTitle from "./components/MainTitle.vue";
import ThreeView from "./components/three/three-view.vue";
import Rotation3D from "@/utils/rotation3D";
import vueSeamlessScroll from "vue-seamless-scroll";
import { Swiper, SwiperSlide } from "vue-awesome-swiper";
import * as echarts from "echarts";
import { echartsFocus, echartsClear } from "@/utils/autoEcharts";
import CommonModal from "@/views/common-components/common-modal.vue";
export default {
name: "CountyScreen",
components: {
MainTitle,
ThreeView,
vueSeamlessScroll,
Swiper,
SwiperSlide,
CommonModal,
},
data() {
let self = this;
return {
title: "翠屏区智慧广电示范区",
warringState: false,
areaCode: window.$localStorage.getItem("areaCode"),
videoUrl: "/localImage/home/home.mp4",
logUrl: "/localImage/smartserver/yj.glb",
itemList: [
{
menuName: "公共服务",
children: [
{
menuItem: "广电公服",
routerPath: "/publicService",
},
{
menuItem: "文娱场所",
routerPath: "/culture-place",
},
{
menuItem: "政务服务",
routerPath: "/govService",
},
{
menuItem: "基础数据",
routerPath: "/smart-radio-basic-data",
},
// {
// menuItem: "应急数据",
// routerPath: "/emergency-data",
// },
],
},
{
menuName: "社会治理",
children: [
{
menuItem: "应急广播",
routerPath: "/emergencyScreen",
},
// {
// menuItem: "值班系统",
// routerPath: "/duty-system",
// },
{
menuItem: "视频监控",
routerPath: "/video-monitor",
},
{
menuItem: "烟火预警",
routerPath: "/emergency-extend",
},
// {
// menuItem: "周界预警",
// routerPath: "/perimeter-screen",
// },
{
menuItem: "人流预警",
isShowTwon: true,
children: [
{
menuItem: "清华街",
areaCode: "511502000001",
},
{
menuItem: "合江门",
areaCode: "511502000002",
},
],
},
{
menuItem: "车流预警",
isShowTwon: true,
children: [
{
menuItem: "合江门",
areaCode: "511502000003",
},
{
menuItem: "盐李路",
areaCode: "511502000004",
},
],
},
{
menuItem: "视频结构化",
routerPath: "/video-structuring",
},
],
},
{
menuName: "乡村振兴",
children: [
{
menuItem: "镇级",
routerPath: "/town-screen",
isShowTwon: true,
},
{
menuItem: "村级",
routerPath: "/village-screen",
isShowTwon: true,
},
{
menuItem: "乡村治理",
routerPath: "/village-governance-img",
isShowTwon: true,
},
{
menuItem: "乡村党建",
routerPath: "/party-screen",
},
{
menuItem: "网格管理",
routerPath: "/grid-manage",
isShowTwon: true,
},
],
},
{
menuName: "文博图旅",
children: [
{
menuItem: "文化馆",
routerPath: "/cultural-center",
},
{
menuItem: "博物馆",
routerPath: "/museum-center",
},
{
menuItem: "图书馆",
routerPath: "/library-center",
},
{
menuItem: "全域旅游",
routerPath: "/global-travel",
},
{
menuItem: "智慧旅游态势",
routerPath: "/smart-travel",
},
],
},
{
menuName: "媒体融合",
children: [
{
menuItem: "媒体融合",
routerPath: "/new-media",
},
{
menuItem: "三江翠屏",
routerPath: "/mediaBigScreen",
},
{
menuItem: "人人通",
routerPath: "/rrt-screen",
},
],
},
{
menuName: "平台应用",
children: [
{
menuItem: "视听资源",
url: "http://60.255.186.185:9024/cp-stzy/#/",
},
{
menuItem: "数据管理",
url: "http://60.255.186.185:9024/cp-web/#/",
},
{
menuItem: "运维运控",
url: "http://60.255.186.185:9999",
},
{
menuItem: "动态表单",
url: "http://60.255.186.185:9024/cp-form/#/",
},
],
},
],
baseInfoList: [],
radioList: [],
radioIconList: [
{
icon: require("@/assets/welcome/icon/gbz-icon.png"),
},
{
icon: require("@/assets/welcome/icon/gbz-icon.png"),
},
{
icon: require("@/assets/welcome/icon/gbz-icon.png"),
},
{
icon: require("@/assets/welcome/icon/gbz-icon.png"),
},
{
icon: require("@/assets/welcome/icon/gbz-icon.png"),
},
{
icon: require("@/assets/welcome/icon/gbz-icon.png"),
},
{
icon: require("@/assets/welcome/icon/gbz-icon.png"),
},
{
icon: require("@/assets/welcome/icon/gbz-icon.png"),
},
],
cTravelList: [],
analysisInfo: [], //公共文化列表
colorList: [
"#00ffff",
"#006ced",
"#ffe000",
"#ffa800",
"#ff5b00",
"#ff3000",
],
open: [false, false, false, false, false],
rotationInstance: null,
swiperOptions: {
on: {
slideChangeTransitionEnd: function () {
self.changeIndex(Number(this.realIndex));
},
touchEnd: function () {
self.changeIndex(Number(this.realIndex));
},
},
grabCursor: true,
mousewheel: true,
slideToClickedSlide: true,
direction: "vertical",
autoplay: false,
loop: false,
loopedSlides: 22,
effect: "coverflow",
slidesPerView: "auto",
centeredSlides: true,
observer: true, //修改swiper自己或子元素时,自动初始化swiper
observeParents: true, //修改swiper的父元素时,自动初始化swiper
coverflowEffect: {
rotate: 0,
stretch: 0,
depth: 66,
modifier: 2,
slideShadows: false,
},
},
menus: [],
currentTwon: {},
townModal: false,
townData: [],
currentType: "",
enterList: [
{
icon: require("@/assets/largeScreen/stzy.png"),
url: "http://60.255.186.185:9024/county-file/#/Login",
text: "视听资源",
},
{
icon: require("@/assets/largeScreen/sjgl.png"),
url: "http://60.255.186.185:9024/xy-web/",
text: "数据管理",
},
{
icon: require("@/assets/largeScreen/ywyk.png"),
url: "http://60.255.186.185:9999/login/toLogin",
text: "运维运控",
},
{
icon: require("@/assets/largeScreen/dtbd.png"),
url: "http://60.255.186.185:9024/county-form/",
text: "动态表单",
},
],
appState: false,
currentMenu: {},
};
},
computed: {
activityOption() {
return {
step: 0.4, // 数值越大速度滚动越快
limitMoveNum: this.analysisInfo.length, // 开始无缝滚动的数据量 this.dataList.length
hoverStop: true, // 是否开启鼠标悬停stop
direction: 2, // 0向下 1向上 2向左 3向右
openWatch: true, // 开启数据实时监控刷新dom
singleHeight: 0, // 单步运动停止的高度(默认值0是无缝不停止的滚动) direction => 0/1
singleWidth: 0, // 单步运动停止的宽度(默认值0是无缝不停止的滚动) direction => 2/3
waitTime: 1000, // 单步运动停止的时间(默认值1000ms)
};
},
},
mounted() {
const { calcRate, windowDraw } = useIndex(this.$refs.appRef);
calcRate();
windowDraw();
this.rotationInstance = new Rotation3D({
id: "#rotation3D",
farScale: 0.8,
// farScale: 1,
xRadius: 50, //x半径压缩
yRadius: 0, //y半径压缩
autoPlay: false,
autoPlayDelay: 6000,
});
// 基本概况
this.initDataInfo("countyBaseInfo", (data) => {
this.baseInfoList = data;
});
// 生产总值
this.initDataInfo("productionTrends", (data) => {
let y = data.map((item) => item.label);
let x = data.map((item) => Number(item.value));
this.queryProductionValue(x, y);
});
// 广电信息
this.initDataInfo("radioInformation", (data) => {
this.radioList = data.map((item, index) => {
item.icon = this.radioIconList[index].icon;
return item;
});
});
// 文化旅游
this.initDataInfo("culturalTourism", (data) => {
this.cTravelList = data;
});
// 文化场所
this.initDataInfo("PCTLocated", (data) => {
this.analysisInfo = data;
let x = data.map((item) => item.label);
let y = data.map((item) => Number(item.value));
this.initChartPie(x, y);
});
// 文化场所
this.initDataInfo("broadcastConstruction", (data) => {
let resData = data.map((item) => {
return {
name: item.label,
num: Number(item.value),
};
});
this.queryChart2(resData);
});
this.getTownMemu();
},
methods: {
toWarring(item) {
switch (this.currentType) {
case "person":
this.$router.push({
path: "/person-warring",
query: {
areaName: item.menuItem,
areaCode: item.areaCode,
},
});
break;
case "car":
this.$router.push({
path: "/car-warring",
query: {
areaName: item.menuItem,
areaCode: item.areaCode,
},
});
break;
default:
break;
}
},
jumpSystem(item) {
this.currentMenu = item;
this.appState = true;
},
// 获取数据
initDataInfo(type, callback) {
let params = {
page: 1,
pageSize: 100,
areaCode: this.areaCode,
type,
};
this.$http
.post("screen/getScreenSurveyPage", this.common.request(params))
.then((res) => {
if (res.data.code === 200) {
let data = res.data.data.records;
callback(data);
}
});
},
queryProductionValue(x, y) {
let myChart = echarts.init(document.getElementById("chartZone"));
var color = ["#80bdff", "#07f8a0"];
const dataX = y;
const dataBar = x;
const dataNowY = [10, 17, 13, 24, 15];
var option = {
color: color,
title: {
text: "单位:亿元",
textStyle: {
color: "#fff",
fontSize: 10,
},
},
tooltip: {
trigger: "axis",
backgroundColor: "rgba(33,56,77,1)",
borderColor: "rgba(33,56,77,1)",
textStyle: {
color: "#fff",
fontSize: 10,
},
axisPointer: {
lineStyle: {
color: "rgba(0,133,255,0)",
},
},
},
legend: {
right: "4%",
data: ["增长率", "生产总值"],
itemGap: 20,
itemWidth: 20,
itemHeight: 10,
textStyle: {
color: "#fff",
fontSize: 10,
},
},
grid: {
top: "20%",
left: "4%",
height: "80%",
width: "auto",
containLabel: true,
},
xAxis: {
type: "category",
boundaryGap: ["0", "20%"],
data: dataX,
axisLabel: {
// interval: 0,
textStyle: {
color: "#fff",
fontSize: 10,
},
},
axisLine: {
show: false,
},
axisTick: {
show: false, // 去除刻度线
},
},
yAxis: [
{
type: "value",
// min: 0,
// max: 200,
// interval: 50,
axisLabel: {
textStyle: {
color: "#fff",
fontSize: 10,
},
},
splitLine: {
show: true,
lineStyle: {
type: "dashed",
color: "rgba(255,255,255,0.1)",
},
},
axisTick: { show: false },
axisLine: { show: false },
},
{
// type: "value",
min: 0,
max: 50,
interval: 10,
axisLabel: {
show: false, // 不显示坐标轴上的文字
},
boundaryGap: ["0", "20%"],
axisTick: { show: false },
axisLine: { show: false },
splitLine: { show: false },
},
],
series: [
{
name: "Max",
type: "bar",
barGap: "-76.5%",
barWidth: "70%",
silent: true,
symbol: "path://M0,10 L10,10 C5.5,10 5.5,5 5,0 C4.5,5 4.5,10 0,10 z",
itemStyle: {
normal: {
color: "rgba(17, 24, 40, 0.1)",
borderWidth: 0,
borderColor: "rgba(17, 24, 40, 0.1)",
},
},
emphasis: {
itemStyle: {
borderWidth: 2,
borderColor: "rgba(19,255,241,1)",
},
},
// data: 250,
z: 9,
tooltip: {
show: false,
},
},
{
name: "生产总值",
type: "bar",
barWidth: "40%",
stack: "one",
itemStyle: {
color: new echarts.graphic.LinearGradient(
0,
0,
0,
1,
[
{
offset: 0,
color: "rgba(21,255,157, 0.1)",
},
{
offset: 1,
color: "rgba(21,255,157, 0.6)",
},
]
),
},
data: dataBar,
},
{
name: "",
type: "bar",
barWidth: "40%",
stack: "one",
itemStyle: {
normal: {
color: "rgba(21, 255, 157,1)",
},
},
data: [6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6],
tooltip: {
show: false,
},
},
// {
// name: "增长率",
// type: "line",
// yAxisIndex: 1,
// symbolSize: 8,
// // 设置拐点颜色以及边框
// itemStyle: {
// color: "rgba(255, 209, 92,1)",
// },
// data: dataNowY,
// },
],
};
myChart.setOption(option);
echartsFocus(myChart, dataNowY.length);
},
initChartPie(xdata, ydata) {
let myChart = echarts.init(document.getElementById("pieChart"));
let num = 0;
ydata.forEach((item) => {
num = num + Number(item);
});
let img =
"";
let data = [];
let color = this.colorList;
for (let i = 0; i < ydata.length; i++) {
data.push(
{
value: ydata[i],
name: xdata[i],
itemStyle: {
normal: {
borderWidth: 1,
shadowBlur: 20,
borderColor: color[i],
shadowColor: color[i],
},
},
}
// {
// value: 2,
// name: "",
// itemStyle: {
// normal: {
// label: {
// show: false,
// },
// labelLine: {
// show: false,
// },
// color: "rgba(0, 0, 0, 0)",
// borderColor: "rgba(0, 0, 0, 0)",
// borderWidth: 0,
// },
// },
// }
);
}
var seriesOption = [
{
name: "",
type: "pie",
clockWise: false,
center: ["50%", "50%"],
radius: [70, 84],
hoverAnimation: false,
itemStyle: {
normal: {
label: {
show: false,
position: "outside",
color: "#ddd",
formatter: function (params) {
var percent = 0;
var total = 0;
for (var i = 0; i < ydata.length; i++) {
total += ydata[i];
}
percent = (
(params.value / total) *
100
).toFixed(0);
if (params.name !== "") {
return (
"文化场所" +
params.name +
"\n" +
"\n" +
"占百分比:" +
percent +
"%"
);
} else {
return "";
}
},
},
labelLine: {
length: 30,
length2: 100,
show: true,
color: "#00ffff",
},
},
},
data: data,
},
];
let option = {
color: color,
title: [
{
text:
"{name|" +
num +
"个" +
"}\n{val|" +
"文化场所" +
"}",
top: "center",
left: "center",
textStyle: {
rich: {
name: {
fontSize: 18,
fontWeight: "bold",
color: "#fff",
padding: [0, 0, 5, 0],
},
val: {
fontSize: 14,
fontWeight: "bold",
color: "#fff",
padding: 0,
},
},
},
},
],
graphic: {
elements: [
{
type: "image",
z: 3,
style: {
image: img,
width: 110,
height: 110,
},
left: "center",
top: "center",
position: [100, 100],
},
],
},
tooltip: {
show: true,
},
legend: {
show: false,
},
toolbox: {
show: false,
},
series: seriesOption,
};
myChart.setOption(option);
echartsFocus(myChart, xdata.length);
},
// 各乡镇应急广播建设情况统计
queryChart2(data) {
var chartDom = document.getElementById("pieChart2");
var myChart = echarts.init(chartDom);
var option;
var xdata = data.map((v) => v.name);
var data = data.map((v) => v.num);
option = {
// backgroundColor: "rgba(2, 12, 44, 1)", //背景色
tooltip: {
trigger: "axis",
axisPointer: {
type: "shadow",
},
formatter: function (params) {
return (
params[0].name +
"<br>" +
"统计数 :" +
params[0].value
);
},
},
grid: {
left: "4%",
right: "4%",
top: "5%",
width: "auto",
height: "100%",
containLabel: true,
},
xAxis: {
data: xdata,
triggerEvent: true,
axisTick: {
show: false,
},
axisLine: {
show: false,
},
axisLabel: {
show: true,
// rotate: 45,
formatter: function (value) {
let txtArry = value.split("");
let rs = "";
for (let i = 0; i < txtArry.length; i++) {
rs += txtArry[i] + "\n"; // 在每个字后面加上换行符,使每个字都竖着显示
}
return rs;
},
textStyle: {
fontSize: 14,
color: "#fff",
// fontSize: 10,
// color: "rgba(255, 255, 255, 1)",
},
},
},
yAxis: {
triggerEvent: true,
splitLine: {
show: true,
lineStyle: {
type: "dashed",
color: "rgba(255,255,255,0.1)",
},
},
axisTick: {
show: false,
},
axisLine: {
show: false,
},
axisLabel: {
show: false,
textStyle: {
color: "#fff",
fontSize: 16,
// color: "rgba(255, 255, 255, 1)",
// fontSize: 12,
},
},
},
series: [
{
name: "订单数",
barMinHeight: 10,
type: "pictorialBar",
barCategoryGap: "60%",
symbol: "path://M0,10 L10,10 C5.5,10 5.5,5 5,0 C4.5,5 4.5,10 0,10 z",
itemStyle: {
normal: {
//渐变色
color: "rgb(215,210,34)",
},
},
data: data,
z: 10,
},
],
};
myChart.setOption(option);
echartsFocus(myChart, xdata.length);
},
toMenu(index) {
let item = this.currentMenu.children[index];
if (item.routerPath && !item.isShowTwon) {
this.$router.push(item.routerPath);
} else if (item.isShowTwon) {
console.log(item);
switch (item.menuItem) {
case "镇级":
this.currentType = "town";
this.townModal = true;
break;
case "村级":
this.currentType = "village";
this.townModal = true;
break;
case "乡村治理":
this.currentType = "governance";
this.townModal = true;
break;
case "网格管理":
this.currentType = "grid";
this.townModal = true;
break;
case "人流预警":
this.currentType = "person";
this.appState = false;
this.currentMenu = item;
this.warringState = true;
break;
case "车流预警":
this.currentType = "car";
this.appState = false;
this.currentMenu = item;
this.warringState = true;
break;
default:
break;
}
} else if (item.url) {
window.open(item.url);
}
},
goTown() {
if (this.currentType != "town") {
return;
}
if (this.currentTwon.areaName != "李庄镇") {
this.$message.info("除李庄镇外,其余尚未建设!");
return;
}
this.townModal = false;
this.$router.push({
name: "town-screen",
query: {
townName: this.currentTwon.areaName,
areaCode: this.currentTwon.areaCode,
},
});
},
toScreenPage(item) {
if (this.currentType == "person") {
this.$router.push({
name: "person-warring",
query: {
areaName: item.areaName,
areaCode: item.areaCode,
},
});
return;
}
if (this.currentType == "car") {
this.$router.push({
name: "car-warring",
query: {
areaName: item.areaName,
areaCode: item.areaCode,
},
});
return;
}
if (item.areaName != "高桥村") {
this.$message.info("除高桥村,其余尚未建设!");
return;
}
if (this.currentType == "village") {
this.$router.push({
name: "village-screen",
query: {
areaName: item.areaName,
areaCode: item.areaCode,
},
});
} else if (this.currentType == "governance") {
this.$router.push({
name: "village-governance-img",
query: {
areaName: item.areaName,
areaCode: item.areaCode,
},
});
} else if (this.currentType == "grid") {
this.$router.push({
name: "grid-manage",
query: {
areaName: item.areaName,
areaCode: item.areaCode,
},
});
}
this.townModal = false;
},
changeIndex(index) {
this.currentTwon = this.menus[index];
this.townData = [];
this.getVill(this.menus[index].areaCode);
},
getTownMemu() {
this.$http
.post(
"base/areaInfo/queryAreaInfoByParentId",
this.common.request({
parentCode: "511502000000",
hasOpen: "1",
})
)
.then((res) => {
if (res.data.code === 200) {
if (res.data.data && res.data.data[0]) {
this.menus = res.data.data;
this.currentTwon = this.menus[0];
this.getVill(this.menus[0].areaCode);
}
} else {
this.$Message.error(res.data.msg);
}
});
},
getVill(code) {
this.$http
.post(
"base/areaInfo/queryAreaInfoByParentId",
this.common.request({
parentCode: code,
hasOpen: "1",
})
)
.then((res) => {
if (res.data.code === 200) {
if (res.data.data && res.data.data[0]) {
this.townData = res.data.data;
}
} else {
this.$Message.error("查询数据失败");
}
})
.catch((err) => {
this.$Message.error("查询数据失败");
});
},
},
};
</script>
<style lang="less" scoped>
@import "../../styles/pbStyle.less";
@import "../../../static/css/rotation3D.css";
.menu-item {
cursor: pointer;
width: 100px;
height: 67px;
background: url("../../assets/largeScreen/enter-box.png") no-repeat;
background-size: 100% 100%;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
margin: 0 20px 20px 0;
span {
font-family: YouSheBiaoTiHei;
font-weight: 500;
font-size: 16px;
color: #ffffff;
}
}
.map-center {
position: fixed;
left: 50%;
top: 50%;
width: 1350px;
pointer-events: none;
transform: translate(-50%, -50%);
}
.eb-container {
width: 1920px;
height: 1080px;
transform: scale(var(--scale)) translate(-50%, -50%);
transform-origin: 0 0;
position: absolute;
left: 50%;
top: 50%;
background-image: url("../../assets/screenView/bg.png");
background-size: 100%;
.bg {
position: absolute;
top: 0;
left: 0;
width: 1920px;
height: 1080px;
background: url("../../assets/largeScreen/index-bg.png") no-repeat;
background-size: 100%;
z-index: -90;
}
.three-box {
position: absolute;
display: flex;
justify-content: center;
align-items: center;
left: 50%;
transform: translateX(-50% - 1.8px);
top: 200px;
width: 500px;
height: 300px;
}
.change-box {
position: absolute;
left: 50%;
transform: translateX(-50%- 4px);
top: 650px;
width: 89px;
height: 50px;
background: url("../../assets/largeScreen/quan.png") no-repeat;
background-size: 100%;
transform-style: preserve-3d;
animation: change 6s linear infinite;
}
@keyframes change {
0% {
transform: rotateX(45deg) translateX(-50%- 4px) scale(1);
}
25% {
transform: rotateX(45deg) translateX(-50%- 4px) scale(5);
}
50% {
transform: rotateX(45deg) translateX(-50%- 4px) scale(9);
}
75% {
transform: rotateX(45deg) translateX(-50%- 4px) scale(5);
}
100% {
transform: rotateX(45deg) translateX(-50%- 4px) scale(1);
}
}
.center-bottom-contain {
position: absolute;
width: 1100px;
height: 400px;
top: 450px;
left: 50%;
font-family: "YouSheBiaoTiHei";
transform: translateX(-50%- 2px);
.menu-name {
width: 100%;
height: 100%;
position: relative;
z-index: 10;
display: flex;
justify-content: center;
align-items: center;
background: url("../../../static/images/qiu.png") no-repeat;
background-size: 100% 100%;
font-family: "YouSheBiaoTiHei";
font-style: normal;
font-size: 28px;
}
.children-list {
width: 0;
height: 0;
top: 73px;
left: 73px;
position: absolute;
.children-item {
width: 100px;
height: 100px;
display: flex;
justify-content: center;
align-items: center;
background: url("../../assets/largeScreen/qiu.png") no-repeat;
background-size: 100%;
transition: 0.2s 0.1s;
position: absolute;
font-size: 23px;
z-index: 2;
top: -50px;
left: 0;
}
}
.children-list.open {
& .children-item.oy-menu-item_1 {
left: -170px;
top: 0px;
}
& .children-item.oy-menu-item_2 {
left: -152px;
top: -106px;
}
& .children-item.oy-menu-item_3 {
left: -92px;
top: -206px;
}
& .children-item.oy-menu-item_4 {
left: 0px;
top: -256px;
}
& .children-item.oy-menu-item_5 {
left: 92px;
top: -206px;
}
& .children-item.oy-menu-item_6 {
left: 152px;
top: -106px;
}
& .children-item.oy-menu-item_7 {
left: 170px;
top: 0px;
}
}
}
// 标题样式
.min-title {
width: 348px;
height: 38px;
background-image: url("../../assets/largeScreen/title-bg-310.png");
background-size: 100% 100%;
padding-left: 40px;
display: flex;
align-items: center;
margin-bottom: 10px;
span {
font-family: "ShiShangZhongHeiJianTi";
font-style: normal;
font-weight: 400;
font-size: 18px;
/* identical to box height */
display: inline-block;
color: #ffffff;
// margin-left: 28px;
text-shadow: 0px 0px 4px #83e1ff;
}
}
.left {
position: absolute;
top: 90px;
left: 58px;
width: 348px;
height: 920px;
.min-title {
span {
}
}
// 南溪区基本介绍
.left-top {
width: 348px;
height: 478px;
background: url("../../assets/welcome/left-top.png") no-repeat;
background-size: 100%;
box-sizing: border-box;
padding: 12px 0 8px 0;
margin-bottom: 16px;
// 内部样式开始
.number {
font-family: "YouSheBiaoTiHei";
font-style: normal;
font-weight: 400;
font-size: 20px;
line-height: 26px;
/* identical to box height */
display: flex;
align-items: flex-end;
text-align: center;
background: linear-gradient(180deg, #ffffff 0%, #a7ddff 100%);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
text-fill-color: transparent;
}
.img {
width: 72px;
height: 64px;
}
.title {
font-family: "PingFang SC";
font-style: normal;
font-weight: 400;
font-size: 14px;
line-height: 20px;
/* identical to box height */
display: flex;
align-items: flex-end;
text-align: center;
background: linear-gradient(180deg, #ffffff 0%, #a7ddff 100%);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
text-fill-color: transparent;
}
//内部样式结束
.top-top-one {
width: 100%;
height: 260px;
display: flex;
align-items: space-between;
justify-content: space-evenly;
flex-wrap: wrap;
.top-one1 {
width: 150px;
height: 126px;
background: url("../../assets/welcome/box.png") no-repeat;
background-size: 100%;
display: flex;
flex-direction: column;
justify-content: space-evenly;
align-items: center;
}
}
.top-icon-title {
width: 108px;
height: 22px;
// margin-top: 22px;
margin: 12px 0 0 16px;
display: flex;
align-items: center;
img {
width: 20px;
height: 20px;
}
span {
margin-left: 4px;
font-family: "Source Han Sans CN";
font-style: normal;
font-weight: 500;
font-size: 14px;
line-height: 22px;
color: #b4c0cc;
}
}
// 图表
.top-chart {
width: 319px;
height: 157px;
margin-left: 12px;
// .chartZone {
// width: 319px;
// height: 157px;
// }
}
}
// 广播电视
.left-bottom {
width: 348px;
height: 335px;
box-sizing: border-box;
// padding: 20px 14px 20px 12px;
display: flex;
flex-direction: column;
justify-content: space-evenly;
background: url("../../assets/welcome/gbds-bg.png") no-repeat;
background-size: 100% 100%;
.bottom-box {
display: flex;
justify-content: space-between;
align-items: space-between;
flex-wrap: wrap;
width: 100%;
height: 100%;
padding: 10px;
.box-box {
width: 154px;
height: 52px;
display: flex;
justify-content: center;
flex-direction: column;
box-sizing: border-box;
padding-left: 23px;
background: url("../../assets/welcome/gb-icon.png")
no-repeat;
background-size: 100%;
.box-icon-title {
width: 100%;
height: 20px;
display: flex;
align-items: center;
img {
width: 14px;
height: 14px;
}
span {
margin-left: 10px;
font-family: "PingFang SC";
font-style: normal;
font-weight: 900;
font-size: 13px;
line-height: 20px;
/* identical to box height */
display: flex;
align-items: center;
color: #ffffff;
}
}
.box-number {
font-family: "PingFang SC";
font-style: normal;
font-weight: 700;
font-size: 16px;
line-height: 22px;
display: flex;
align-items: center;
text-align: right;
color: #ffffff;
text-shadow: 0px 0px 4px #00a3ff;
}
}
}
}
}
.right {
position: absolute;
top: 90px;
right: 58px;
width: 348px;
height: 920px;
// 文化旅游
.cultural-tourism {
display: flex;
flex-direction: column;
justify-content: space-evenly;
width: 348px;
height: 174px;
margin-bottom: 16px;
background: url("../../assets/welcome/whlv-bg.png") no-repeat;
background-size: 100%;
.cultural-content {
display: flex;
justify-content: space-evenly;
flex-wrap: wrap;
align-items: space-between;
width: 100%;
height: 100%;
.content-box {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
width: 103px;
height: 73px;
.box-number {
font-family: "Furore";
font-style: normal;
font-weight: 400;
font-size: 24px;
line-height: 28px;
/* identical to box height */
text-align: center;
color: #ffffff;
text-shadow: 0px 0px 8px #1e85ff;
}
.box-title {
font-family: "PingFang SC";
font-style: normal;
font-weight: 400;
font-size: 14px;
line-height: 20px;
/* identical to box height */
text-align: center;
color: #ffffff;
}
}
}
}
// 快捷入口
.enter {
width: 348px;
height: 174px;
background: url("../../assets/welcome/whlv-bg.png") no-repeat;
background-size: 100%;
display: flex;
justify-content: space-between;
align-items: space-between;
flex-wrap: wrap;
padding: 10px 10px;
margin-bottom: 10px;
.enter-item {
cursor: pointer;
width: 100px;
height: 67px;
background: url("../../assets/largeScreen/enter-box.png")
no-repeat;
background-size: 100% 100%;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
span {
font-family: YouSheBiaoTiHei;
font-weight: 500;
font-size: 16px;
color: #ffffff;
}
}
}
// 公共文化场所分布
.public-culture {
display: flex;
flex-direction: column;
justify-content: space-evenly;
align-items: center;
width: 348px;
height: 374px;
background: url("../../assets/welcome/ggwhcs-bg.png") no-repeat;
background-size: 100%;
margin-bottom: 16px;
.pieChart {
width: 348px;
height: 200px;
}
.pieContent {
width: 335px;
height: 130px;
display: flex;
align-items: center;
flex-wrap: wrap;
justify-content: space-between;
.scrollBox {
// 内容两排显示
overflow: hidden;
}
.datalist {
width: 453px;
height: 130px;
display: flex;
justify-content: space-evenly;
align-items: center;
align-content: space-evenly;
flex-wrap: wrap;
.contentItem {
width: 145px;
height: 55px;
// margin-bottom: 16px;
margin-right: 6px;
display: flex;
justify-content: center;
flex-direction: column;
cursor: pointer;
.line {
display: flex;
.dataline {
height: 4px;
width: 24px;
margin-right: 5px;
// background-color: #19cd17;
border-radius: 2px;
}
.defaultline {
height: 4px;
flex: 1;
background-color: #1b424f;
border-radius: 2px;
}
}
.name {
font-family: "PingFang SC";
font-size: 14px;
font-weight: 400;
line-height: 20px;
letter-spacing: 0em;
color: #ffffff;
text-align: left;
margin: 4px 0 2px;
}
.num {
font-family: "Furore";
font-size: 20px;
font-weight: 400;
line-height: 23px;
letter-spacing: 0em;
color: #ffffff;
// text-align: center;
}
}
}
}
}
// 各乡镇应急广播建设情况统计
.emergency-broadcast {
width: 348px;
height: 210px;
background: url("../../assets/welcome/qktj-bg.png") no-repeat;
background-size: 100% 100%;
}
}
}
.turntable {
display: flex;
overflow: hidden;
width: 100%;
height: 600px;
background-image: url("../../assets/ScreenView/turntable.png");
background-size: 100% 100%;
background-repeat: no-repeat;
border: 1px solid #8eddff;
border-radius: 8px;
.blue {
color: #01dbff;
}
.orange {
color: #ffa901;
}
.cyan {
color: #01f4ba;
}
.purple {
color: #d505dc;
}
.left {
margin-top: 50px;
margin-left: 70px;
width: 200px;
height: 80%;
}
.right {
position: absolute;
right: 50px;
top: 20px;
width: 340px;
height: 90%;
display: flex;
flex-direction: column;
justify-content: space-between;
.current {
width: 100%;
height: 150px;
border-bottom: 2px dashed #ffd28f;
display: flex;
align-items: center;
justify-content: center;
> div {
width: 100%;
display: flex;
justify-content: center;
align-items: center;
}
}
.menu-container {
background-color: transparent !important;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
width: 100%;
height: 70%;
overflow: hidden;
overflow-y: auto;
&::-webkit-scrollbar {
display: none;
}
> div {
width: 45%;
}
}
}
}
.page-left-left {
position: absolute;
top: 0;
left: 450px;
height: 100%;
width: 373px;
z-index: 11;
}
.list {
font-family: "YouSheBiaoTiHei";
width: 230px;
height: 700px;
/*padding-top: 22px;*/
overflow: hidden;
margin-top: 80px;
.swiper-container {
height: 60% !important;
overflow: hidden;
.item {
height: 100px !important;
line-height: 100px;
color: #f5f5f5;
font-size: 40px;
/*margin-top: 60px;*/
/*margin-bottom: 60px;*/
letter-spacing: 1px;
.swiper-item {
display: flex;
justify-content: left;
align-items: flex-end;
flex-direction: column;
}
}
}
}
//选中时swiper-item的样式
/deep/ .swiper-slide-active {
font-size: 40px !important;
background: linear-gradient(180deg, #fff5d3 0%, #ffd056 100%),
linear-gradient(0deg, #ffffff, #ffffff);
/*background-image:-webkit-linear-gradient(bottom,red,#fd8403,yellow);*/
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
}
/deep/ .ivu-modal-close {
margin: 10px 10px 0 0;
.ivu-icon-ios-close-empty {
color: #fff !important;
font-size: 36px !important;
}
}
/deep/ .ivu-modal-content {
background-color: transparent !important;
}
</style>