| | |
| | | <template> |
| | | <div class="connectivity"> |
| | | <el-row> |
| | | <el-button type="primary" size="mini">绘制线段</el-button> |
| | | <el-button type="primary" size="mini">截断面分析</el-button> |
| | | <el-button type="primary" size="mini">清除</el-button> |
| | | </el-row> |
| | | <el-table |
| | | :data="tableData" |
| | | height="250" |
| | | border |
| | | style="width: 100%"> |
| | | <el-table-column |
| | | prop="date" |
| | | label="管线名称" |
| | | width="180"> |
| | | </el-table-column> |
| | | <el-table-column |
| | | prop="name" |
| | | label="管线类型" |
| | | width="180"> |
| | | </el-table-column> |
| | | <el-table-column |
| | | prop="address" |
| | | label="操作"> |
| | | </el-table-column> |
| | | </el-table> |
| | | </div> |
| | | <div class="connectivity"> |
| | | <el-row> |
| | | <el-button type="primary" @click="drawLine" size="mini" title="地图上绘制要进行分析截断面的线">绘制线段</el-button> |
| | | <el-button type="primary" @click="jdmQuery" size="mini" title="截断面分析">截断面分析</el-button> |
| | | <el-button type="primary" @click="jdmClear" size="mini" title="清除截断面分析结果">清除</el-button> |
| | | </el-row> |
| | | <div slot="header" class="fixed-style"> |
| | | <span>管段查询结果</span> |
| | | </div> |
| | | <el-table class="tableBox" :data="tableData" height="150" max-height="200" highlight-current-row style="width: 100%" size="mini"> |
| | | <el-table-column prop="mediumtype" label="介质类型" :show-overflow-tooltip="true"></el-table-column> |
| | | <el-table-column prop="x" label="断面(经度)" :show-overflow-tooltip="true" width="80"></el-table-column> |
| | | <el-table-column prop="y" label="断面(纬度)" :show-overflow-tooltip="true" width="80"></el-table-column> |
| | | <el-table-column prop="z" label="断面(高程)" :show-overflow-tooltip="true" width="80"></el-table-column> |
| | | <el-table-column prop="spacing" label="间距(m)" width="80"></el-table-column> |
| | | </el-table> |
| | | <span class="fixed-style">断面图</span> |
| | | <span v-show="!myChartShow" style="color: #909399;font-size: 12px;height: 200px;display: block;text-align: center;line-height: 200px">暂无数据</span> |
| | | <div v-show="myChartShow" id="echarts_box" ref="myChart" style="width:350px;height:200px;margin: 0 auto"></div> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | import eventBus from '../../../../../eventBus' |
| | | import mapApi from '../../../../../api/mapApi' |
| | | import DrawLine from '../../../../plugin/DrawLine' |
| | | |
| | | export default { |
| | | name: 'CrossSectional', |
| | | data () { |
| | | return { |
| | | tableData: [{ |
| | | date: '2016-05-02', |
| | | name: '王小虎', |
| | | address: '上海市普陀区金沙江路 1518 弄' |
| | | }, { |
| | | date: '2016-05-04', |
| | | name: '王小虎', |
| | | address: '上海市普陀区金沙江路 1517 弄' |
| | | }, { |
| | | date: '2016-05-01', |
| | | name: '王小虎', |
| | | address: '上海市普陀区金沙江路 1519 弄' |
| | | }, { |
| | | date: '2016-05-03', |
| | | name: '王小虎', |
| | | address: '上海市普陀区金沙江路 1516 弄' |
| | | }] |
| | | measure: null, |
| | | myChart: null, |
| | | options: [], |
| | | echartsList: [], |
| | | myChartShow: false, |
| | | linkPipeline: [], |
| | | // 横断面 管段查询结果 的table表格数据 |
| | | tableData: [], |
| | | hdmParam: null |
| | | } |
| | | }, |
| | | mounted () { |
| | | // 初始化echarts图表 |
| | | this.myChart = this.$echarts.init(this.$refs.myChart) |
| | | // 使用 DrwLine方法 |
| | | eventBus.$on('draw-hdm-line', (points) => { |
| | | this.getHdmPoint(points) |
| | | }) |
| | | }, |
| | | methods: { |
| | | // 横断面 线段绘制 |
| | | drawLine () { |
| | | if (this.measure === null) { |
| | | this.measure = new DrawLine(window.map) |
| | | } |
| | | this.measure.destory() |
| | | this.measure.init() |
| | | }, |
| | | // 绘制的横断面 线段数据获取 |
| | | async getHdmPoint (line) { |
| | | // 横断面数据 |
| | | this.hdmParam = { |
| | | x1: line[0].lng, |
| | | y1: line[0].lat, |
| | | x2: line[1].lng, |
| | | y2: line[1].lat |
| | | } |
| | | }, |
| | | // 横断面 数据请求 |
| | | async jdmQuery () { |
| | | this.tableData = [] |
| | | if (this.hdmParam == null) { |
| | | this.$message('请先在地图上绘制截断线') |
| | | return false |
| | | } |
| | | // 已绘制线图 进行绘制横断面数据分析 |
| | | const res = await mapApi.getCrossSection(this.hdmParam) |
| | | // 调用数据处理方法 |
| | | this.dealWithData(res) |
| | | // table数据处理 |
| | | const dataPoint = res.data.point |
| | | // 存储间距list |
| | | const spacingList = res.data.pointInterval.reverse() |
| | | for (let i = 0; i < dataPoint.length; i++) { |
| | | const obj = { |
| | | mediumtype: dataPoint[i].pipelines.extraData.mediumtype, |
| | | x: parseFloat(dataPoint[i].crossPoint3D.x).toFixed(4), |
| | | y: parseFloat(dataPoint[i].crossPoint3D.y).toFixed(4), |
| | | z: parseFloat(dataPoint[i].crossPoint3D.z).toFixed(4), |
| | | spacing: spacingList[i - 1] |
| | | } |
| | | this.tableData.push(obj) |
| | | } |
| | | }, |
| | | // 对获取到的数据进行处理 |
| | | dealWithData (e) { |
| | | console.log(e) |
| | | }, |
| | | // 横断面绘制完成后 进行横断面数据分析 进行图表展示 |
| | | selectRow (dataList) { |
| | | // console.log(dataList) |
| | | // 3. 使用刚指定的配置项和数据,显示图表 |
| | | this.option = { |
| | | tooltip: { |
| | | trigger: 'axis', |
| | | axisPointer: { |
| | | type: 'cross', |
| | | label: { |
| | | backgroundColor: '#6a7985' |
| | | } |
| | | } |
| | | }, |
| | | // legend: { |
| | | // // data: ['直接访问', '搜索引擎'] |
| | | // data: dataList |
| | | // }, |
| | | toolbox: { |
| | | show: false, |
| | | feature: { |
| | | saveAsImage: {} |
| | | } |
| | | }, |
| | | grid: { |
| | | left: '10px', |
| | | right: '0', |
| | | top: '10px', |
| | | bottom: '5px', |
| | | containLabel: true |
| | | }, |
| | | xAxis: [ |
| | | { |
| | | type: 'category', |
| | | boundaryGap: false, |
| | | axisLabel: { |
| | | // formatter: '{value}', |
| | | textStyle: { |
| | | color: '#fff' |
| | | } |
| | | } |
| | | // data: ['周一', '周二', '周三', '周四', '周五', '周六', '周日'] |
| | | // data: dataList |
| | | } |
| | | ], |
| | | yAxis: [ |
| | | { |
| | | type: 'value', |
| | | axisLabel: { |
| | | // formatter: '{value}', |
| | | textStyle: { |
| | | color: '#fff' |
| | | } |
| | | } |
| | | } |
| | | ], |
| | | // series: [ |
| | | // { |
| | | // name: '搜索引擎', |
| | | // type: 'line', |
| | | // stack: '总量', |
| | | // label: { |
| | | // show: true, |
| | | // position: 'top' |
| | | // }, |
| | | // areaStyle: {}, |
| | | // emphasis: { |
| | | // focus: 'series' |
| | | // }, |
| | | // data: [820, 932, 901, 934, 1290, 1330, 1320] |
| | | // } |
| | | // ] |
| | | series: this.echartsList |
| | | } |
| | | this.myChartShow = true |
| | | this.myChart.clear() |
| | | this.myChart.setOption(this.option) |
| | | }, |
| | | // 横断面清除 |
| | | jdmClear () { |
| | | this.hdmParam = null |
| | | this.tableData = [] |
| | | this.option = [] |
| | | this.myChartShow = false |
| | | this.myChart.clear() |
| | | if (this.measure != null) { |
| | | this.measure.destory() |
| | | } |
| | | } |
| | | } |
| | | } |
| | | </script> |
| | | |
| | | <style lang="less" scoped> |
| | | /deep/ .el-table { |
| | | margin-top: 15px; |
| | | } |
| | | |
| | | </style> |