Home >Web Front-end >JS Tutorial >A brief discussion on using angular9+echarts to draw 3D maps

A brief discussion on using angular9+echarts to draw 3D maps

青灯夜游
青灯夜游forward
2021-03-25 11:37:252497browse

This article will share with you the usage of echarts in angular and introduce the method of drawing 3D maps. It has certain reference value. Friends in need can refer to it. I hope it will be helpful to everyone.

A brief discussion on using angular9+echarts to draw 3D maps

Create a new angular9 project

1. Install @angular-cli scaffolding

2. <strong>ng -v</strong>View version

3、ng new my-project(project name)

Download echarts

npm i echarts

Related recommendations: "angular tutorial"

Create container

src/app/app. componnet.html

<div id="main" style="width:800px;height:500px"></div>

Create map instance

src/app/app.componnet.ts

import { Component } from &#39;@angular/core&#39;;
import * as echarts from "echarts";
import  &#39;echarts/map/js/china.js&#39;
@Component({
  selector: &#39;app-root&#39;,
  templateUrl: &#39;./app.component.html&#39;,
  styleUrls: [&#39;./app.component.scss&#39;]
})
export class AppComponent {
  option = {
    title: {
        top: 10,
        text: &#39;3D中国地图&#39;,
        left: &#39;center&#39;,
        textStyle: {
            color: &#39;#fff&#39;
        }
    },
    backgroundColor: &#39;rgba(0, 10, 52, 1)&#39;,
    geo: {
        map: &#39;china&#39;,
        aspectScale: 0.75,
        layoutCenter: ["50%", "51.5%"], //地图位置
        layoutSize: &#39;118%&#39;,
        roam: true,
        itemStyle: {
            normal: {
                borderColor: &#39;rgba(147, 235, 248, 1)&#39;,
                borderWidth: 0.5,
                color: {
                    type: &#39;linear-gradient&#39;,
                    x: 0,
                    y: 1500,
                    x2: 2500,
                    y2: 0,
                    colorStops: [{
                        offset: 0,
                        color: &#39;#009DA1&#39; // 0% 处的颜色
                    }, {
                        offset: 1,
                        color: &#39;#005B9E&#39; // 50% 处的颜色
                    }],
                    global: true // 缺省为 false
                },
                opacity: 0.5,
            },
            emphasis: {
                areaColor: &#39;#2a333d&#39;
            }
        },
        regions: [{
            name: &#39;南海诸岛&#39;,
            itemStyle: {
                areaColor: &#39;rgba(0, 10, 52, 1)&#39;,
                borderColor: &#39;rgba(0, 10, 52, 1)&#39;
            },
            emphasis: {
                areaColor: &#39;rgba(0, 10, 52, 1)&#39;,
                borderColor: &#39;rgba(0, 10, 52, 1)&#39;
            }
        }],
        z: 2
    },
    series: [{
        type: &#39;map&#39;,
        map: &#39;china&#39;,
        tooltip: {
            show: false
        },
        label: {
            show: true,
            color: &#39;#FFFFFF&#39;,
            fontSize: 16
        },
        aspectScale: 0.75,
        layoutCenter: ["50%", "50%"], //地图位置
        layoutSize: &#39;118%&#39;,
        roam: true,
        itemStyle: {
            normal: {
                borderColor: &#39;rgba(147, 235, 248, 0.6)&#39;,
                borderWidth: 0.8,
                areaColor: {
                    type: &#39;linear-gradient&#39;,
                    x: 0,
                    y: 1200,
                    x2: 1000,
                    y2: 0,
                    colorStops: [{
                        offset: 0,
                        color: &#39;#009DA1&#39; // 0% 处的颜色
                    }, {
                        offset: 1,
                        color: &#39;#005B9E&#39; // 50% 处的颜色
                    }],
                    global: true // 缺省为 false
                },
            },
            emphasis: {
                areaColor: &#39;rgba(147, 235, 248, 0)&#39;
            }
        },
        zlevel: 1
    }]
};

  ngOnInit(){
    let dom = document.getElementById(&#39;main&#39;)
    let myChart = echarts.init(dom)
    myChart.on(&#39;georoam&#39;, function(params) {
      var option = myChart.getOption(); //获得option对象
      if (params.zoom != null && params.zoom != undefined) { //捕捉到缩放时
          option.geo[0].zoom = option.series[0].zoom; //下层geo的缩放等级跟着上层的geo一起改变
          option.geo[0].center = option.series[0].center; //下层的geo的中心位置随着上层geo一起改变
      } else { //捕捉到拖曳时
          option.geo[0].center = option.series[0].center; //下层的geo的中心位置随着上层geo一起改变
      }
      myChart.setOption(option); //设置option
  });
    myChart.setOption(this.option)
  }
}

Effect picture

A brief discussion on using angular9+echarts to draw 3D maps

For more programming related knowledge, please visit: Programming Video! !

The above is the detailed content of A brief discussion on using angular9+echarts to draw 3D maps. For more information, please follow other related articles on the PHP Chinese website!

Statement:
This article is reproduced at:csdn.net. If there is any infringement, please contact admin@php.cn delete