Skip to content
目录

地形

加载地形

WARNING

地形功能需要你使用 maptalks-gl

mapbox

js
const map = new maptalks.Map("map", {
    // "center": [119.09557457, 30.14442343, 339.73126220703125], "zoom": 11.856275713521464, "pitch": 61.80000000000011, "bearing": -64.07337236948052,
    center: [108.95986733, 34.21997952, 430.3062438964844],
    zoom: 12.698416480987284,
    pitch: 0,
    bearing: 1.8437368186266667,
    // cameraInfiniteFar: true,
    // heightFactor: 4.2,
    zoomControl: true,
    // baseLayer: new maptalks.TileLayer('base', {
    //     urlTemplate: "https://webrd01.is.autonavi.com/appmaptile?lang=zh_cn&size=1&scale=1&style=8&x={x}&y={y}&z={z}",
    //     subdomains: ["a", "b", "c", "d"],
    // })
});

const sceneConfig = {
    postProcess: {
        enable: true,
        antialias: {
            enable: true,
        },
    },
};

const colors4 = [
    [0, "#F0F9E9"],
    [200, "#D7EFD1"],
    [400, "#A6DCB6"],
    [650, "#8FD4BD"],
    [880, "#67C1CB"],
    [1100, "#3C9FC8"],
    [1300, "#1171B1"],
    [1450, "#085799"],
    [1600, "#084586"],
];

const terrain = {
    type: "mapbox",
    // tileSize: 256,
    maxAvailableZoom: 14,

    requireSkuToken: false,
    urlTemplate: "mapbox terrain server url",
    subdomains: ["a", "b", "c", "d"],
    colors: colors4,
    exaggeration: 4,
};
const group = new maptalks.GroupGLLayer("group", [], {
    terrain,
});
group.addTo(map);

// map.setView({
//     "center": [120.06864866, 30.12911788, 430.3062438964844], "zoom": 12.814714048170666, "pitch": 56.45000000000009, "bearing": 2.7148818684635216
// })

map.setView({
    center: [118.25079334, 30.1210681, 430.3062438964844],
    zoom: 11.892086520379873,
    pitch: 66.64999999999992,
    bearing: 112.90705084326646,
});

天地图

WARNING

天地图地形需要设置地图投影为 EPSG:4326

js
map = new maptalks.Map("map", {
    center: [114.3404041441181, 30.548730054693106],
    zoom: 10,
    spatialReference: {
        projection: "EPSG:4326",
    },
});

const sceneConfig = {
    postProcess: {
        enable: true,
        antialias: {
            enable: true,
        },
    },
};

const skinLayers = [
    // baseLayer
];

const colors4 = [
    [0, "#F0F9E9"],
    [200, "#D7EFD1"],
    [400, "#A6DCB6"],
    [650, "#8FD4BD"],
    [880, "#67C1CB"],
    [1100, "#3C9FC8"],
    [1300, "#1171B1"],
    [1450, "#085799"],
    [1600, "#084586"],
];

const terrain = {
    type: "tianditu",
    // tileSize: 256,
    // terrainWidth: 65,
    shader: "lit",
    maxAvailableZoom: 12,
    // tileSystem: [1, -1, -180, 90],
    urlTemplate:
        "https://t{s}.tianditu.gov.cn/mapservice/swdx?T=elv_c&tk=your key&x={x}&y={y}&l={z}",
    subdomains: ["1", "2", "3", "4", "5"],
    colors: colors4,
    exaggeration: 4,
    material: {
        baseColorFactor: [1, 1, 1, 1],
        outputSRGB: 1,
        roughnessFactor: 0.69,
        metallicFactor: 0,
    },
};

const group = new maptalks.GroupGLLayer("group", skinLayers, {
    terrain,
});
group.addTo(map);
map.setView({
    center: [118.25079334, 30.1210681, 430.3062438964844],
    zoom: 9.892086520379873,
    pitch: 66.64999999999992,
    bearing: 112.90705084326646,
});

cesium/cesiumlab等cesium系

WARNING

cesium地形需要设置地图投影为 EPSG:4326

加载cesiumlab 地形数据例子

js
map = new maptalks.Map("map", {
    center: [114.3404041441181, 30.548730054693106],
    zoom: 10,
    spatialReference: {
        projection: "EPSG:4326",
    },
});

const sceneConfig = {
    postProcess: {
        enable: true,
        antialias: {
            enable: true,
        },
    },
};

const skinLayers = [
    // baseLayer
];

const colors4 = [
    [0, "#F0F9E9"],
    [200, "#D7EFD1"],
    [400, "#A6DCB6"],
    [650, "#8FD4BD"],
    [880, "#67C1CB"],
    [1100, "#3C9FC8"],
    [1300, "#1171B1"],
    [1450, "#085799"],
    [1600, "#084586"],
];
const terrain = {
    // tileSystem: [1, 1, -180, -90],
    // zoomOffset: -1,
    maxAvailableZoom: 14,
    type: "cesium-ion", //or cisium 本地部署的服务就cesium
    // terrainWidth: 65,
    accessToken: "your token",
    urlTemplate:
        "https://assets.ion.cesium.com/asset_depot/1/CesiumWorldTerrain/v1.2/{z}/{x}/{y}.terrain",
    shader: "lit",
    colors: colors6,
    exaggeration: 4,
};
const group = new maptalks.GroupGLLayer("group", skinLayers, {
    terrain,
});
group.addTo(map);
map.setView({
    center: [118.25079334, 30.1210681, 430.3062438964844],
    zoom: 11.892086520379873,
    pitch: 66.64999999999992,
    bearing: 112.90705084326646,
});

获取地形当前鼠标位置的数据

核心库从v1.0.0-rc.33开始,地图的事件系统我们加了地形相关的信息数据了,直接从事件属性读取对应的值即可

js
map.on("click mousemove", (e) => {
    console.log(e.terrain);
});

WARNING

  • 要求核心库版本 >=v1.0.0-rc.33
  • terrain的值可能为空,取决当前鼠标位置的地形数据是否加载完成,所以做好null判断

地形着色

新版本的maptalks-gl里添加了地形着色的支持

js
const colors5 = [
    [0, "#FBFBFB"],
    [200, "#D6D6D6"],
    [400, "#BEBEBE"],
    [650, "#AFAFAF"],
    [880, "#868686"],
    [1100, "#5E5E5E"],
    [1300, "#3F3F3F"],
    [1450, "#2B2B2B"],
    [1600, "#070707"],
];

const terrain = {
    type: "mapbox",
    tileSize: 256,
    maxAvailableZoom: 14,

    requireSkuToken: false,
    urlTemplate: "your server url",
    subdomains: ["a", "b", "c", "d"],
    colors: colors5,
    exaggeration: 4,
};
const group = new maptalks.GroupGLLayer("group", [], {
    terrain,
});
group.addTo(map);

地形着色过程中会自动颜色进行插值的的

  • colors参数表示每个海拔段的颜色值,中间的值会自动进行插值
  • exaggeration 表示地形夸张程度

效果怎样取决于你的视觉审美了

WARNING

地形着色和地形夸张目前不支持动态更新,即在配置好的那一刻就决定了效果

蒙层

地形支持setMask()的,业务里根据我们的需求设置不同的mask即可:

  • ClipInsideMask 内裁剪,挖洞
  • ClipOutsideMask

terrain mask demo

js
import { Circle, ClipInsideMask, GroupGLLayer } from "maptalks-gl";
const circle = new Circle([118.24874119019701, 30.13560350137501], 10000);
const shell = circle.getShell();
//ClipOutsideMask 是Polygon的子类,使用方式和Polygon一样
// const mask = new maptalks.ClipOutsideMask([shell]);
const mask = new ClipInsideMask([shell]);

const terrain = {
    type: "mapbox",
    tileSize: 256,
    maxAvailableZoom: 14,

    requireSkuToken: false,
    urlTemplate: "./../assets/data/tile-rgb/{z}/{x}/{y}.png",
    subdomains: ["a", "b", "c", "d"],
    colors: colors4,
    exaggeration: 4,
};
const group = new GroupGLLayer("group", [], {
    terrain,
});
group.addTo(map);

const terrainLayer = group.getTerrainLayer();
terrainLayer.setMask(mask);

This document is generated by mdpress