diff --git a/package.json b/package.json
index f646f014c..5e5d0f947 100644
--- a/package.json
+++ b/package.json
@@ -22,6 +22,7 @@
"babel-eslint": "^8.0.1",
"babel-plugin-component": "^1.1.1",
"echarts": "^5.2.2",
+ "echarts-gl": "^2.0.9",
"element-theme": "^2.0.1",
"element-ui": "^2.13.0",
"file-saver": "^2.0.5",
diff --git a/src/assets/img/shuju/3d-pid-bg.png b/src/assets/img/shuju/3d-pid-bg.png
new file mode 100644
index 000000000..4519b38e8
Binary files /dev/null and b/src/assets/img/shuju/3d-pid-bg.png differ
diff --git a/src/assets/scss/modules/visual/search_1.scss b/src/assets/scss/modules/visual/search_1.scss
index 55aaef76f..ffb46b67f 100644
--- a/src/assets/scss/modules/visual/search_1.scss
+++ b/src/assets/scss/modules/visual/search_1.scss
@@ -24,6 +24,7 @@
display: flex;
align-items: center;
margin-left:40px;
+ z-index: 10;
.second-select {
diff --git a/src/assets/scss/modules/visual/shijianchulifenxi.scss b/src/assets/scss/modules/visual/shijianchulifenxi.scss
index bd9655728..ca099bed4 100644
--- a/src/assets/scss/modules/visual/shijianchulifenxi.scss
+++ b/src/assets/scss/modules/visual/shijianchulifenxi.scss
@@ -21,8 +21,8 @@
}
.l_bottom {
- height: calc(100vh - 200px - 355px);
- margin-top: 20px;
+ height: calc(100vh - 200px - 365px);
+ margin-top: 0;
}
}
@@ -35,25 +35,7 @@
}
.l_bottom {
- .bottom_label {
- position: relative;
- padding-left: 40px;
- font-size: 16px;
- font-weight: 500;
- color: #fff;
- }
- .bottom_label::after {
- content: '';
- position: absolute;
- top: 50%;
- left: 20px;
- width: 12px;
- height: 12px;
- box-sizing: border-box;
- margin-top: -6px;
- background: #2865fa;
- border-radius: 50%;
- }
+
> span {
font-size: 18px;
font-family: PingFang SC;
@@ -66,6 +48,26 @@
}
}
+.bottom_label {
+ position: relative;
+ padding-left: 40px;
+ font-size: 16px;
+ font-weight: 500;
+ color: #fff;
+}
+.bottom_label::after {
+ content: '';
+ position: absolute;
+ top: 50%;
+ left: 20px;
+ width: 12px;
+ height: 12px;
+ box-sizing: border-box;
+ margin-top: -6px;
+ background: #2865fa;
+ border-radius: 50%;
+}
+
.g-r {
.m-tb {
diff --git a/src/views/components/resiSearch.vue b/src/views/components/resiSearch.vue
index ddbd29fab..78da43f1d 100644
--- a/src/views/components/resiSearch.vue
+++ b/src/views/components/resiSearch.vue
@@ -173,6 +173,7 @@
size="small"
clearable
class="resi-cell-select"
+ :collapse-tags="n.multiSelect == 1 ? true : false"
:multiple="n.multiSelect == 1 ? true : false"
>
` +
+ // `` +
+ // `${bfb}%`
+ // )
+ // }
+ }
+ },
+ xAxis3D: {
+ min: -1,
+ max: 1
+ },
+ yAxis3D: {
+ min: -1,
+ max: 1
+ },
+ zAxis3D: {
+ min: -1,
+ max: 1
+ },
+ grid3D: {
+ show: false,
+ boxHeight: boxHeight, // 圆环的高度
+ viewControl: {
+ // 3d效果可以放大、旋转等,请自己去查看官方配置
+ alpha, // 角度
+ beta: -40,
+ distance, // 调整视角到主体的距离,类似调整zoom
+ rotateSensitivity: 0, // 设置为0无法旋转
+ zoomSensitivity: 0, // 设置为0无法缩放
+ panSensitivity: 0, // 设置为0无法平移
+ autoRotate: false // 自动旋转
+ }
+ },
+ series: series
+ }
+ return option
+}
+
+/**
+ * 生成扇形的曲面参数方程,用于 series-surface.parametricEquation
+ */
+const 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) {
+ isSelected = false
+ }
+ // 通过扇形内径/外径的值,换算出辅助参数 k(默认值 1/3)
+ 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: function (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: function (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: function (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
+ }
+ return Math.sin(v) > 0 ? 1 * h * 0.1 : -1
+ }
+ }
+}
+
+/**
+ * 获取3d丙图的最高扇区的高度
+ */
+const getHeight3D = (series, height) => {
+ series.sort((a, b) => {
+ return b.pieData.value - a.pieData.value
+ })
+ return (height * 25) / series[0].pieData.value
+}
+
+/**
+ * 格式化浮点数
+ */
+const fomatFloat = (num, n) => {
+ let f = parseFloat(num)
+ if (isNaN(f)) {
+ return false
+ }
+ f = Math.round(num * Math.pow(10, n)) / Math.pow(10, n) // n 幂
+ let s = f.toString()
+ let rs = s.indexOf('.')
+ // 判定如果是整数,增加小数点再补0
+ if (rs < 0) {
+ rs = s.length
+ s += '.'
+ }
+ while (s.length <= rs + n) {
+ s += '0'
+ }
+ return s
+}
+
+export { getPie3D, getParametricEquation }
\ No newline at end of file
diff --git a/src/views/modules/visual/communityGovern/shijianchuli/lineOption copy.js b/src/views/modules/visual/communityGovern/shijianchuli/lineOption copy.js
new file mode 100644
index 000000000..04b4f9503
--- /dev/null
+++ b/src/views/modules/visual/communityGovern/shijianchuli/lineOption copy.js
@@ -0,0 +1,86 @@
+import * as echarts from 'echarts'
+export function lineOption () {
+
+ return {
+ tooltip: {
+ trigger: 'axis',
+ axisPointer: {
+ type: 'cross',
+ label: {
+ backgroundColor: '#6a7985'
+ }
+ }
+ },
+ xAxis: {
+ type: 'category',
+ // boundaryGap: false,
+ axisLabel: {
+ color: '#8ec7dc',
+ fontSize: 16
+ },
+ axisTick: {
+ show: false
+ },
+ axisLine: {
+ lineStyle: {
+ color: '#0c4b59'
+ }
+ }
+ },
+ yAxis: {
+ nameTextStyle: {
+ color: '#8ec7dc',
+ fontSize: 18
+ },
+ splitNumber: 4,
+ minInterval: 1,
+ show: true,
+ type: 'value',
+ axisLabel: {
+ color: '#8ec7dc',
+ fontSize: 18
+ },
+ axisTick: {
+ show: false
+ },
+ splitLine: {
+ lineStyle: {
+ color: ['#145968'],
+ type: 'dotted'
+ }
+ },
+ axisLine: {
+ show: true,
+ symbol: ['none', 'arrow'],
+ symbolOffset: [0, 15],
+ lineStyle: {
+ color: '#0c4b59'
+ }
+ }
+ },
+ series: [
+ {
+ name: '项目数',
+ type: 'line',
+ smooth: true,
+ barWidth: 15,
+ areaStyle: {},
+ itemStyle: {
+ color: new echarts.graphic.LinearGradient(
+ 0, 1, 0, 0,
+ [
+ { offset: 0, color: 'rgba(121, 55, 255, 0)' },
+ { offset: 1, color: '#6339FF' }
+ ]
+ )
+ }
+ },
+ // {
+ // data: [820, 932, 901, 934, 1290, 1330, 1320],
+ // type: 'line',
+ // areaStyle: {}
+ // }
+ ]
+
+ }
+}
diff --git a/src/views/modules/visual/communityGovern/shijianchuli/lineOption.js b/src/views/modules/visual/communityGovern/shijianchuli/lineOption.js
index 04b4f9503..d02e4b20b 100644
--- a/src/views/modules/visual/communityGovern/shijianchuli/lineOption.js
+++ b/src/views/modules/visual/communityGovern/shijianchuli/lineOption.js
@@ -1,4 +1,11 @@
import * as echarts from 'echarts'
+let circleList = [
+ 'image://',
+ 'image://'
+]
+let className = ['1号停车场', '2号停车场', '3号停车场', '4号停车场', '5号停车场', '6号停车场', '7号停车场']
+let serviceCount = [50, 28, 17, 38, 90, 73, 39]
+
export function lineOption () {
return {
@@ -11,6 +18,13 @@ export function lineOption () {
}
}
},
+ // grid: {
+ // left: '5%',
+ // right: '5%',
+ // bottom: '5%',
+ // top: '10%',
+ // containLabel: true
+ // },
xAxis: {
type: 'category',
// boundaryGap: false,
@@ -25,7 +39,8 @@ export function lineOption () {
lineStyle: {
color: '#0c4b59'
}
- }
+ },
+ // data: className
},
yAxis: {
nameTextStyle: {
@@ -58,29 +73,82 @@ export function lineOption () {
}
}
},
+ // series: [
+ // {
+ // name: '项目数',
+ // type: 'line',
+ // smooth: true,
+ // barWidth: 15,
+ // areaStyle: {},
+ // itemStyle: {
+ // color: new echarts.graphic.LinearGradient(
+ // 0, 1, 0, 0,
+ // [
+ // { offset: 0, color: 'rgba(121, 55, 255, 0)' },
+ // { offset: 1, color: '#6339FF' }
+ // ]
+ // )
+ // }
+ // },
+ // // {
+ // // data: [820, 932, 901, 934, 1290, 1330, 1320],
+ // // type: 'line',
+ // // areaStyle: {}
+ // // }
+ // ]
series: [
{
- name: '项目数',
- type: 'line',
- smooth: true,
- barWidth: 15,
- areaStyle: {},
- itemStyle: {
- color: new echarts.graphic.LinearGradient(
- 0, 1, 0, 0,
- [
- { offset: 0, color: 'rgba(121, 55, 255, 0)' },
- { offset: 1, color: '#6339FF' }
- ]
- )
- }
+ name: '',
+ type: 'bar',
+ zlevel: 1,
+ itemStyle: {
+
+ normal: {
+ barBorderRadius: 0,
+ color: function (params) {
+ // 大于等于50%的是黄色 反之为蓝色
+ var colorList = [
+ ['rgba(252, 210, 152, .2)', 'rgba(252, 210, 152, 1)'],
+ ['rgba(36, 253, 231, .2)', 'rgba(36, 253, 231, 1)'],
+ ];
+ var colorItem
+
+ colorItem = colorList[1];
+
+ // 设置线条渐变色
+ return new echarts.graphic.LinearGradient(0, 1, 0, 0, [{
+ offset: 0,
+ color: colorItem[0]
+ },
+ {
+ offset: 1,
+ color: colorItem[1]
+ }
+ ], false);
+ }
+
+ },
+ },
+ barWidth: 4,
+ // data: serviceCount
+ },
+
+ {
+ name: 'XXX',
+ type: 'pictorialBar',
+ symbol: function (params, value) {
+ // 设置图片
+
+ return circleList[1]
},
- // {
- // data: [820, 932, 901, 934, 1290, 1330, 1320],
- // type: 'line',
- // areaStyle: {}
- // }
+ symbolPosition: 'end',
+ symbolSize: [30, 30],
+ symbolOffset: [0, -12],
+ z: 20,
+ // data: serviceCount
+ }
]
+
}
}
diff --git a/src/views/modules/visual/communityGovern/shijianchuli/pieOption copy.js b/src/views/modules/visual/communityGovern/shijianchuli/pieOption copy.js
new file mode 100644
index 000000000..5eb83badb
--- /dev/null
+++ b/src/views/modules/visual/communityGovern/shijianchuli/pieOption copy.js
@@ -0,0 +1,183 @@
+
+export function pieOption (_charts) {
+const center= ['50%', '170px']
+ return {
+ title: {
+ text: '0',
+ top: 140,
+ left: 'center',
+ textStyle: {
+ width: '100%',
+ fontSize: 32,
+ color: '#FFFFFF',
+ fontWeight: 400
+ },
+ itemGap: 5,
+ subtext: '总数',
+ subtextStyle: {
+ fontSize: 20,
+ color: '#fff',
+ fontWeight: 400
+ }
+ },
+ tooltip: {
+ show: false
+ },
+ // legend: {
+ // top: 350,
+ // bottom: 0,
+ // itemWidth: 20,
+ // itemHeight: 10,
+ // textStyle: {
+ // color: '#D2E7FF',
+ // fontSize: 16,
+ // lineHeight: 20,
+ // },
+
+ // },
+ series: [
+ // 外侧圆环
+ {
+ type: 'pie',
+ // 起始刻度的角度,默认为 90 度,即圆心的正上方。0 度为圆心的正右方。
+ startAngle: 0,
+ hoverAnimation: false,
+ // tooltip: {
+ // },
+ center: center,
+ radius: ['58%', '58.3%'],
+ label: {
+ normal: {
+ show: false
+ }
+ },
+ labelLine: {
+ normal: {
+ show: false
+ }
+ },
+ data: [{
+ value: 360,
+ itemStyle: {
+ normal: {
+ color: 'rgba(40, 101, 250, 0)',
+ width:0,
+ borderColor: 'rgba(40, 101, 250, 0.5)',
+ borderWidth: 1,
+ borderType: 'dotted'
+ }
+ }
+ }
+ ]
+ },
+
+ // 突出的
+ {
+ hoverAnimation: false,
+ // name: 'Access From',
+ type: 'pie',
+ center: center,
+ radius: ['35%', '48%'],
+ avoidLabelOverlap: false,
+ // top: top + '%',
+ // height: '80%',
+ selectedMode: 'single',
+ left: 'center',
+ width: 400,
+ label: {
+ // show: false,
+ position: 'outside',
+ alignTo: 'edge',
+ // formatter: '{a|{c}}\n\n{name|{b}}',
+ formatter: '{a|{c}%}\n{r|}\n{name|{b}}',
+ minMargin: 5,
+ edgeDistance: 1,
+ lineHeight: 15,
+ color: '#fff',
+ fontSize: 12,
+ // distanceToLabelLine: -60,
+ rich: {
+ name: {
+ padding: [0, 6, 0, 6]
+ },
+ a: {
+ fontSize: 30,
+ color: '#fff',
+ padding: [0, 6, 6, 6]
+ },
+ r: {
+ backgroundColor: 'auto',
+ borderRadius: 6,
+ width: 6,
+ height: 6,
+ // padding: [3, 3, 0, -12]
+ }
+ }
+ },
+ labelLine: {
+ show: false,
+ smooth: 0.2,
+ length: 30,
+ length2: 0,
+ maxSurfaceAngle: 80
+ },
+ labelLayout: function (params) {
+
+ const isLeft = params.labelRect.x < _charts.getWidth() / 2;
+ const points = params.labelLinePoints;
+ // Update the end point.
+ if (points) {
+ points[2][0] = isLeft
+ ? params.labelRect.x
+ : params.labelRect.x + params.labelRect.width;
+ }
+
+ return {
+ labelLinePoints: points
+ };
+ },
+ itemStyle: {
+ color:function(params) {
+ //自定义颜色
+ var colorList = [ '#FAC126', '#3DDA83'];
+ return colorList[params.dataIndex]
+ }
+ },
+ data: [],
+
+ },
+ // 中间圆环
+ {
+ type: 'pie',
+ // 起始刻度的角度,默认为 90 度,即圆心的正上方。0 度为圆心的正右方。
+ startAngle: 0,
+ hoverAnimation: false,
+ center: center,
+ // tooltip: {
+ // },
+ radius: ['0%', '25%'],
+ label: {
+
+ show: false
+
+ },
+ labelLine: {
+
+ show: false
+
+ },
+ data: [{
+ value: 360,
+ itemStyle: {
+ normal: {
+ color: 'rgba(8, 37, 134, 1)',
+
+ }
+ }
+ }
+ ]
+ },
+ ]
+
+ }
+}
diff --git a/src/views/modules/visual/communityGovern/shijianchuli/shijianchulifenxi copy 2.vue b/src/views/modules/visual/communityGovern/shijianchuli/shijianchulifenxi copy 2.vue
new file mode 100644
index 000000000..8ec4d06f2
--- /dev/null
+++ b/src/views/modules/visual/communityGovern/shijianchuli/shijianchulifenxi copy 2.vue
@@ -0,0 +1,328 @@
+
+
+ 事件处理分析
+
+
+
+
+ | {{ item }} |
---|---|
+ | |
{{ item }}
-
- {{ btn }}
- {{ item.name }}
+ {{ btn }}
+ {{ item.name }}
![]() ![]() ![]() ![]() ![]() ![]() |