antv-l7/docs/api/earth/earth.zh.md

5.2 KiB
Raw Blame History

title order
地球模式 1

markdown:docs/common/style.md

简介

l7-maps 提供 Earth 地图相较于高德地图、mapbox 地图,是完全不同的一种表现形式,提供了全球视角下的可视化展示能力,为用户提供了更多的地理信息可视化表现形式。

为了区别普通的地图l7-maps 提供了全新的 Earth 地图类型, L7 提供对应的 EarthLayer 图层

import { EarthLayer } from '@antv/l7';
import { Earth } from '@antv/l7-maps';

目前在地球模式下支持的图层类型

点图层

  • 平面点: shape: 'circle'
  • 圆柱点: shape: 'cylinder'

线图层

  • 3D 弧线: shape: 'arc3d'

使用

// 1、引入对应模块
import { Scene, Earth } from '@antv/l7-maps';
import { EarthLayer } from '@antv/l7-layers';

// 2、构建 Earth Map
const scene = new Scene({
  id: 'map',
  map: new Earth({}),
});

// 3、构建地球图层当前的 shape 为 base表示基础球体
const earthlayer = new EarthLayer()
  .source(
    // 地球表面的纹理
    'https://gw.alipayobjects.com/mdn/rms_23a451/afts/img/A*3-3NSpqRqUoAAAAAAAAAAAAAARQnAQ',
    {
      parser: {
        type: 'image',
        extent: [121.168, 30.2828, 121.384, 30.421],
      },
    },
  )
  .color('#f00')
  .shape('base')
  .style({
    opacity: 1.0,
    radius: 40,
    globelOtions: {
      ambientRatio: 0.6, // 环境光
      diffuseRatio: 0.4, // 漫反射
      specularRatio: 0.1, // 高光反射
      earthTime: 0.1,
    },
  })
  .animate(true);

scene.on('loaded', () => {
  // 4、添加基础地球球体
  scene.addLayer(earthlayer);
});
// 经过上述的步骤,我们就可以在场景中添加一个基础的地球了

独立的地图类型 Earth

构造函数 Earth

作为 l7-maps 的基础地图类型,Earth 提供了地球系统的相机系统,目前只需要传入一个空对象。

  • args: {}
import { Scene, Earth } from '@antv/l7-maps';

const scene = new Scene({
  id: 'map',
  map: new Earth({}),
});

rotateY

提供了简单的方法控制地球系统的旋转(实际上控制的是相机的旋转,需要传入一个对象

  • force: false 判断是否强制生效,默认该方法的优先级比用户鼠标操作要低,当用户操作相机的时候,该方法会失效
  • reg: 0.01 旋转的角度(视觉上地球的旋转角度), reg 表示的并不是实际的旋转角度,而是单位旋转角度的比例
    🌟 单位旋转角度 = Math.min(this.earthCameraZoom * this.earthCameraZoom, 1)
import { Scene, Earth } from '@antv/l7-maps';

const scene = new Scene({
  id: 'map',
  map: new Earth({}),
});

const mapService = scene.getMapService();

function step() {
  mapService.rotateY({
    option: {
      force: true,
      reg: 0.1,
    },
  });
  requestAnimationFrame(step);
}

scene.on('loaded', () => {
  scene.addLayer(earthlayer);
  step();
});

地图图层 EarthLayer

地球图层区别于普通高德地图和 Mapbox 地图的图层,只在地球模式下可以被使用,用于表示地球的球体、大气层、辉光等效果。
🌟 使用不同的 shape 参数表示区别不同的地球图层。

地球球体图层 baseLayer

  • source: 数据

    • map: 地球表面纹理贴图的地址
    • parser: 解析器,目前只需要写固定的对象值即可: { parser: { type: "image" } }
  • shape: 图层类型

    默认值是 base, 目前支持的 shape 类型有:

    • base: 球体
    • atomSphere: 大气层
    • bloomSphere: 辉光

    当用户的 shape 参数不被识别时,自动降级为 base 类型

  • globelOtions: 图层样式

    • ambientRatio: 环境光
    • diffuseRatio: 漫反射
    • specularRatio: 高光反射
const earthlayer = new EarthLayer()
  .source(
    'https://gw.alipayobjects.com/mdn/rms_23a451/afts/img/A*3-3NSpqRqUoAAAAAAAAAAAAAARQnAQ',
    {
      parser: {
        type: 'image',
      },
    },
  )
  .shape('base')
  .style({
    globelOtions: {
      ambientRatio: 0.6, // 环境光
      diffuseRatio: 0.4, // 漫反射
      specularRatio: 0.1, // 高光反射
    },
  });
L7 地球图层

地球内发光/大气图层 atomLayer

atomLayer 作为地球的效果图层,不需要传入数据,所以可以不调用 source 方法

const atomLayer = new EarthLayer()
  .color('#2E8AE6')
  .shape('atomSphere')
  .style({
    // 可以控制发光程度
    opacity: 1,
  });
L7 地球图层大气效果

地球内外发光/辉光图层 bloomLayer

bloomLayer 作为地球的效果图层,不需要传入数据,所以可以不调用 source 方法

const bloomLayer = new EarthLayer()
  .color('#fff')
  .shape('bloomSphere')
  .style({
    opacity: 0.5,
  });
L7 地球图层辉光效果