echarts地图轮播markpoint
正常添加echarts地图后,添加markpoint图层
javascript
//引入echarts 注册地图 略过 只展示关键代码
option.series= [
{
// roam: true,
name: '地图',
type: 'map',
id: 'mapData',
map: 'china',
data: this.outdata, //无需在意 配合visualMap给地图区块添加颜色使用
center: [95, 35],
zoom: 1.5,
z: 2,
itemStyle: {
borderColor: 'rgba(0,0,0,0.15)',
borderWidth: 1.3,
shadowColor: 'rgba(0,0,0,0.2)',
},
emphasis: {
label: {
show: true,
},
},
},
//下方是markpoint代码 因为echarts官方已经不推荐使用markpoint 改为使用scatter
{
type: 'scatter',
coordinateSystem: 'geo',
//下方的symbol替换为需要展示的图标的base64编码即可
symbol:
'image://',
symbolSize: 30,
symbolOffset: [0, '-50%'],
label: {
show: true,
position: 'top',
color: '#333333',
fontSize: 14,
fontWeight: 600,
formatter: '{b}', //配合下方data中的name使用 展示name
textBorderColor: '#ffffff',
textBorderWidth: 2,
textBorderType: 'solid',
},
emphasis: {
scale: 1.2,
label: {
fontSize: 18,
},
},
select: {
label: {
color: '#333333',
fontSize: 18,
fontWeight: 600,
},
},
data: [
{
name: '济南片区',
value: [117.2, 36.7],
},
{
name: '西南片区',
value: [104.065701, 30.659487],
},
{
name: '青岛片区',
value: [120.1, 36.4],
},
{
name: '华中片区',
value: [117.291321, 31.861125],
},
{
name: '华北片区',
value: [116.4, 39.9],
},
{
name: '华东片区',
value: [121.473701, 31.230393],
},
{
name: '华南片区',
value: [113.6, 23.1],
},
{
name: '东南片区',
value: [119.4543, 26.2875],
},
{
name: '中原片区',
value: [113.653427, 34.761125],
},
],
},
],
轮播代码如下:
思路是对当前高亮节点进行取消高亮操作,然后在高亮下一个节点
需要注意seriesIndex 可以通过在鼠标移入事件中添加打印信息获取
javascript
//该段代码在echarts初始化之后调用即可
startLunbo () {
if (this.intervalId) {
clearInterval(this.intervalId)
this.intervalId = null
}
this.intervalId = setInterval(() => {
this.myMapChart.dispatchAction({
type: 'downplay',
seriesIndex: 1,
dataIndexInside: this.lunboId === 0 ? 8 : this.lunboId - 1, //和上面的代码片段中data的长度有关
})
this.myMapChart.dispatchAction({
type: 'highlight',
seriesIndex: 1,
dataIndexInside: this.lunboId,
})
this.toolIdx = this.lunboId
this.lunboId++
if (this.lunboId > 8) { //和上面的代码片段中data的长度有关
this.lunboId = 0
}
}, 2500)
}
其中鼠标的移入移出事件 自行完成即可